This repository has been archived by the owner on Nov 2, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsetup.py
executable file
·105 lines (86 loc) · 3.69 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
#!/usr/bin/env python
# -*- encoding: utf-8 -*-
# ======================================================================
"""
Copyright and other protections apply. Please see the accompanying
:doc:`LICENSE <LICENSE>` and :doc:`CREDITS <CREDITS>` file(s) for rights
and restrictions governing use of this software. All rights not
expressly waived or licensed are reserved. If those files are missing or
appear to be modified from their originals, then please contact the
author before viewing or using this software in any capacity.
"""
# ======================================================================
# See <https://bugs.python.org/setuptools/issue152>
from __future__ import absolute_import, division, print_function
# ---- Imports ---------------------------------------------------------
import setuptools
import codecs
import inspect
import os
# ---- Data ------------------------------------------------------------
__all__ = ()
_MY_DIR = os.path.abspath(os.path.dirname(inspect.stack()[0][1]))
INSTALL_REQUIRES = (
'Django >= 1.8.0',
'django-fernet-fields',
'future',
'slacker',
)
TESTS_REQUIRE = [
'pytest',
]
# WARNING: This imposes limitations on tests/requirements.txt such that
# the full Pip syntax is not supported. See also
# <http://stackoverflow.com/questions/14399534/>.
with open(os.path.join(_MY_DIR, 'tests', 'requirements.txt')) as f:
TESTS_REQUIRE.extend(f.read().splitlines())
# ---- Initialization --------------------------------------------------
vers_info = {
'__path__': os.path.join(_MY_DIR, 'emojiwatch', 'version.py'),
}
if os.path.isfile(vers_info['__path__']):
with open(vers_info['__path__']) as _version_file:
exec(compile(_version_file.read(), vers_info['__path__'], 'exec'), vers_info, vers_info) # pylint: disable=exec-used
with codecs.open(os.path.join(_MY_DIR, 'README.rst'), encoding='utf-8') as readme_file:
README = readme_file.read()
__vers_str__ = vers_info.get('__vers_str__')
__release__ = vers_info.get('__release__', __vers_str__)
SETUP_ARGS = {
'name': 'django-emojiwatch',
'version': __vers_str__,
'author': 'Matt Bogosian',
'author_email': '[email protected]',
'url': 'https://django-emojiwatch.readthedocs.org/en/{}/'.format(__release__),
'license': 'MIT License',
'description': 'Bare bones Slack app for posting custom emoji updates to a designated channel',
'long_description': README,
# From <https://pypi.python.org/pypi?%3Aaction=list_classifiers>
'classifiers': (
'Topic :: Communications :: Chat',
'Topic :: Office/Business :: Groupware',
'Development Status :: 3 - Alpha',
'Framework :: Django',
'Framework :: Django :: 1.8',
'Framework :: Django :: 1.11',
'Framework :: Django :: 2.0',
'Intended Audience :: System Administrators',
'License :: OSI Approved :: MIT License',
'Operating System :: OS Independent',
'Programming Language :: Python',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.4',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
'Programming Language :: Python :: Implementation :: CPython',
'Programming Language :: Python :: Implementation :: PyPy',
),
'packages': setuptools.find_packages(exclude=('tests',)),
'include_package_data': True,
'install_requires': INSTALL_REQUIRES,
'setup_requires': ('pytest-runner',),
'test_suite': 'tests',
'tests_require': TESTS_REQUIRE,
}
if __name__ == '__main__':
os.environ['COVERAGE_PROCESS_START'] = os.environ.get('COVERAGE_PROCESS_START', os.path.join(_MY_DIR, '.coveragerc'))
setuptools.setup(**SETUP_ARGS)