-
Notifications
You must be signed in to change notification settings - Fork 20
/
setup.py
139 lines (127 loc) · 6.08 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
from setuptools import setup
from setuptools.command.build_py import build_py
import glob
import os
import platform
import subprocess
from pathlib import Path
from shutil import copyfile
import sys
class FetchDependencies(build_py):
"""
A command class that fetch Java Dependencies and
add them as files within a python package
"""
def create_stubs(self, project_root, command):
working_directory = project_root / 'optapy-core'
subprocess.run([str((project_root / command).absolute()), 'dependency:copy-dependencies'],
cwd=working_directory, check=True)
subprocess.run([str((project_root / command).absolute()), 'dependency:copy-dependencies',
'-Dclassifier=javadoc'], cwd=working_directory, check=True)
subprocess.run([sys.executable, str((project_root / 'create-stubs.py').absolute())],
cwd=working_directory, check=True)
target_dir = self.build_lib
for file_name in find_stub_files(str(working_directory / 'java-stubs')):
os.makedirs(os.path.dirname(os.path.join(target_dir, file_name)), exist_ok=True)
copyfile(os.path.join(str(working_directory), file_name), os.path.join(target_dir, file_name))
for file_name in find_stub_files(str(working_directory / 'jpype-stubs')):
os.makedirs(os.path.dirname(os.path.join(target_dir, file_name)), exist_ok=True)
copyfile(os.path.join(str(working_directory), file_name), os.path.join(target_dir, file_name))
for file_name in find_stub_files(str(working_directory / 'org-stubs')):
os.makedirs(os.path.dirname(os.path.join(target_dir, file_name)), exist_ok=True)
copyfile(os.path.join(str(working_directory), file_name), os.path.join(target_dir, file_name))
def run(self):
if not self.dry_run:
project_root = Path(__file__).parent
# Do a mvn clean install
# which is configured to add dependency jars to 'target/dependency'
command = 'mvnw'
if platform.system() == 'Windows':
command = 'mvnw.cmd'
self.create_stubs(project_root, command)
subprocess.run([str((project_root / command).absolute()), 'clean', 'install', '-Dasciidoctor.skip',
'-Dassembly.skipAssembly'],
cwd=project_root, check=True)
classpath_jars = []
# Add the main artifact
classpath_jars.extend(glob.glob(os.path.join(project_root, 'optapy-core', 'target', '*.jar')))
# Add the main artifact's dependencies
classpath_jars.extend(glob.glob(os.path.join(project_root, 'optapy-core', 'target', 'dependency', '*.jar')))
# Get the basename of each file (to be stored in classpath.txt, which is used
# when setting the classpath)
filenames = list(map(os.path.basename, classpath_jars))
classpath_list_text = "\n".join(filenames)
self.mkpath(os.path.join(self.build_lib, 'optapy', 'jars'))
# Copy classpath jars to optapy.jars
for file in classpath_jars:
copyfile(file, os.path.join(self.build_lib, 'optapy', 'jars', os.path.basename(file)))
# Add classpath.txt to optapy
fp = open(os.path.join(self.build_lib, 'optapy', 'classpath.txt'), 'w')
fp.write(classpath_list_text)
fp.close()
# Make optapy.jars a Python module
fp = open(os.path.join(self.build_lib, 'optapy', 'jars', '__init__.py'), 'w')
fp.close()
build_py.run(self)
def find_stub_files(stub_root: str):
"""
This function is taken from the awesome sqlalchey-stubs:
https://github.com/dropbox/sqlalchemy-stubs/blob/master/setup.py#L32
It's licensed under Apache 2.0:
https://github.com/dropbox/sqlalchemy-stubs/blob/master/LICENSE
"""
for root, dirs, files in os.walk(stub_root):
for file in files:
if file.endswith(".pyi"):
if os.path.sep in root:
sub_root = root.split(os.path.sep, 1)[-1]
yield os.path.join(sub_root, file)
this_directory = Path(__file__).parent
long_description = (this_directory / "README.md").read_text()
setup(
name='optapy',
version='9.37.0b0',
license='Apache License Version 2.0',
license_file='LICENSE',
description='An AI constraint solver that optimizes planning and scheduling problems',
long_description=long_description,
long_description_content_type='text/markdown',
url='https://github.com/optapy/optapy',
project_urls={
'OptaPy Documentation': 'https://optapy.org',
'OptaPlanner Homepage': 'https://www.optaplanner.org/',
},
classifiers=[
'Development Status :: 4 - Beta',
'Programming Language :: Python :: 3',
'Topic :: Scientific/Engineering :: Artificial Intelligence',
'Topic :: Software Development :: Libraries :: Java Libraries',
'License :: OSI Approved :: Apache Software License',
'Operating System :: OS Independent'
],
packages=['optapy', 'optapy.config', 'optapy.constraint', 'optapy.score', 'optapy.types', 'optapy.test',
'jpyinterpreter',
'java-stubs', 'jpype-stubs', 'org-stubs'],
package_dir={
'optapy': 'optapy-core/src/main/python',
'jpyinterpreter': 'jpyinterpreter/src/main/python',
# Setup tools need a non-empty directory to use as base
# Since these packages are generated during the build,
# we use the src/main/resources package, which does
# not contain any python files and is already included
# in the build
'java-stubs': 'optapy-core/src/main/resources',
'jpype-stubs': 'optapy-core/src/main/resources',
'org-stubs': 'optapy-core/src/main/resources',
},
test_suite='tests',
python_requires='>=3.9',
install_requires=[
'JPype1>=1.4.1',
],
cmdclass={'build_py': FetchDependencies},
package_data={
'optapy': ['classpath.txt'],
'optapy.jars': ['*.jar'],
},
)