forked from GuiltyTargets/guiltytargets-results
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
121 lines (99 loc) · 3.08 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
# -*- coding: utf-8 -*-
"""Setup module for the gene_prioritization package."""
import codecs # To use a consistent encoding
import os
import re
import setuptools
#################################################################
PACKAGES = setuptools.find_packages(where='src')
META_PATH = os.path.join('src', '__init__.py')
KEYWORDS = ['Gene Prioritization', 'Networks Biology',
'Drug Target Prioritization']
CLASSIFIERS = [
'Development Status :: 4 - Beta',
'Environment :: Console',
'Intended Audience :: Developers',
'Intended Audience :: Science/Research',
'License :: OSI Approved :: MIT Software License',
'Operating System :: OS Independent',
'Programming Language :: Python',
'Programming Language :: Python :: 3.4',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
'Topic :: Scientific/Engineering :: Bio-Informatics'
]
INSTALL_REQUIRES = [
'numpy',
'pandas',
'scipy',
'py2cytoscape',
'rpy2',
'scikit-learn',
'xlrd',
'openpyxl',
'python-igraph',
'click',
'jinja2',
]
EXTRAS_REQUIRE = {
}
TESTS_REQUIRE = [
]
ENTRY_POINTS = {
'console_scripts': [
'gene_prioritization = gene_prioritization.cli:main',
]
}
DEPENDENCY_LINKS = [
]
PACKAGE_DATA = {
'': [
'*.r',
'*.R'
]
}
#################################################################
HERE = os.path.abspath(os.path.dirname(__file__))
def read(*parts):
"""Build an absolute path from *parts* and return the contents of the resulting file. Assume UTF-8 encoding."""
with codecs.open(os.path.join(HERE, *parts), 'rb', 'utf-8') as f:
return f.read()
META_FILE = read(META_PATH)
def find_meta(meta):
"""Extract __*meta*__ from META_FILE"""
meta_match = re.search(
r'^__{meta}__ = ["\']([^"\']*)["\']'.format(meta=meta),
META_FILE, re.M
)
if meta_match:
return meta_match.group(1)
raise RuntimeError('Unable to find __{meta}__ string'.format(meta=meta))
def get_long_description():
"""Get the long_description from the README.rst file. Assume UTF-8 encoding."""
with codecs.open(os.path.join(HERE, 'README.rst'), encoding='utf-8') as f:
long_description = f.read()
return long_description
if __name__ == '__main__':
setuptools.setup(
name=find_meta('title'),
version=find_meta('version'),
description=find_meta('description'),
long_description=get_long_description(),
url=find_meta('url'),
author=find_meta('author'),
author_email=find_meta('email'),
maintainer=find_meta('author'),
maintainer_email=find_meta('email'),
license=find_meta('license'),
classifiers=CLASSIFIERS,
keywords=KEYWORDS,
packages=PACKAGES,
package_dir={'': 'src'},
install_requires=INSTALL_REQUIRES,
extras_require=EXTRAS_REQUIRE,
tests_require=TESTS_REQUIRE,
entry_points=ENTRY_POINTS,
dependency_links=DEPENDENCY_LINKS,
package_data=PACKAGE_DATA,
include_package_data=True,
)