-
Notifications
You must be signed in to change notification settings - Fork 60
/
setup.py
102 lines (87 loc) · 3.72 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
import os
from setuptools import setup, find_packages, Extension
from setuptools.command.build_ext import build_ext
with open('requirements.txt') as f:
required_dependencies = f.read().splitlines()
external_dependencies = []
for dependency in required_dependencies:
if dependency[0:2] == '-e':
repo_name = dependency.split('=')[-1]
repo_url = dependency[3:]
external_dependencies.append('{} @ {}'.format(repo_name, repo_url))
else:
external_dependencies.append(dependency)
def get_extensions():
uncompress = Extension('scilpy.tractograms.uncompress',
['scilpy/tractograms/uncompress.pyx'])
quick_tools = Extension('scilpy.tractanalysis.quick_tools',
['scilpy/tractanalysis/quick_tools.pyx'])
voxel_boundary_intersection =\
Extension('scilpy.tractanalysis.voxel_boundary_intersection',
['scilpy/tractanalysis/voxel_boundary_intersection.pyx'])
streamlines_metrics =\
Extension('scilpy.tractanalysis.streamlines_metrics',
['scilpy/tractanalysis/streamlines_metrics.pyx'])
return [uncompress, quick_tools,
voxel_boundary_intersection, streamlines_metrics]
class CustomBuildExtCommand(build_ext):
""" build_ext command to use when numpy headers are needed. """
def run(self):
# Now that the requirements are installed, get everything from numpy
from Cython.Build import cythonize
from numpy import get_include
# Add everything requires for build
self.swig_opts = None
self.include_dirs = [get_include()]
self.distribution.ext_modules[:] = cythonize(
self.distribution.ext_modules)
# Call original build_ext command
build_ext.finalize_options(self)
build_ext.run(self)
# Get the requiered python version
PYTHON_VERSION = ""
with open('.python-version') as f:
f.readline()
PYTHON_VERSION = f.readline().strip("\n")
# Get version and release info, which is all stored in scilpy/version.py
ver_file = os.path.join('scilpy', 'version.py')
with open(ver_file) as f:
exec(f.read())
entry_point_legacy = []
if os.getenv('SCILPY_LEGACY') != 'False':
entry_point_legacy = ["{}=scripts.legacy.{}:main".format(
os.path.basename(s),
os.path.basename(s).split(".")[0]) for s in LEGACY_SCRIPTS]
opts = dict(name=NAME,
maintainer=MAINTAINER,
maintainer_email=MAINTAINER_EMAIL,
description=DESCRIPTION,
long_description=LONG_DESCRIPTION,
url=URL,
download_url=DOWNLOAD_URL,
license=LICENSE,
classifiers=CLASSIFIERS,
author=AUTHOR,
author_email=AUTHOR_EMAIL,
platforms=PLATFORMS,
version=VERSION,
packages=find_packages(),
cmdclass={
'build_ext': CustomBuildExtCommand
},
ext_modules=get_extensions(),
python_requires=PYTHON_VERSION,
setup_requires=[], # replaced by PEP518 (pyproject.toml)
install_requires=external_dependencies,
entry_points={
'console_scripts': ["{}=scripts.{}:main".format(
os.path.basename(s),
os.path.basename(s).split(".")[0]) for s in SCRIPTS] +
entry_point_legacy
},
data_files=[('data/LUT',
["data/LUT/freesurfer_desikan_killiany.json",
"data/LUT/freesurfer_subcortical.json",
"data/LUT/dk_aggregate_structures.json"])],
include_package_data=True)
setup(**opts)