forked from ElementsProject/libwally-core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup.py
123 lines (105 loc) · 4.5 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
"""setuptools config for wallycore """
kwargs = {
'name': 'wallycore',
'version': '0.6.8',
'description': 'libwally Bitcoin library',
'long_description': 'Python bindings for the libwally Bitcoin library',
'url': 'https://github.com/ElementsProject/libwally-core',
'author': 'Jon Griffiths',
'author_email': '[email protected]',
'license': 'MIT',
'zip_safe': False,
'classifiers': [
'Development Status :: 5 - Production/Stable',
'Intended Audience :: Developers',
'Topic :: Software Development :: Libraries',
'License :: OSI Approved :: MIT License',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
],
'keywords': 'Bitcoin wallet BIP32 BIP38 BIP39 secp256k1',
'project_urls': {
'Documentation': 'https://wally.readthedocs.io/en/latest',
'Source': 'https://github.com/ElementsProject/libwally-core',
'Tracker': 'https://github.com/ElementsProject/libwally-core/issues',
},
'packages': ['wallycore'],
'package_dir': {'':'src/swig_python'},
}
import platform
if platform.system() == "Windows":
# On windows wally is defined as a standard python extension
from distutils.core import Extension
wally_ext = Extension(
'_wallycore',
define_macros=[
('SWIG_PYTHON_BUILD', None),
('USE_ECMULT_STATIC_PRECOMPUTATION', None),
('WALLY_CORE_BUILD', None),
('HAVE_CONFIG_H', None),
('SECP256K1_BUILD', None),
('BUILD_ELEMENTS', None),
],
include_dirs=[
# Borrowing config from wrap_js
# TODO: Move this to another directory
'./src/wrap_js/windows_config',
'./',
'./src',
'./include',
'./src/ccan',
'./src/secp256k1',
'./src/secp256k1/src/',
],
sources=[
'src/swig_python/swig_wrap.c',
'src/wrap_js/src/combined.c',
'src/wrap_js/src/combined_ccan.c',
'src/wrap_js/src/combined_ccan2.c',
],
)
kwargs['py_modules'] = 'wallycore'
kwargs['ext_modules'] = [wally_ext]
else:
# *nix uses a custom autotools/make build
import distutils
import distutils.command.build_py
import os
import platform
import subprocess
import multiprocessing
class _build_py(distutils.command.build_py.build_py):
def build_libwallycore(self):
abs_path = os.path.dirname(os.path.abspath(__file__)) + '/'
def call(cmd):
subprocess.check_call(cmd.split(' '), cwd=abs_path)
# Run the autotools/make build to generate a python extension module
extra_build_options = os.getenv('ENABLE_ELEMENTS', '')
call('./tools/cleanup.sh')
call('./tools/autogen.sh')
call('./configure --enable-swig-python --enable-ecmult-static-precomputation {}'.format(extra_build_options))
call('make -j{}'.format(multiprocessing.cpu_count()))
# Copy the so that has just been built to the build_dir that distutils expects it to be in
# The extension of the built lib is dylib on osx
so_ext = 'dylib' if platform.system() == 'Darwin' else 'so'
src_so = 'src/.libs/libwallycore.{}'.format(so_ext)
distutils.dir_util.mkpath(self.build_lib)
dest_so = os.path.join(self.build_lib, 'libwallycore.so')
distutils.file_util.copy_file(src_so, dest_so)
def run(self):
# Override build_py to first build the c library, then perform the normal python build.
# Overriding build_clib would be more obvious but that results in setuptools trying to do
# build_py first, which fails because the wallycore/__init__.py is created by making the
# clib
self.build_libwallycore()
distutils.command.build_py.build_py.run(self)
kwargs['cmdclass'] = {'build_py': _build_py}
# Force Distribution to have ext modules. This is necessary to generate the correct platform
# dependent filename when generating wheels because the building of the underlying wally c libs
# is effectively hidden from distutils - which means it assumes it is building a pure python
# module.
from distutils.dist import Distribution
Distribution.has_ext_modules = lambda self: True
from setuptools import setup
setup(**kwargs)