forked from SystemRDL/systemrdl-compiler
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
160 lines (134 loc) · 5.27 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
import sys
import os
import platform
import fnmatch
import setuptools
with open("README.md", "r") as fh:
long_description = fh.read()
# Replace relative image path with github-hosted one
long_description = long_description.replace(
"docs/img/overview.svg",
"https://raw.githubusercontent.com/SystemRDL/systemrdl-compiler/master/docs/img/overview.svg?sanitize=true"
)
with open(os.path.join("systemrdl", "__about__.py")) as f:
v_dict = {}
exec(f.read(), v_dict)
rdl_version = v_dict['__version__']
target = platform.system().lower()
PLATFORMS = {'windows', 'linux', 'darwin', 'cygwin'}
for known in PLATFORMS:
if target.startswith(known):
target = known
def run_setup(with_binary):
if with_binary:
extra_compile_args = {
'windows': ['/DANTLR4CPP_STATIC', '/Zc:__cplusplus'],
'linux': ['-std=c++11'],
'darwin': ['-std=c++11'],
'cygwin': ['-std=c++11'],
}
# Define an Extension object that describes the Antlr accelerator
parser_ext = setuptools.Extension(
name='systemrdl.parser.sa_systemrdl_cpp_parser',
# Add the Antlr runtime source directory to the include search path
include_dirs=["systemrdl/parser/ext/antlr4-cpp-runtime"],
# Rather than listing each C++ file (Antlr has a lot!), discover them automatically
sources=get_files("systemrdl/parser/ext", "*.cpp"),
depends=get_files("systemrdl/parser/ext", "*.h"),
extra_compile_args=extra_compile_args.get(target, [])
)
ext_modules = [parser_ext]
else:
ext_modules = []
setuptools.setup(
name="systemrdl-compiler",
version=rdl_version,
author="Alex Mykyta",
author_email="[email protected]",
description="Parse and elaborate front-end for SystemRDL 2.0",
long_description=long_description,
long_description_content_type="text/markdown",
url="https://github.com/SystemRDL/systemrdl-compiler",
packages=setuptools.find_packages(exclude=["test"]),
include_package_data=True,
ext_modules=ext_modules,
cmdclass={"build_ext": ve_build_ext},
python_requires='>=3.5.2',
install_requires=[
"antlr4-python3-runtime >= 4.9, < 4.10",
"colorama",
"markdown",
],
classifiers=(
"Development Status :: 5 - Production/Stable",
"Programming Language :: Python",
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 3.5",
"Programming Language :: Python :: 3.6",
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3 :: Only",
"Intended Audience :: Developers",
"License :: OSI Approved :: MIT License",
"Operating System :: OS Independent",
"Topic :: Scientific/Engineering :: Electronic Design Automation (EDA)",
"Topic :: Software Development :: Compilers",
"Topic :: Software Development :: Code Generators",
),
project_urls={
"Documentation": "http://systemrdl-compiler.readthedocs.io",
"Source": "https://github.com/SystemRDL/systemrdl-compiler",
"Tracker": "https://github.com/SystemRDL/systemrdl-compiler/issues",
},
)
#===============================================================================
from setuptools.command.build_ext import build_ext
from distutils.errors import CCompilerError, DistutilsExecError, DistutilsPlatformError
def get_files(path, pattern):
"""
Recursive file search that is compatible with python3.4 and older
"""
matches = []
for root, _, filenames in os.walk(path):
for filename in fnmatch.filter(filenames, pattern):
matches.append(os.path.join(root, filename))
return matches
class BuildFailed(Exception):
pass
class ve_build_ext(build_ext):
"""
This class extends setuptools to fail with a common BuildFailed exception
if a build fails
"""
def run(self):
try:
build_ext.run(self)
except DistutilsPlatformError:
raise BuildFailed()
def build_extension(self, ext):
try:
build_ext.build_extension(self, ext)
except (CCompilerError, DistutilsExecError, DistutilsPlatformError):
raise BuildFailed()
except ValueError:
# this can happen on Windows 64 bit, see Python issue 7511
if "'path'" in str(sys.exc_info()[1]): # works with Python 2 and 3
raise BuildFailed()
raise
# Detect if an alternate interpreter is being used
is_jython = "java" in sys.platform
is_pypy = hasattr(sys, "pypy_version_info")
# Force using fallback if using an alternate interpreter
using_fallback = is_jython or is_pypy
if not using_fallback:
try:
run_setup(with_binary=True)
except BuildFailed:
if 'SYSTEMRDL_REQUIRE_BINARY_BUILD' in os.environ:
# Force failure if binary build is required
raise
else:
using_fallback = True
if using_fallback:
run_setup(with_binary=False)