forked from astropy/astropy
/
setup.py
executable file
·102 lines (80 loc) · 3.41 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
#!/usr/bin/env python
# Licensed under a 3-clause BSD style license - see LICENSE.rst
# Use "distribute" - the setuptools fork that supports python 3.
from distribute_setup import use_setuptools
use_setuptools()
from distutils.command import sdist
import glob
import os
from setuptools import setup, find_packages
import astropy
from astropy import setup_helpers
from astropy.version_helper import get_git_devstr, generate_version_py
#version should be PEP386 compatible (http://www.python.org/dev/peps/pep-0386)
version = '0.0.dev'
# Indicates if this version is a release version
release = 'dev' not in version
# Adjust the compiler in case the default on this platform is to use a
# broken one.
setup_helpers.adjust_compiler()
# Indicate that we are in building mode
setup_helpers.set_build_mode()
if not release:
version += get_git_devstr(False)
generate_version_py('astropy', version, release,
setup_helpers.get_debug_option())
# Use the find_packages tool to locate all packages and modules
packagenames = find_packages()
# Treat everything in scripts except README.rst as a script to be installed
scripts = glob.glob(os.path.join('scripts', '*'))
scripts.remove(os.path.join('scripts', 'README.rst'))
# Check that Numpy is installed.
# NOTE: We cannot use setuptools/distribute/packaging to handle this
# dependency for us, since some of the subpackages need to be able to
# access numpy at build time, and they are configured before
# setuptools has a chance to check and resolve the dependency.
setup_helpers.check_numpy()
# This dictionary stores the command classes used in setup below
cmdclassd = {'test': setup_helpers.setup_test_command('astropy'),
# Use distutils' sdist because it respects package_data.
# setuptools/distributes sdist requires duplication of
# information in MANIFEST.in
'sdist': sdist.sdist}
# Additional C extensions that are not Cython-based should be added here.
extensions = []
# A dictionary to keep track of all package data to install
package_data = {'astropy': ['data/*']}
# A dictionary to keep track of extra packagedir mappings
package_dirs = {}
# Update extensions, package_data, packagenames and package_dirs from
# any sub-packages that define their own extension modules and package
# data. See the docstring for setup_helpers.update_package_files for
# more details.
setup_helpers.update_package_files('astropy', extensions, package_data,
packagenames, package_dirs)
if setup_helpers.HAVE_CYTHON and not release:
from Cython.Distutils import build_ext
# Builds Cython->C if in dev mode and Cython is present
cmdclassd['build_ext'] = build_ext
if setup_helpers.AstropyBuildSphinx is not None:
cmdclassd['build_sphinx'] = setup_helpers.AstropyBuildSphinx
setup(name='astropy',
version=version,
description='Community-developed python astronomy tools',
packages=packagenames,
package_data=package_data,
package_dir=package_dirs,
ext_modules=extensions,
scripts=scripts,
requires=['numpy'], # scipy not required, but strongly recommended
install_requires=['numpy'],
provides=['astropy'],
author='The Astropy Team',
author_email='astropy.team@gmail.com',
license='BSD',
url='http://astropy.org',
long_description=astropy.__doc__,
cmdclass=cmdclassd,
zip_safe=False,
use_2to3=True
)