-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsetup.py
130 lines (105 loc) · 4.35 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
'''
Created on 09.11.2009
@author: philkraf
'''
from __future__ import print_function, division
import io
import re
import sys
from distutils.sysconfig import customize_compiler
from setuptools import setup, Extension
from setuptools.command.build_ext import build_ext
class DecompBuildExt(build_ext):
"""
Custom build class to get rid of the -Wstrict-prototypes warning
source: https://stackoverflow.com/a/36293331/3032680
Removes also CLASS_swigregister clutter in decomp.py
"""
@staticmethod
def clean_swigregister(decomp_py):
"""
SWIG creates ugly CLASS_swigregister functions. We remove them.
"""
rp_call = re.compile(r'^(\w*?)_swigregister\((\w*?)\)', re.MULTILINE)
decomp_py, n = rp_call.subn('# \\1 end', decomp_py)
print(n, 'CLASS_swigregister(CLASS) lines deleted')
rp_def = re.compile(r'^(\w*?)_swigregister = _decomp\.(\w*?)_swigregister', re.MULTILINE)
decomp_py, n = rp_def.subn('_decomp.\\1_swigregister(\\1)', decomp_py)
print(n, 'CLASS_swigregister = _decomp... -> _decomp.CLASS_swigregister(CLASS)')
return decomp_py
@staticmethod
def clean_static_methods(decomp_py):
"""SWIG creates still static methods as free functions (extra) to ensure Py2.2 compatibility
We don't want that in 2018
"""
# Find class names and free functions
classes = re.findall(r'class\s(\w*?)\(.*?\):', decomp_py, re.MULTILINE)
funcs = re.findall(r'^def (\w*?)\(\*args, \*\*kwargs\):$', decomp_py, flags=re.MULTILINE)
# Find old style static methods (def CLASS_method():)
static_methods = [f for f in funcs if [c for c in classes if f.startswith(c)]]
count = 0
for sm in static_methods:
decomp_py, n = re.subn(r'^def {}.*?:.*?return.*?$'.format(sm),
'\n\n', decomp_py, flags=re.MULTILINE + re.DOTALL)
count += n
print(count, 'old style static methods removed from', len(classes), 'classes')
return decomp_py
def build_extensions(self):
customize_compiler(self.compiler)
try:
self.compiler.compiler_so.remove("-Wstrict-prototypes")
except (AttributeError, ValueError):
pass
build_ext.build_extensions(self)
decomp_py = open('decomp/decomp.py').read()
# decomp_py = self.clean_swigregister(decomp_py)
decomp_py = self.clean_static_methods(decomp_py)
open('decomp/decomp.py', 'w').write(decomp_py)
def get_version():
for line in open('decomp/__init__.py'):
if line.strip().startswith('__version__'):
return line.split('=')[-1].strip().strip("'")
def pop_arg(arg):
if arg in sys.argv:
sys.argv.remove(arg)
return True
else:
return False
if __name__ == '__main__':
if pop_arg('swig'):
print('Generate wrapper with swig')
wrapper = 'decomp/decomp.i'
else:
print('Use pregenerated wrapper')
wrapper = 'decomp/decomp_wrap.cpp'
print(' ->', wrapper)
ext = Extension('decomp._decomp',
sources=['decomp/SOM.cpp', 'decomp/SOMcomponent.cpp', wrapper],
swig_opts=['-c++', '-Wextra', '-w512', '-w511', '-O', '-keyword', '-castmode'],
)
classifiers = [
'Development Status :: 4 - Beta',
'Intended Audience :: Science/Research',
'License :: OSI Approved :: MIT License',
'Programming Language :: C++',
'Programming Language :: Python',
'Topic :: Scientific/Engineering',
'Topic :: Software Development :: Libraries :: Python Modules',
]
description = 'DECOMP: a carbon pool model for soil organic matter in the forest floor'
long_description = io.open('README.rst', encoding='utf-8').read()
setup(name='decomp',
version=get_version(),
license='MIT',
ext_modules=[ext],
packages=['decomp'],
python_requires='>=3.5',
keywords='decomposition soil litter',
author='Philipp Kraft',
author_email="philipp.kraft@umwelt.uni-giessen.de",
url="https://www.uni-giessen.de/hydro/download",
description=description,
long_description=long_description,
classifiers=classifiers,
cmdclass=dict(build_ext=DecompBuildExt)
)