-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathsetup.py
executable file
·181 lines (151 loc) · 7.61 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
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
#!/usr/bin/env python3
# vim: set fileencoding=utf-8 ff=unix tw=78 ai syn=python : per PEP 0263
# Python package installation Date : 2018-06-20
'''
_______________| fecon236/setup.py :: Installation via setuptools.
Essential install config file, esp. for pip.
Dependencies: setuptools>=38.6.0 [for markdown support]
(wheel>=0.31.0 [for markdown support] distribution)
(twine>=1.11.0 [for markdown support] PyPI submit)
VERSION in play: Use "pip show fecon236"
Rant: pip CANNOT properly resolve dependencies!
Setting up installation is frustrating in the
complex Python ecosystem with magical incantations.
Templates: https://github.com/kennethreitz/samplemod
https://github.com/kennethreitz/setup.py
References: Donald Stufft, 2013, "setup.py vs requirements.txt"
https://caremad.io/posts/2013/07/setup-vs-requirement
https://packaging.python.org/tutorials/distributing-packages <=!!
https://packaging.python.org/guides/single-sourcing-package-version
https://packaging.python.org/guides -- Idiosyncrasies
https://packaging.python.org/discussions/wheel-vs-egg -- No eggs!
https://packaging.python.org/specifications -- PyPA SPECS.
For PyPI: - Distinguish between "Universal" and "Pure" wheels.
- Create distribution wheels by:
pythonN setup.py bdist_wheel [--universal]
- dist/ will be under your project’s root directory.
- build/ and PROJECT.egg-info/ as well.
- To upload to PyPI:
twine upload dist/*
- Check up at https://pypi.org/project/PROJECT
Markdown support (2018, finally at PyPI!):
https://dustingram.com/articles/2018/03/16/markdown-descriptions-on-pypi
CLASSIFERS: https://pypi.python.org/pypi?%3Aaction=list_classifiers
CHANGE LOG For latest version, see https://git.io/fecon236
2018-06-20 Change development status from alpha to stable.
2018-06-02 Add PROJECTURL and edit project_urls.
2018-05-24 Support markdown by appending "content_type" incantations.
Recent setuptools, wheel, and twine are necessary.
PyPI rendering corrected by excluding "license" as text.
2018-05-01 Eliminate attempt at __version__ here.
2018-04-30 Additional directives, requirements.txt comparison.
2018-04-23 First version.
'''
import os
from setuptools import setup, find_packages
PROJECT = 'fecon236'
PROJECTURL = 'https://github.com/MathSci/' + PROJECT
# What packages are required? For example:
# 'foo', 'bar>=2.0', 'foobar~=3.4.5'
# ___ATTN___ But does this list start their installations??
# How is this connected to requirements.txt??
# What if prequisites are already furnished by Anaconda?
# https://packaging.python.org/discussions/install-requires-vs-requirements
# "Specify what a project MINIMALLY needs to run correctly.
# When the project is installed by pip,
# this is the specification that is used to install its dependencies.
# NOT considered best practice to use install_requires to pin
# dependencies to specific versions, or to specify sub-dependencies.
# Note: install_requires is a listing of ABSTRACT requirements,
# i.e just names and version restrictions that do not determine
# where the dependencies will be fulfilled. The concreteness
# will be determined at install time using pip options."
# "Whereas "install_requires" defines the dependencies
# for a single project, requirements.txt is used to define
# requirements for a complete Python ENVIRONMENT.
# Requirements files often contain an exhaustive listing
# of pinned versions for the purpose of achieving
# repeatable installations of a complete environment."
# However, using "pip install -e . " which is short for --editable,
# and "." refering to the current working directory, will install
# the current directory (i.e. your project) in editable mode.
# This will also INSTALL any dependencies declared with "install_requires"
# and any scripts declared with "console_scripts".
# Dependencies will be installed in the usual, non-editable mode.
# If you don’t want to install any dependencies at all:
# pip install -e . --no-deps
REQUIRED = []
# ^Leave EMPTY instead of relying on --no-deps
# (We do not want conflicts with conda installations.)
with open('README.md') as f:
readme = f.read()
with open('VERSION') as f:
# Read top-level file as pure string, deleting line return:
versioned = f.read().strip().replace(os.linesep, '')
# with open('LICENSE.md') as f:
# licensed = f.read()
#
# # license=licensed, # GOTCHA in setup
# #
# # The "license" argument is for supplying the name of the software license
# # being used (e.g. 'MIT' or 'GPLv2'), NOT for supplying the entire text
# # of the license. If the text is included, setuptools' failure to indent
# # the license text causes all subsequent fields of the PKG-INFO
# # (including the long description and keywords) to not be parsed,
# # hence they will not show up correctly on PyPI.
# # 2017-07-14 https://stackoverflow.com/questions/45104281
setup(
name=PROJECT,
version=versioned,
description='Tools for financial economics',
long_description=readme,
long_description_content_type="text/markdown",
author='Mathematical Sciences Group',
author_email='[email protected]',
python_requires='>=2.7.0',
url=PROJECTURL,
project_urls={
'Source': PROJECTURL,
'Require': PROJECTURL+'/blob/develop/require.txt',
'Installation': PROJECTURL+'/blob/develop/docs/READ/fe-10_Install.md',
'Documentation': PROJECTURL+'/tree/develop/docs',
'Notebooks': 'https://github.com/rsvp/fecon235/tree/master/nb',
'Tracker': PROJECTURL+'/projects/3',
'Issues': PROJECTURL+'/issues',
'License': PROJECTURL+'/blob/master/LICENSE.md',
},
install_requires=REQUIRED,
include_package_data=True,
packages=find_packages(exclude=('.old', 'docs', 'tests')),
license='BSD',
keywords='finance economics statistics econometrics pandas jupyter',
classifiers=[
'Development Status :: 5 - Production/Stable',
'License :: OSI Approved :: BSD License',
'Topic :: Scientific/Engineering',
'Topic :: Office/Business :: Financial :: Investment',
'Intended Audience :: Science/Research',
'Intended Audience :: Financial and Insurance Industry',
'Natural Language :: English',
'Programming Language :: Python',
'Programming Language :: Python :: 2',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3',
'Programming Language :: Python :: 3.4',
'Programming Language :: Python :: Implementation :: CPython'
],
)
# ======================================================== Endnotes ===========
# __________ Donald STUFFT's template included:
# dependency_links = [
# "http://packages.example.com/snapshots/",
# "http://example2.com/p/bar-1.0.tar.gz",
# ],
# __________ STATUS Classifiers
# 'Development Status :: 1 - Planning',
# 'Development Status :: 2 - Pre-Alpha',
# 'Development Status :: 3 - Alpha',
# 'Development Status :: 4 - Beta',
# 'Development Status :: 5 - Production/Stable',
# 'Development Status :: 6 - Mature',
# 'Development Status :: 7 - Inactive',