forked from python-dugong/python-dugong
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
executable file
·107 lines (89 loc) · 3.51 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
#!/usr/bin/env python3
import sys
import os.path
import warnings
import subprocess
try:
import setuptools
except ImportError:
raise SystemExit('Setuptools/distribute package not found. Please install from '
'https://pypi.python.org/pypi/distribute')
if sys.version_info < (3,3):
raise SystemExit('Python version is %d.%d.%d, but Dugong requires 3.3 or newer'
% sys.version_info[:3])
basedir = os.path.abspath(os.path.dirname(sys.argv[0]))
if os.path.exists(os.path.join(basedir, 'MANIFEST.in')):
print('found MANIFEST.in, running in developer mode')
warnings.resetwarnings()
# We can't use `error`, because e.g. Sphinx triggers a
# DeprecationWarning.
warnings.simplefilter('default')
def main():
try:
from sphinx.application import Sphinx #pylint: disable-msg=W0612
except ImportError:
pass
else:
fix_docutils()
with open(os.path.join(basedir, 'README.rst'), 'r') as fh:
long_desc = fh.read()
import dugong
setuptools.setup(
name='dugong',
zip_safe=True,
long_description=long_desc,
version=dugong.__version__,
description=('A HTTP 1.1 client module supporting asynchronous IO, pipelining '
'and `Expect: 100-continue`. Designed for RESTful protocols.'),
author='Nikolaus Rath',
author_email='Nikolaus@rath.org',
license='PSF',
keywords=['http'],
package_dir={'': '.'},
packages=setuptools.find_packages(),
url='https://github.com/python-dugong/python-dugong/',
classifiers=['Programming Language :: Python :: 3',
'Development Status :: 5 - Production/Stable',
'Intended Audience :: Developers',
'License :: OSI Approved :: Python Software Foundation License',
'Topic :: Internet :: WWW/HTTP',
'Topic :: Software Development :: Libraries :: Python Modules' ],
provides=['dugong'],
cmdclass={'upload_docs': upload_docs },
command_options={ 'sdist': { 'formats': ('setup.py', 'bztar') } ,
'build_sphinx': {'version': ('setup.py', dugong.__version__),
'release': ('setup.py', dugong.__version__) }},
)
def fix_docutils():
'''Work around https://bitbucket.org/birkenfeld/sphinx/issue/1154/'''
import docutils.parsers
from docutils.parsers import rst
old_getclass = docutils.parsers.get_parser_class
# Check if bug is there
try:
old_getclass('rst')
except AttributeError:
pass
else:
return
def get_parser_class(parser_name):
"""Return the Parser class from the `parser_name` module."""
if parser_name in ('rst', 'restructuredtext'):
return rst.Parser
else:
return old_getclass(parser_name)
docutils.parsers.get_parser_class = get_parser_class
assert docutils.parsers.get_parser_class('rst') is rst.Parser
class upload_docs(setuptools.Command):
user_options = []
boolean_options = []
description = "Upload documentation"
def initialize_options(self):
pass
def finalize_options(self):
pass
def run(self):
subprocess.check_call(['rsync', '-aHv', '--del', os.path.join(basedir, 'doc', 'html') + '/',
'ebox.rath.org:/srv/www.rath.org/dugong-docs/'])
if __name__ == '__main__':
main()