|
24 | 24 | join,
|
25 | 25 | )
|
26 | 26 | from distutils.version import StrictVersion
|
| 27 | +from functools import partial |
27 | 28 | from setuptools import (
|
28 | 29 | Extension,
|
29 | 30 | find_packages,
|
|
33 | 34 | import versioneer
|
34 | 35 |
|
35 | 36 |
|
36 |
| -def window_specialization(typename): |
37 |
| - """Make an extension for an AdjustedArrayWindow specialization.""" |
38 |
| - return Extension( |
39 |
| - 'zipline.lib._{name}window'.format(name=typename), |
40 |
| - ['zipline/lib/_{name}window.pyx'.format(name=typename)], |
41 |
| - depends=['zipline/lib/_windowtemplate.pxi'], |
42 |
| - ) |
43 |
| - |
44 |
| - |
45 |
| -ext_modules = [ |
46 |
| - Extension('zipline.assets._assets', ['zipline/assets/_assets.pyx']), |
47 |
| - Extension('zipline.assets.continuous_futures', |
48 |
| - ['zipline/assets/continuous_futures.pyx']), |
49 |
| - Extension('zipline.lib.adjustment', ['zipline/lib/adjustment.pyx']), |
50 |
| - Extension('zipline.lib._factorize', ['zipline/lib/_factorize.pyx']), |
51 |
| - window_specialization('float64'), |
52 |
| - window_specialization('int64'), |
53 |
| - window_specialization('int64'), |
54 |
| - window_specialization('uint8'), |
55 |
| - window_specialization('label'), |
56 |
| - Extension('zipline.lib.rank', ['zipline/lib/rank.pyx']), |
57 |
| - Extension('zipline.data._equities', ['zipline/data/_equities.pyx']), |
58 |
| - Extension('zipline.data._adjustments', ['zipline/data/_adjustments.pyx']), |
59 |
| - Extension('zipline._protocol', ['zipline/_protocol.pyx']), |
60 |
| - Extension( |
61 |
| - 'zipline.finance._finance_ext', |
62 |
| - ['zipline/finance/_finance_ext.pyx'], |
63 |
| - ), |
64 |
| - Extension('zipline.gens.sim_engine', ['zipline/gens/sim_engine.pyx']), |
65 |
| - Extension( |
66 |
| - 'zipline.data._minute_bar_internal', |
67 |
| - ['zipline/data/_minute_bar_internal.pyx'] |
68 |
| - ), |
69 |
| - Extension( |
70 |
| - 'zipline.data._resample', |
71 |
| - ['zipline/data/_resample.pyx'] |
72 |
| - ), |
73 |
| - Extension( |
74 |
| - 'zipline.pipeline.loaders.blaze._core', |
75 |
| - ['zipline/pipeline/loaders/blaze/_core.pyx'], |
76 |
| - depends=['zipline/lib/adjustment.pxd'], |
77 |
| - ), |
78 |
| -] |
| 37 | +conda_build = os.path.basename(sys.argv[0]) in ('conda-build', # unix |
| 38 | + 'conda-build-script.py') # win |
| 39 | + |
| 40 | +if conda_build: |
| 41 | + # If conda-build is running this, then we're currently expanding the jinja |
| 42 | + # template in conda/zipline/meta.yaml, not actually installing. We don't |
| 43 | + # have numpy or Cython yet, but luckily we only need the names from |
| 44 | + # install_requires and build_requires. |
| 45 | + ext_modules = [] |
| 46 | +else: |
| 47 | + try: |
| 48 | + import Cython # noqa |
| 49 | + except ImportError: |
| 50 | + raise Exception("Install Cython before zipline.") |
| 51 | + |
| 52 | + try: |
| 53 | + import numpy as np |
| 54 | + except ImportError: |
| 55 | + raise Exception("Install numpy before zipline.") |
| 56 | + |
| 57 | + NumpyExtension = partial(Extension, include_dirs=[np.get_include()]) |
| 58 | + |
| 59 | + def window_specialization(typename): |
| 60 | + """Make an extension for an AdjustedArrayWindow specialization.""" |
| 61 | + return NumpyExtension( |
| 62 | + 'zipline.lib._{name}window'.format(name=typename), |
| 63 | + ['zipline/lib/_{name}window.pyx'.format(name=typename)], |
| 64 | + depends=['zipline/lib/_windowtemplate.pxi'], |
| 65 | + ) |
| 66 | + |
| 67 | + ext_modules = [ |
| 68 | + NumpyExtension('zipline.assets._assets', |
| 69 | + ['zipline/assets/_assets.pyx']), |
| 70 | + NumpyExtension('zipline.assets.continuous_futures', |
| 71 | + ['zipline/assets/continuous_futures.pyx']), |
| 72 | + NumpyExtension('zipline.lib.adjustment', |
| 73 | + ['zipline/lib/adjustment.pyx']), |
| 74 | + NumpyExtension('zipline.lib._factorize', |
| 75 | + ['zipline/lib/_factorize.pyx']), |
| 76 | + window_specialization('float64'), |
| 77 | + window_specialization('int64'), |
| 78 | + window_specialization('int64'), |
| 79 | + window_specialization('uint8'), |
| 80 | + window_specialization('label'), |
| 81 | + NumpyExtension('zipline.lib.rank', ['zipline/lib/rank.pyx']), |
| 82 | + NumpyExtension('zipline.data._equities', |
| 83 | + ['zipline/data/_equities.pyx']), |
| 84 | + NumpyExtension('zipline.data._adjustments', |
| 85 | + ['zipline/data/_adjustments.pyx']), |
| 86 | + Extension('zipline._protocol', ['zipline/_protocol.pyx']), |
| 87 | + Extension( |
| 88 | + 'zipline.finance._finance_ext', |
| 89 | + ['zipline/finance/_finance_ext.pyx'], |
| 90 | + ), |
| 91 | + NumpyExtension('zipline.gens.sim_engine', |
| 92 | + ['zipline/gens/sim_engine.pyx']), |
| 93 | + NumpyExtension( |
| 94 | + 'zipline.data._minute_bar_internal', |
| 95 | + ['zipline/data/_minute_bar_internal.pyx'] |
| 96 | + ), |
| 97 | + NumpyExtension( |
| 98 | + 'zipline.data._resample', |
| 99 | + ['zipline/data/_resample.pyx'] |
| 100 | + ), |
| 101 | + NumpyExtension( |
| 102 | + 'zipline.pipeline.loaders.blaze._core', |
| 103 | + ['zipline/pipeline/loaders/blaze/_core.pyx'], |
| 104 | + depends=['zipline/lib/adjustment.pxd'], |
| 105 | + ), |
| 106 | + ] |
79 | 107 |
|
80 | 108 |
|
81 | 109 | STR_TO_CMP = {
|
@@ -226,9 +254,6 @@ def setup_requirements(requirements_path, module_names, strict_bounds,
|
226 | 254 | return module_lines
|
227 | 255 |
|
228 | 256 |
|
229 |
| -conda_build = os.path.basename(sys.argv[0]) in ('conda-build', # unix |
230 |
| - 'conda-build-script.py') # win |
231 |
| - |
232 | 257 | setup_requires = setup_requirements(
|
233 | 258 | 'etc/requirements.txt',
|
234 | 259 | ('Cython', 'numpy'),
|
|
0 commit comments