forked from PaddlePaddle/PGL
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsetup.py
executable file
·127 lines (104 loc) · 3.83 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import os
import sys
import re
import codecs
from setuptools import setup, find_packages
from setuptools import Extension
from setuptools import dist
from setuptools.command.build_ext import build_ext as _build_ext
try:
from Cython.Build import cythonize
except ImportError:
def cythonize(*args, **kwargs):
"""cythonize"""
from Cython.Build import cythonize
return cythonize(*args, **kwargs)
class CustomBuildExt(_build_ext):
"""CustomBuildExt"""
def finalize_options(self):
_build_ext.finalize_options(self)
# Prevent numpy from thinking it is still in its setup process:
__builtins__.__NUMPY_SETUP__ = False
import numpy
self.include_dirs.append(numpy.get_include())
workdir = os.path.dirname(os.path.abspath(__file__))
with open(os.path.join(workdir, './requirements.txt')) as f:
requirements = f.read().splitlines()
cur_dir = os.path.abspath(os.path.dirname(__file__))
with open(os.path.join(cur_dir, 'README.md'), 'rb') as f:
lines = [x.decode('utf-8') for x in f.readlines()]
lines = ''.join([re.sub('^<.*>\n$', '', x) for x in lines])
long_description = lines
compile_extra_args = ["-std=c++11"]
link_extra_args = []
if sys.platform == "darwin":
compile_extra_args = ['-std=c++11', "-mmacosx-version-min=10.9"]
link_extra_args = ["-stdlib=libc++", "-mmacosx-version-min=10.9"]
def read(*parts):
with codecs.open(os.path.join(cur_dir, *parts), 'r') as fp:
return fp.read()
# Reference: https://github.com/pypa/pip/blob/master/setup.py
def find_version(*file_paths):
version_file = read(*file_paths)
version_match = re.search(
r"^__version__ = ['\"]([^'\"]*)['\"]",
version_file,
re.M, )
if version_match:
return version_match.group(1)
raise RuntimeError("Unable to find version string.")
extensions = [
Extension(
"pgl.graph_kernel",
["pgl/graph_kernel.pyx"],
language="c++",
extra_compile_args=compile_extra_args,
extra_link_args=link_extra_args, ),
]
def get_package_data(path):
files = []
for root, dirnames, filenames in os.walk(path):
for filename in filenames:
files.append(os.path.join(root, filename))
return files
package_data = {'pgl': get_package_data(os.path.join(cur_dir, 'pgl/data'))}
setup(
name="pgl",
description='Paddle Graph Learning',
version=find_version("pgl", "__init__.py"),
long_description=long_description,
long_description_content_type='text/markdown',
url="https://github.com/PaddlePaddle/PGL",
package_data=package_data,
setup_requires=[
'setuptools>=18.0',
'numpy>=1.16.4',
],
install_requires=requirements,
cmdclass={'build_ext': CustomBuildExt},
packages=find_packages(),
include_package_data=True,
#ext_modules=cythonize(extensions),
ext_modules=extensions,
classifiers=[
'Intended Audience :: Developers',
'License :: OSI Approved :: Apache Software License',
'Operating System :: OS Independent',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
'Programming Language :: Python :: 3.7',
], )