-
Notifications
You must be signed in to change notification settings - Fork 54
/
setup.py
executable file
·135 lines (114 loc) · 4.76 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
from setuptools import setup, find_packages # Always prefer setuptools over distutils
from codecs import open # To use a consistent encoding
from os import path
import os
HERE = path.abspath(path.dirname(__file__))
# trick to manage package versions in one place only
# http://stackoverflow.com/questions/458550/standard-way-to-embed-version-into-python-package
import re
VERSIONFILE="ontospy/VERSION.py"
verstrline = open(VERSIONFILE, "rt").read()
VSRE = r"^__version__ = ['\"]([^'\"]*)['\"]"
mo = re.search(VSRE, verstrline, re.M)
if mo:
VERSIONSTRING = mo.group(1)
else:
raise RuntimeError("Unable to find version string in %s." % (VERSIONFILE,))
# Get the long description from the README file
with open(path.join(HERE, 'README.md'), encoding='utf-8') as f:
long_description = f.read()
# Parse requirements.txt file so to have one single source of truth
REQUIREMENTS_DATA = []
with open(path.join(HERE, 'requirements.txt'), encoding='utf-8') as f:
for l in f.readlines():
if not l.startswith("#"):
if (">=" in l):
REQUIREMENTS_DATA.append([l.split(">=")[0]])
elif ("=" in l):
REQUIREMENTS_DATA.append([l.split("=")[0]])
def get_package_folders(top_folder, root_path):
"""
Utility to generate dynamically the list of folders needed by the package_data setting
..
package_data={
'ontospy': ['viz/static/*.*', 'viz/templates/*.*', 'viz/templates/shared/*.*', 'viz/templates/splitter/*.*', 'viz/templates/markdown/*.*'],
},
...
"""
_dirs = []
out = []
for root, dirs, files in os.walk(top_folder):
for dir in dirs:
_dirs.append(os.path.join(root, dir))
for d in _dirs:
_d = os.path.join(d, "*.*")
out.append(_d.replace(root_path+"/", ""))
return out
PROJECT_ROOT = os.path.join(HERE, "ontospy") # should be top level always
DATA_STATIC_FILES = os.path.join(PROJECT_ROOT, "gendocs", "media", "static")
DATA_TEMPLATE_FILES = os.path.join(PROJECT_ROOT, "gendocs", "media", "templates")
# dynamically generate list of data folders
PACKAGE_DATA_FOLDERS = get_package_folders(
DATA_STATIC_FILES, PROJECT_ROOT) + get_package_folders(
DATA_TEMPLATE_FILES, PROJECT_ROOT)
if False:
print(PACKAGE_DATA_FOLDERS)
setup(
name='ontospy',
version=VERSIONSTRING,
description=
'Query, inspect and visualize ontologies encoded via RDF and OWL.',
long_description=long_description,
long_description_content_type='text/markdown',
url='https://github.com/lambdamusic/ontospy',
author='Michele Pasin',
author_email='[email protected]',
license='MIT',
# See https://pypi.python.org/pypi?%3Aaction=list_classifiers
classifiers=[
# How mature is this project? Common values are
# 3 - Alpha
# 4 - Beta
# 5 - Production/Stable
'Development Status :: 5 - Production/Stable',
# Indicate who your project is intended for
'Intended Audience :: Science/Research',
'Intended Audience :: Developers',
'Topic :: Scientific/Engineering :: Artificial Intelligence',
# Pick your license as you wish (should match "license" above)
'License :: OSI Approved :: MIT License',
# Specify the Python versions you support here. In particular, ensure
# that you indicate whether you support Python 2, Python 3 or both.
'Programming Language :: Python :: 3',
'Programming Language :: Python :: 3.2',
'Programming Language :: Python :: 3.3',
'Programming Language :: Python :: 3.4',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
'Programming Language :: Python :: 3.7',
],
keywords='ontology semantic web linked data rdf owl visualization documentation knowledge graph',
packages=find_packages(exclude=['contrib', 'docs', 'tests*']),
# List run-time dependencies here. These will be installed by pip when your
# project is installed. For an analysis of "install_requires" vs pip's
# requirements files see:
# http://python-packaging-user-guide.readthedocs.org/en/latest/requirements/
# NOTE: packages are installed in reverse order
install_requires=REQUIREMENTS_DATA,
# List additional groups of dependencies here (e.g. development dependencies).
# You can install these using the following syntax, for example:
# $ pip install -e .[dev,test]
extras_require={
'SHELL': ['readline'],
},
package_data={
'ontospy': PACKAGE_DATA_FOLDERS
},
entry_points={
'console_scripts': [
# 'ontospy-sketch=ontospy.extras.sketch:main',
'ontospy=ontospy.cli:main_cli',
'ontospy_quicktest=ontospy.tests.quick:main'
],
},
)