-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
137 lines (118 loc) · 5.01 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
"""A package for reference counting and interop with native pointers
See:
https://github.com/csiro-hydroinformatics/pyrefcount
"""
from setuptools import setup
import re
# To use a consistent encoding
from codecs import open
import os
# TODO: credit original template setup from ???
here = os.path.abspath(os.path.dirname(__file__))
verstr = 'unknown'
VERSIONFILE = "refcount/_version.py"
with open(VERSIONFILE, "r")as f:
verstrline = f.read().strip()
pattern = re.compile(r"__version__ = ['\"](.*)['\"]")
mo = pattern.search(verstrline)
if mo:
verstr = mo.group(1)
else:
raise RuntimeError("Unable to find version string in %s." % (VERSIONFILE,))
# try:
# import pypandoc
# long_description = pypandoc.convert('README.md', 'rst')
# long_description = long_description.replace("\r","") # Do not forget this line
# long_description_content_type='text/markdown'
# except:
# print("Pandoc not found. Long_description conversion failure.")
# # Get the long description from the README file
# with open(os.path.join(here, 'README.md'), encoding='utf-8') as f:
# long_description = f.read()
# long_description_content_type='text/markdown'
with open(os.path.join(here, 'README.md'), encoding='utf-8') as f:
long_description = f.read()
long_description_content_type='text/markdown'
# with open(os.path.join(os.path.dirname(__file__), "requirements.txt"), "r") as f:
# REQUIREMENTS = f.read().splitlines()
REQUIREMENTS = ['cffi', 'typing-extensions']
TEST_REQUIREMENTS = ['pytest',
# 'coveralls',
# 'pytest-cov',
# 'pytest-mpl'
]
CLASSIFIERS = ['Development Status :: 4 - Beta',
'Intended Audience :: Developers',
'Topic :: Software Development ',
'Topic :: Software Development :: Object Brokering', # ??
'License :: OSI Approved :: MIT License',
'Operating System :: OS Independent',
'Programming Language :: Python',
# 'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3'
]
# Arguments marked as "Required" below must be included for upload to PyPI.
# Fields marked as "Optional" may be commented out.
setup(
name='refcount',
version=verstr,
description='A Python package for reference counting and interop with native pointers',
long_description=long_description,
long_description_content_type=long_description_content_type,
url='https://github.com/csiro-hydroinformatics/pyrefcount',
author='Jean-Michel Perraud',
author_email='per202@csiro.au',
classifiers=CLASSIFIERS,
keywords='interop python native-libraries reference-counting handle cffi',
packages=['refcount'],
install_requires=REQUIREMENTS,
# extras_require={
# ':python_version >= "3.6"': [
# 'PyQt5',
# ]
# # extras_require={ # Optional
# # 'dev': ['check-manifest'],
# # 'test': ['coverage'],
# },
# If there are data files included in your packages that need to be
# installed, specify them here.
#
# If using Python 2.6 or earlier, then these have to be included in
# MANIFEST.in as well.
# package_data={ # Optional
# 'sample': ['package_data.dat'],
# },
# Although 'package_data' is the preferred approach, in some case you may
# need to place data files outside of your packages. See:
# http://docs.python.org/3.4/distutils/setupscript.html#installing-additional-files
#
# In this case, 'data_file' will be installed into '<sys.prefix>/my_data'
# data_files=[('my_data', ['data/data_file'])], # Optional
# To provide executable scripts, use entry points in preference to the
# "scripts" keyword. Entry points provide cross-platform support and allow
# `pip` to create the appropriate form of executable for the target
# platform.
#
# For example, the following would provide a command called `sample` which
# executes the function `main` from this package when invoked:
# entry_points={ # Optional
# 'console_scripts': [
# 'sample=sample:main',
# ],
# },
# List additional URLs that are relevant to your project as a dict.
#
# This field corresponds to the "Project-URL" metadata fields:
# https://packaging.python.org/specifications/core-metadata/#project-url-multiple-use
#
# Examples listed include a pattern for specifying where the package tracks
# issues, where the source is hosted, where to say thanks to the package
# maintainers, and where to support the project financially. The key is
# what's used to render the link text on PyPI.
project_urls={ # Optional
'Bug Reports': 'https://github.com/csiro-hydroinformatics/pyrefcount/issues',
# 'Funding': 'https://donate.pypi.org',
# 'Say Thanks!': 'http://saythanks.io/to/example',
'Source': 'https://github.com/csiro-hydroinformatics/pyrefcount',
},
)