-
Notifications
You must be signed in to change notification settings - Fork 8
Expand file tree
/
Copy pathsetup.py
More file actions
executable file
·132 lines (118 loc) · 4.6 KB
/
setup.py
File metadata and controls
executable file
·132 lines (118 loc) · 4.6 KB
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
128
129
130
131
132
#!/usr/bin/env python
"""
Setup script for oxasl
"""
import os
import subprocess
import re
import io
from setuptools import setup
from setuptools import find_packages
MODULE = 'oxasl'
def get_filetext(rootdir, filename):
""" Get the text of a local file """
with io.open(os.path.join(rootdir, filename), encoding='utf-8') as f:
return f.read()
def git_version():
""" Get the full and python standardized version from Git tags (if possible) """
try:
# Full version includes the Git commit hash
full_version = subprocess.check_output('git describe --dirty', shell=True).decode("utf-8").strip(" \n")
# Python standardized version in form major.minor.patch.post<build>
version_regex = re.compile(r"v?(\d+\.\d+\.\d+(-\d+)?).*")
match = version_regex.match(full_version)
if match:
std_version = match.group(1).replace("-", ".post")
else:
raise RuntimeError("Failed to parse version string %s" % full_version)
return full_version, std_version
except:
# Any failure, return None. We may not be in a Git repo at all
return None, None
def git_timestamp():
""" Get the last commit timestamp from Git (if possible)"""
try:
return subprocess.check_output('git log -1 --format=%cd', shell=True).decode("utf-8").strip(" \n")
except:
# Any failure, return None. We may not be in a Git repo at all
return None
def update_metadata(rootdir, version_str, timestamp_str):
""" Update the version and timestamp metadata in the module _version.py file """
with io.open(os.path.join(rootdir, MODULE, "_version.py"), "w", encoding='utf-8') as f:
f.write("__version__ = '%s'\n" % version_str)
f.write("__timestamp__ = '%s'\n" % timestamp_str)
def get_requirements(rootdir):
""" Get a list of all entries in the requirements file """
with io.open(os.path.join(rootdir, 'requirements.txt'), encoding='utf-8') as f:
return [l.strip() for l in f.readlines()]
def get_version(rootdir):
""" Get the current version number (and update it in the module _version.py file if necessary)"""
version, timestamp = git_version()[1], git_timestamp()
if version is not None and timestamp is not None:
# We got the metadata from Git - update the version file
update_metadata(rootdir, version, timestamp)
else:
# Could not get metadata from Git - use the version file if it exists
with io.open(os.path.join(rootdir, MODULE, '_version.py'), encoding='utf-8') as f:
md = f.read()
match = re.search(r"^__version__ = ['\"]([^'\"]*)['\"]", md, re.M)
if match:
version = match.group(1)
else:
version = "unknown"
return version
module_dir = os.path.abspath(os.path.dirname(__file__))
kwargs = {
'name' : 'oxasl',
'version' : get_version(module_dir),
'description' : 'Python library for manipulating and modelling ASL data',
'long_description' : get_filetext(module_dir, 'README.md'),
'long_description_content_type' : 'text/markdown',
'url' : 'https://oxasl.readthedocs.io/',
'author' : 'Martin Craig',
'author_email' : 'martin.craig@eng.ox.ac.uk',
'license' : 'Apache-2.0',
'install_requires' : get_requirements(module_dir),
'packages' : find_packages(),
'package_data' : {
'oxasl.gui': ['banner.png', 'icon.png']
},
'entry_points' : {
'console_scripts' : [
"oxasl_preproc=oxasl.preproc:main",
"oxasl_basil=oxasl.basil:main",
"oxasl_calib=oxasl.calib:main",
"oxasl_mask=oxasl.mask:main",
"oxasl_reg=oxasl.reg:main",
"oxasl=oxasl.pipeline:main",
"oxasl_region_analysis=oxasl.region_analysis:main",
],
'gui_scripts' : [
"oxasl_gui=oxasl.gui:main",
],
},
'classifiers' : [
'Development Status :: 3 - Alpha',
'Intended Audience :: Science/Research',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3',
'Topic :: Scientific/Engineering :: Bio-Informatics',
'License :: OSI Approved :: Apache Software License',
],
}
try:
from sphinx.setup_command import BuildDoc
kwargs["cmdclass"] = {
'doc' : BuildDoc,
}
kwargs["command_options"] = {
'doc': {
'version': ('setup.py', kwargs["version"]),
'release': ('setup.py', kwargs["version"]),
'source_dir': ('setup.py', 'doc'),
'build_dir': ('setup.py', 'doc'),
}
}
except:
pass
setup(**kwargs)