-
Notifications
You must be signed in to change notification settings - Fork 80
Expand file tree
/
Copy pathsetup.py
More file actions
186 lines (162 loc) · 5.6 KB
/
setup.py
File metadata and controls
186 lines (162 loc) · 5.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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
import os
from glob import glob
from setuptools import setup, find_packages
import subprocess
import imp
from distutils.core import setup
from distutils.command.clean import clean
from distutils.command.install import install
class InstallRuntime(install):
# Calls the default run command, then deletes the build area
# (equivalent to "setup clean --all").
def run(self):
install.run(self)
c = clean(self.distribution)
c.all = True
c.finalize_options()
c.run()
DISTNAME = 'dynamicgem'
MAINTAINER = 'Palash Goyal, Sujit Rokka Chhetri'
MAINTAINER_EMAIL = 'palashgo@usc.edu, schhetri@uci.edu'
DESCRIPTION = 'dynamicGEM: A Python module for Dynamic Graph Embedding Methods'
LONG_DESCRIPTION = open('README.md').read()
URL = 'https://github.com/palash1992/DynamicGEM'
DOWNLOAD_URL = 'https://github.com/palash1992/DynamicGEM'
KEYWORDS = ['dynamic graph embedding', 'graph embedding', 'network analysis',
'network embedding', 'data mining', 'machine learning']
LICENSE = 'BSD'
VERSION = '1.0.0'
ISRELEASED = True
INSTALL_REQUIRES = (
'tensorflow==1.11.0',
'Cython>=0.29',
'h5py==2.8.0',
'joblib>=0.12.5',
'Keras>=2.2.4',
'matplotlib==3.0.1',
'networkx>=1.11',
'numpy>=1.15.3',
'pandas>=0.23.4',
'scikit-learn>=0.20.0',
'scipy>=1.1.0',
'seaborn>=0.9.0',
'six>=1.11.0',
'sklearn>=0.0'
)
def get_package_data(topdir, excluded=set()):
retval = []
for dirname, subdirs, files in os.walk(os.path.join(DISTNAME, topdir)):
for x in excluded:
if x in subdirs:
subdirs.remove(x)
retval.append(os.path.join(dirname[len(DISTNAME) + 1:], '*.*'))
return retval
def get_data_files(dest, source):
retval = []
for dirname, subdirs, files in os.walk(source):
retval.append(
(os.path.join(dest, dirname[len(source) + 1:]), glob(os.pathjoin(dirname, '*.*')))
)
return retval
# Return the git revision as a string
def git_version():
"""Return the git revision as a string.
Copied from numpy setup.py
"""
def _minimal_ext_cmd(cmd):
# construct minimal environment
env = {}
for k in ['SYSTEMROOT', 'PATH']:
v = os.environ.get(k)
if v is not None:
env[k] = v
# LANGUAGE is used on win32
env['LANGUAGE'] = 'C'
env['LANG'] = 'C'
env['LC_ALL'] = 'C'
out = subprocess.Popen(cmd, stdout=subprocess.PIPE, env=env).communicate()[0]
return out
try:
out = _minimal_ext_cmd(['git', 'rev-parse', 'HEAD'])
GIT_REVISION = out.strip().decode('ascii')
except OSError:
GIT_REVISION = "Unknown"
return GIT_REVISION
def write_version_py(filename='dynamicgem/version.py'):
# Copied from numpy setup.py
cnt = """
# THIS FILE IS GENERATED FROM DynamicGEM SETUP.PY
short_version = '%(version)s'
version = '%(version)s'
full_version = '%(full_version)s'
git_revision = '%(git_revision)s'
release = %(isrelease)s
if not release:
version = full_version
short_version += ".dev"
"""
FULLVERSION = VERSION
if os.path.exists('.git'):
GIT_REVISION = git_version()
elif os.path.exists('dynamicgem/version.py'):
# must be a source distribution, use existing version file
version = imp.load_source('DynamicGEM.version', 'dynamicgem/version.py')
GIT_REVISION = version.git_revision
else:
GIT_REVISION = 'Unknown'
if not ISRELEASED:
FULLVERSION += '.dev0+' + GIT_REVISION[:7]
a = open(filename, 'w')
try:
a.write(cnt % {'version': VERSION,
'full_version': FULLVERSION,
'git_revision': GIT_REVISION,
'isrelease': str(ISRELEASED)})
finally:
a.close()
def setup_package():
write_version_py()
setup(
name=DISTNAME,
version=VERSION,
author=MAINTAINER,
author_email=MAINTAINER_EMAIL,
maintainer=MAINTAINER,
maintainer_email=MAINTAINER_EMAIL,
description=DESCRIPTION,
url=URL,
download_url=DOWNLOAD_URL,
keywords=KEYWORDS,
install_requires=INSTALL_REQUIRES,
packages=find_packages(),
package_dir={DISTNAME: 'dynamicgem'},
package_data={DISTNAME: get_package_data('datasets')},
license=LICENSE,
long_description=LONG_DESCRIPTION,
classifiers=['Intended Audience :: Science/Research',
'Intended Audience :: Developers',
'License :: OSI Approved',
'Programming Language :: Python',
'Topic :: Software Development',
'Topic :: Scientific/Engineering',
'Topic :: Scientific/Engineering :: Artificial Intelligence',
'Topic :: Scientific/Engineering :: Graph Analysis',
'Programming Language :: Python :: 3.5', ],
)
def timer_setup():
setup(
name="matlabruntimeforpython",
version="R2017a",
description='A module to call MATLAB from Python',
author='MathWorks',
url='http://www.mathworks.com/',
platforms=['Linux', 'Windows', 'MacOS'],
packages=[ 'TIMERS_ALL' ],
package_dir={'TIMERS_ALL': 'dynamicgem/TIMERS/TIMERS_ALL/for_redistribution_files_only/TIMERS_ALL'},
package_data={'TIMERS_ALL': ['*.ctf']},
# Executes the custom code above in order to delete the build area.
cmdclass={'install': InstallRuntime}
)
if __name__ == "__main__":
setup_package()
timer_setup()