Show More
setup.py
261 lines
| 9.5 KiB
| text/x-python
|
PythonLexer
|
r1033 | #!/usr/bin/env python | ||
# -*- coding: utf-8 -*- | ||||
"""Setup script for IPython. | ||||
Under Posix environments it works like a typical setup.py script. | ||||
Under Windows, the command sdist is not supported, since IPython | ||||
|
r1207 | requires utilities which are not available under Windows.""" | ||
|
r1033 | |||
|
r3199 | #----------------------------------------------------------------------------- | ||
# Copyright (c) 2008-2010, IPython Development Team. | ||||
# Copyright (c) 2001-2007, Fernando Perez <fernando.perez@colorado.edu> | ||||
# Copyright (c) 2001, Janko Hauser <jhauser@zscout.de> | ||||
# Copyright (c) 2001, Nathaniel Gray <n8gray@caltech.edu> | ||||
|
r1033 | # | ||
|
r3199 | # Distributed under the terms of the Modified BSD License. | ||
# | ||||
# The full license is in the file COPYING.txt, distributed with this software. | ||||
#----------------------------------------------------------------------------- | ||||
|
r1237 | |||
|
r2493 | #----------------------------------------------------------------------------- | ||
# Minimal Python version sanity check | ||||
#----------------------------------------------------------------------------- | ||||
import sys | ||||
# This check is also made in IPython/__init__, don't forget to update both when | ||||
# changing Python version requirements. | ||||
|
r3196 | if sys.version[0:3] < '2.6': | ||
|
r2493 | error = """\ | ||
|
r3196 | ERROR: 'IPython requires Python Version 2.6 or above.' | ||
|
r2493 | Exiting.""" | ||
print >> sys.stderr, error | ||||
sys.exit(1) | ||||
|
r3196 | # At least we're on the python version we need, move on. | ||
|
r2493 | |||
|
r1237 | #------------------------------------------------------------------------------- | ||
# Imports | ||||
#------------------------------------------------------------------------------- | ||||
|
r1033 | |||
# Stdlib imports | ||||
import os | ||||
|
r2460 | import shutil | ||
|
r1033 | |||
from glob import glob | ||||
|
r1207 | |||
# BEFORE importing distutils, remove MANIFEST. distutils doesn't properly | ||||
# update it when the contents of directories change. | ||||
if os.path.exists('MANIFEST'): os.remove('MANIFEST') | ||||
from distutils.core import setup | ||||
|
r1033 | |||
|
r2493 | # Our own imports | ||
|
r2498 | from IPython.utils.path import target_update | ||
|
r1207 | |||
|
r1237 | from setupbase import ( | ||
setup_args, | ||||
find_packages, | ||||
find_package_data, | ||||
find_scripts, | ||||
find_data_files, | ||||
|
r3199 | check_for_dependencies, | ||
record_commit_info, | ||||
|
r1237 | ) | ||
|
r3744 | from setupext import setupext | ||
|
r1237 | |||
|
r1033 | isfile = os.path.isfile | ||
|
r2058 | pjoin = os.path.join | ||
|
r1237 | |||
|
r2460 | #----------------------------------------------------------------------------- | ||
# Function definitions | ||||
#----------------------------------------------------------------------------- | ||||
def cleanup(): | ||||
"""Clean up the junk left around by the build process""" | ||||
if "develop" not in sys.argv: | ||||
try: | ||||
shutil.rmtree('ipython.egg-info') | ||||
except: | ||||
try: | ||||
os.unlink('ipython.egg-info') | ||||
except: | ||||
pass | ||||
|
r1237 | #------------------------------------------------------------------------------- | ||
# Handle OS specific things | ||||
#------------------------------------------------------------------------------- | ||||
|
r1033 | |||
if os.name == 'posix': | ||||
os_name = 'posix' | ||||
elif os.name in ['nt','dos']: | ||||
os_name = 'windows' | ||||
else: | ||||
print 'Unsupported operating system:',os.name | ||||
sys.exit(1) | ||||
|
r1207 | # Under Windows, 'sdist' has not been supported. Now that the docs build with | ||
# Sphinx it might work, but let's not turn it on until someone confirms that it | ||||
# actually works. | ||||
|
r1033 | if os_name == 'windows' and 'sdist' in sys.argv: | ||
print 'The sdist command is not available under Windows. Exiting.' | ||||
sys.exit(1) | ||||
|
r1237 | #------------------------------------------------------------------------------- | ||
# Things related to the IPython documentation | ||||
#------------------------------------------------------------------------------- | ||||
|
r1033 | # update the manuals when building a source dist | ||
if len(sys.argv) >= 2 and sys.argv[1] in ('sdist','bdist_rpm'): | ||||
|
r1188 | import textwrap | ||
|
r1207 | |||
# List of things to be updated. Each entry is a triplet of args for | ||||
|
r1033 | # target_update() | ||
|
r1244 | to_update = [ | ||
|
r1207 | # FIXME - Disabled for now: we need to redo an automatic way | ||
# of generating the magic info inside the rst. | ||||
|
r1522 | #('docs/magic.tex', | ||
|
r1207 | #['IPython/Magic.py'], | ||
#"cd doc && ./update_magic.sh" ), | ||||
|
r2100 | |||
('docs/man/ipcluster.1.gz', | ||||
['docs/man/ipcluster.1'], | ||||
'cd docs/man && gzip -9c ipcluster.1 > ipcluster.1.gz'), | ||||
('docs/man/ipcontroller.1.gz', | ||||
['docs/man/ipcontroller.1'], | ||||
'cd docs/man && gzip -9c ipcontroller.1 > ipcontroller.1.gz'), | ||||
('docs/man/ipengine.1.gz', | ||||
['docs/man/ipengine.1'], | ||||
'cd docs/man && gzip -9c ipengine.1 > ipengine.1.gz'), | ||||
|
r1522 | ('docs/man/ipython.1.gz', | ||
['docs/man/ipython.1'], | ||||
|
r2100 | 'cd docs/man && gzip -9c ipython.1 > ipython.1.gz'), | ||
('docs/man/ipython-wx.1.gz', | ||||
['docs/man/ipython-wx.1'], | ||||
'cd docs/man && gzip -9c ipython-wx.1 > ipython-wx.1.gz'), | ||||
('docs/man/ipythonx.1.gz', | ||||
['docs/man/ipythonx.1'], | ||||
'cd docs/man && gzip -9c ipythonx.1 > ipythonx.1.gz'), | ||||
('docs/man/irunner.1.gz', | ||||
['docs/man/irunner.1'], | ||||
'cd docs/man && gzip -9c irunner.1 > irunner.1.gz'), | ||||
|
r1207 | |||
|
r1522 | ('docs/man/pycolor.1.gz', | ||
['docs/man/pycolor.1'], | ||||
|
r2100 | 'cd docs/man && gzip -9c pycolor.1 > pycolor.1.gz'), | ||
|
r1207 | ] | ||
|
r1596 | # Only build the docs if sphinx is present | ||
|
r1244 | try: | ||
import sphinx | ||||
except ImportError: | ||||
pass | ||||
else: | ||||
|
r1596 | # The Makefile calls the do_sphinx scripts to build html and pdf, so | ||
# just one target is enough to cover all manual generation | ||||
# First, compute all the dependencies that can force us to rebuild the | ||||
# docs. Start with the main release file that contains metadata | ||||
|
r2058 | docdeps = ['IPython/core/release.py'] | ||
|
r1596 | # Inculde all the reST sources | ||
pjoin = os.path.join | ||||
for dirpath,dirnames,filenames in os.walk('docs/source'): | ||||
if dirpath in ['_static','_templates']: | ||||
continue | ||||
docdeps += [ pjoin(dirpath,f) for f in filenames | ||||
if f.endswith('.txt') ] | ||||
# and the examples | ||||
for dirpath,dirnames,filenames in os.walk('docs/example'): | ||||
docdeps += [ pjoin(dirpath,f) for f in filenames | ||||
if not f.endswith('~') ] | ||||
# then, make them all dependencies for the main PDF (the html will get | ||||
# auto-generated as well). | ||||
to_update.append( | ||||
('docs/dist/ipython.pdf', | ||||
docdeps, | ||||
"cd docs && make dist") | ||||
) | ||||
|
r1525 | |||
|
r1207 | [ target_update(*t) for t in to_update ] | ||
|
r1525 | |||
|
r1237 | #--------------------------------------------------------------------------- | ||
|
r3681 | # Find all the packages, package data, and data_files | ||
|
r1237 | #--------------------------------------------------------------------------- | ||
packages = find_packages() | ||||
package_data = find_package_data() | ||||
data_files = find_data_files() | ||||
#--------------------------------------------------------------------------- | ||||
|
r3681 | # Handle scripts, dependencies, and setuptools specific things | ||
|
r1237 | #--------------------------------------------------------------------------- | ||
|
r2422 | # For some commands, use setuptools. Note that we do NOT list install here! | ||
# If you want a setuptools-enhanced install, just run 'setupegg.py install' | ||||
if len(set(('develop', 'sdist', 'release', 'bdist_egg', 'bdist_rpm', | ||||
'bdist', 'bdist_dumb', 'bdist_wininst', 'install_egg_info', | ||||
'build_sphinx', 'egg_info', 'easy_install', 'upload', | ||||
)).intersection(sys.argv)) > 0: | ||||
import setuptools | ||||
|
r1237 | # This dict is used for passing extra arguments that are setuptools | ||
# specific to setup | ||||
setuptools_extra_args = {} | ||||
|
r1033 | |||
if 'setuptools' in sys.modules: | ||||
|
r1237 | setuptools_extra_args['zip_safe'] = False | ||
|
r3839 | setuptools_extra_args['entry_points'] = find_scripts(True) | ||
|
r1561 | setup_args['extras_require'] = dict( | ||
|
r3673 | parallel = 'pyzmq>=2.1.4', | ||
|
r3672 | zmq = 'pyzmq>=2.0.10.1', | ||
|
r1561 | doc='Sphinx>=0.3', | ||
|
r1237 | test='nose>=0.10.1', | ||
) | ||||
|
r3699 | requires = setup_args.setdefault('install_requires', []) | ||
|
r3744 | setupext.display_status = False | ||
if not setupext.check_for_readline(): | ||||
|
r3743 | if sys.platform == 'darwin': | ||
|
r3744 | requires.append('readline') | ||
|
r3743 | elif sys.platform.startswith('win'): | ||
requires.append('pyreadline') | ||||
else: | ||||
pass | ||||
# do we want to install readline here? | ||||
|
r3681 | |||
# Script to be run by the windows binary installer after the default setup | ||||
# routine, to add shortcuts and similar windows-only things. Windows | ||||
# post-install scripts MUST reside in the scripts/ dir, otherwise distutils | ||||
# doesn't find them. | ||||
if 'bdist_wininst' in sys.argv: | ||||
if len(sys.argv) > 2 and \ | ||||
('sdist' in sys.argv or 'bdist_rpm' in sys.argv): | ||||
print >> sys.stderr, "ERROR: bdist_wininst must be run alone. Exiting." | ||||
sys.exit(1) | ||||
setup_args['scripts'] = [pjoin('scripts','ipython_win_post_install.py')] | ||||
|
r1033 | else: | ||
|
r1237 | # If we are running without setuptools, call this function which will | ||
# check for dependencies an inform the user what is needed. This is | ||||
# just to make life easy for users. | ||||
check_for_dependencies() | ||||
|
r3839 | setup_args['scripts'] = find_scripts(False) | ||
|
r1237 | |||
#--------------------------------------------------------------------------- | ||||
# Do the actual setup now | ||||
#--------------------------------------------------------------------------- | ||||
|
r3199 | setup_args['cmdclass'] = {'build_py': record_commit_info('IPython')} | ||
|
r1237 | setup_args['packages'] = packages | ||
setup_args['package_data'] = package_data | ||||
setup_args['data_files'] = data_files | ||||
setup_args.update(setuptools_extra_args) | ||||
|
r2460 | |||
|
r1237 | if __name__ == '__main__': | ||
setup(**setup_args) | ||||
|
r2460 | cleanup() | ||