-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
138 lines (105 loc) · 3.97 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
128
129
130
131
132
133
134
135
136
137
138
import sys
import os
import re
import logging
import argparse
import subprocess
from setuptools import setup, find_packages
from contextlib import contextmanager
ROOT = os.path.dirname(__file__)
def get_long_description():
with open(os.path.join(ROOT, 'README.md'), encoding='utf-8') as f:
markdown_txt = f.read()
try:
import pypandoc
long_description = pypandoc.convert(markdown_txt, 'rst', format='md')
except(IOError, ImportError):
logging.warning("Could not import package 'pypandoc'. Will not convert markdown readme to rst for PyPI.")
long_description = markdown_txt
return long_description
def get_version():
VERSION_RE = re.compile(r'''__version__ = ['"]([0-9.]+)['"]''')
init = open(os.path.join(ROOT, 'sockeye', '__init__.py')).read()
return VERSION_RE.search(init).group(1)
def get_git_hash():
try:
sp = subprocess.Popen(['git', 'rev-parse', 'HEAD'], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
out_str = sp.communicate()[0].decode("utf-8").strip()
return out_str
except:
return "unkown"
@contextmanager
def temporarily_write_git_hash(git_hash, filename=os.path.join('sockeye', 'git_version.py')):
"""Temporarily create a module git_version in sockeye so that it will be included when installing and packaging."""
content = """
# This file is automatically generated in setup.py
git_hash = "%s"
""" % git_hash
if os.path.exists(filename):
raise RuntimeError("%s already exists, will not overwrite" % filename)
with open(filename, "w") as out:
out.write(content)
try:
yield
except:
raise
finally:
os.remove(filename)
def get_requirements(filename):
with open(os.path.join(ROOT, filename)) as f:
return [line.rstrip() for line in f]
try:
from sphinx.setup_command import BuildDoc
cmdclass = {'build_sphinx': BuildDoc}
except:
logging.warning("Package 'sphinx' not found. You will not be able to build docs.")
cmdclass = {}
parser = argparse.ArgumentParser(add_help=False)
parser.add_argument('-r', '--requirement', help='Optionally specify a different requirements.txt file.', required=False)
args, unparsed_args = parser.parse_known_args()
sys.argv[1:] = unparsed_args
if args.requirement is None:
install_requires = get_requirements('requirements.txt')
else:
install_requires = get_requirements(args.requirement)
args = dict(
name='sockeye',
version=get_version(),
description='Sequence-to-Sequence framework for Neural Machine Translation',
long_description=get_long_description(),
url='https://github.com/awslabs/sockeye',
author='Amazon',
author_email='sockeye-dev@amazon.com',
maintainer_email='sockeye-dev@amazon.com',
license='Apache License 2.0',
python_requires='>=3',
packages=find_packages(exclude=("test",)),
setup_requires=['pytest-runner'],
tests_require=['pytest', 'pytest-cov'],
extras_require={
'optional': ['mxboard', 'matplotlib'],
'dev': get_requirements('requirements.dev.txt')
},
install_requires=install_requires,
entry_points={
'console_scripts': [
'sockeye-average = sockeye.average:main',
'sockeye-embeddings = sockeye.embeddings:main',
'sockeye-evaluate = sockeye.evaluate:main',
'sockeye-extract-parameters = sockeye.extract_parameters:main',
'sockeye-lexicon = sockeye.lexicon:main',
'sockeye-init-embed = sockeye.init_embedding:main',
'sockeye-prepare-data = sockeye.prepare_data:main',
'sockeye-train = sockeye.train:main',
'sockeye-translate = sockeye.translate:main',
'sockeye-vocab = sockeye.vocab:main'
],
},
classifiers = [
'License :: OSI Approved :: Apache Software License',
'Programming Language :: Python :: 3 :: Only',
],
cmdclass=cmdclass,
)
with temporarily_write_git_hash(get_git_hash()):
setup(**args)