##// END OF EJS Templates
calculate 'all' dependency set after finishing the rest...
Min RK -
Show More
@@ -1,339 +1,338 b''
1 1 #!/usr/bin/env python
2 2 # -*- coding: utf-8 -*-
3 3 """Setup script for IPython.
4 4
5 5 Under Posix environments it works like a typical setup.py script.
6 6 Under Windows, the command sdist is not supported, since IPython
7 7 requires utilities which are not available under Windows."""
8 8
9 9 #-----------------------------------------------------------------------------
10 10 # Copyright (c) 2008-2011, IPython Development Team.
11 11 # Copyright (c) 2001-2007, Fernando Perez <fernando.perez@colorado.edu>
12 12 # Copyright (c) 2001, Janko Hauser <jhauser@zscout.de>
13 13 # Copyright (c) 2001, Nathaniel Gray <n8gray@caltech.edu>
14 14 #
15 15 # Distributed under the terms of the Modified BSD License.
16 16 #
17 17 # The full license is in the file COPYING.rst, distributed with this software.
18 18 #-----------------------------------------------------------------------------
19 19
20 20 #-----------------------------------------------------------------------------
21 21 # Minimal Python version sanity check
22 22 #-----------------------------------------------------------------------------
23 23 from __future__ import print_function
24 24
25 25 import sys
26 26
27 27 # This check is also made in IPython/__init__, don't forget to update both when
28 28 # changing Python version requirements.
29 29 v = sys.version_info
30 30 if v[:2] < (2,7) or (v[0] >= 3 and v[:2] < (3,3)):
31 31 error = "ERROR: IPython requires Python version 2.7 or 3.3 or above."
32 32 print(error, file=sys.stderr)
33 33 sys.exit(1)
34 34
35 35 PY3 = (sys.version_info[0] >= 3)
36 36
37 37 # At least we're on the python version we need, move on.
38 38
39 39 #-------------------------------------------------------------------------------
40 40 # Imports
41 41 #-------------------------------------------------------------------------------
42 42
43 43 # Stdlib imports
44 44 import os
45 45 import shutil
46 46
47 47 from glob import glob
48 48
49 49 # BEFORE importing distutils, remove MANIFEST. distutils doesn't properly
50 50 # update it when the contents of directories change.
51 51 if os.path.exists('MANIFEST'): os.remove('MANIFEST')
52 52
53 53 from distutils.core import setup
54 54
55 55 # Our own imports
56 56 from setupbase import target_update
57 57
58 58 from setupbase import (
59 59 setup_args,
60 60 find_packages,
61 61 find_package_data,
62 62 check_package_data_first,
63 63 find_entry_points,
64 64 build_scripts_entrypt,
65 65 find_data_files,
66 66 check_for_dependencies,
67 67 git_prebuild,
68 68 check_submodule_status,
69 69 update_submodules,
70 70 require_submodules,
71 71 UpdateSubmodules,
72 72 get_bdist_wheel,
73 73 CompileCSS,
74 74 JavascriptVersion,
75 75 css_js_prerelease,
76 76 install_symlinked,
77 77 install_lib_symlink,
78 78 install_scripts_for_symlink,
79 79 unsymlink,
80 80 )
81 81 from setupext import setupext
82 82
83 83 isfile = os.path.isfile
84 84 pjoin = os.path.join
85 85
86 86 #-------------------------------------------------------------------------------
87 87 # Handle OS specific things
88 88 #-------------------------------------------------------------------------------
89 89
90 90 if os.name in ('nt','dos'):
91 91 os_name = 'windows'
92 92 else:
93 93 os_name = os.name
94 94
95 95 # Under Windows, 'sdist' has not been supported. Now that the docs build with
96 96 # Sphinx it might work, but let's not turn it on until someone confirms that it
97 97 # actually works.
98 98 if os_name == 'windows' and 'sdist' in sys.argv:
99 99 print('The sdist command is not available under Windows. Exiting.')
100 100 sys.exit(1)
101 101
102 102 #-------------------------------------------------------------------------------
103 103 # Make sure we aren't trying to run without submodules
104 104 #-------------------------------------------------------------------------------
105 105 here = os.path.abspath(os.path.dirname(__file__))
106 106
107 107 def require_clean_submodules():
108 108 """Check on git submodules before distutils can do anything
109 109
110 110 Since distutils cannot be trusted to update the tree
111 111 after everything has been set in motion,
112 112 this is not a distutils command.
113 113 """
114 114 # PACKAGERS: Add a return here to skip checks for git submodules
115 115
116 116 # don't do anything if nothing is actually supposed to happen
117 117 for do_nothing in ('-h', '--help', '--help-commands', 'clean', 'submodule'):
118 118 if do_nothing in sys.argv:
119 119 return
120 120
121 121 status = check_submodule_status(here)
122 122
123 123 if status == "missing":
124 124 print("checking out submodules for the first time")
125 125 update_submodules(here)
126 126 elif status == "unclean":
127 127 print('\n'.join([
128 128 "Cannot build / install IPython with unclean submodules",
129 129 "Please update submodules with",
130 130 " python setup.py submodule",
131 131 "or",
132 132 " git submodule update",
133 133 "or commit any submodule changes you have made."
134 134 ]))
135 135 sys.exit(1)
136 136
137 137 require_clean_submodules()
138 138
139 139 #-------------------------------------------------------------------------------
140 140 # Things related to the IPython documentation
141 141 #-------------------------------------------------------------------------------
142 142
143 143 # update the manuals when building a source dist
144 144 if len(sys.argv) >= 2 and sys.argv[1] in ('sdist','bdist_rpm'):
145 145
146 146 # List of things to be updated. Each entry is a triplet of args for
147 147 # target_update()
148 148 to_update = [
149 149 # FIXME - Disabled for now: we need to redo an automatic way
150 150 # of generating the magic info inside the rst.
151 151 #('docs/magic.tex',
152 152 #['IPython/Magic.py'],
153 153 #"cd doc && ./update_magic.sh" ),
154 154
155 155 ('docs/man/ipcluster.1.gz',
156 156 ['docs/man/ipcluster.1'],
157 157 'cd docs/man && gzip -9c ipcluster.1 > ipcluster.1.gz'),
158 158
159 159 ('docs/man/ipcontroller.1.gz',
160 160 ['docs/man/ipcontroller.1'],
161 161 'cd docs/man && gzip -9c ipcontroller.1 > ipcontroller.1.gz'),
162 162
163 163 ('docs/man/ipengine.1.gz',
164 164 ['docs/man/ipengine.1'],
165 165 'cd docs/man && gzip -9c ipengine.1 > ipengine.1.gz'),
166 166
167 167 ('docs/man/ipython.1.gz',
168 168 ['docs/man/ipython.1'],
169 169 'cd docs/man && gzip -9c ipython.1 > ipython.1.gz'),
170 170
171 171 ]
172 172
173 173
174 174 [ target_update(*t) for t in to_update ]
175 175
176 176 #---------------------------------------------------------------------------
177 177 # Find all the packages, package data, and data_files
178 178 #---------------------------------------------------------------------------
179 179
180 180 packages = find_packages()
181 181 package_data = find_package_data()
182 182
183 183 data_files = find_data_files()
184 184
185 185 setup_args['packages'] = packages
186 186 setup_args['package_data'] = package_data
187 187 setup_args['data_files'] = data_files
188 188
189 189 #---------------------------------------------------------------------------
190 190 # custom distutils commands
191 191 #---------------------------------------------------------------------------
192 192 # imports here, so they are after setuptools import if there was one
193 193 from distutils.command.sdist import sdist
194 194 from distutils.command.upload import upload
195 195
196 196 class UploadWindowsInstallers(upload):
197 197
198 198 description = "Upload Windows installers to PyPI (only used from tools/release_windows.py)"
199 199 user_options = upload.user_options + [
200 200 ('files=', 'f', 'exe file (or glob) to upload')
201 201 ]
202 202 def initialize_options(self):
203 203 upload.initialize_options(self)
204 204 meta = self.distribution.metadata
205 205 base = '{name}-{version}'.format(
206 206 name=meta.get_name(),
207 207 version=meta.get_version()
208 208 )
209 209 self.files = os.path.join('dist', '%s.*.exe' % base)
210 210
211 211 def run(self):
212 212 for dist_file in glob(self.files):
213 213 self.upload_file('bdist_wininst', 'any', dist_file)
214 214
215 215 setup_args['cmdclass'] = {
216 216 'build_py': css_js_prerelease(
217 217 check_package_data_first(git_prebuild('IPython'))),
218 218 'sdist' : css_js_prerelease(git_prebuild('IPython', sdist)),
219 219 'upload_wininst' : UploadWindowsInstallers,
220 220 'submodule' : UpdateSubmodules,
221 221 'css' : CompileCSS,
222 222 'symlink': install_symlinked,
223 223 'install_lib_symlink': install_lib_symlink,
224 224 'install_scripts_sym': install_scripts_for_symlink,
225 225 'unsymlink': unsymlink,
226 226 'jsversion' : JavascriptVersion,
227 227 }
228 228
229 229 #---------------------------------------------------------------------------
230 230 # Handle scripts, dependencies, and setuptools specific things
231 231 #---------------------------------------------------------------------------
232 232
233 233 # For some commands, use setuptools. Note that we do NOT list install here!
234 234 # If you want a setuptools-enhanced install, just run 'setupegg.py install'
235 235 needs_setuptools = set(('develop', 'release', 'bdist_egg', 'bdist_rpm',
236 236 'bdist', 'bdist_dumb', 'bdist_wininst', 'bdist_wheel',
237 237 'egg_info', 'easy_install', 'upload', 'install_egg_info',
238 238 ))
239 239
240 240 if len(needs_setuptools.intersection(sys.argv)) > 0:
241 241 import setuptools
242 242
243 243 # This dict is used for passing extra arguments that are setuptools
244 244 # specific to setup
245 245 setuptools_extra_args = {}
246 246
247 247 # setuptools requirements
248 248
249 249 extras_require = dict(
250 250 parallel = ['pyzmq>=2.1.11'],
251 251 qtconsole = ['pyzmq>=2.1.11', 'pygments'],
252 252 zmq = ['pyzmq>=2.1.11'],
253 253 doc = ['Sphinx>=1.1', 'numpydoc'],
254 254 test = ['nose>=0.10.1', 'requests'],
255 255 terminal = [],
256 256 nbformat = ['jsonschema>=2.0'],
257 257 notebook = ['tornado>=4.0', 'pyzmq>=2.1.11', 'jinja2', 'pygments', 'mistune>=0.5'],
258 258 nbconvert = ['pygments', 'jinja2', 'mistune>=0.3.1']
259 259 )
260 260
261 261 if sys.version_info < (3, 3):
262 262 extras_require['test'].append('mock')
263 263
264 264 extras_require['notebook'].extend(extras_require['nbformat'])
265 265 extras_require['nbconvert'].extend(extras_require['nbformat'])
266 266
267 everything = set()
268 for deps in extras_require.values():
269 everything.update(deps)
270 extras_require['all'] = everything
271
272 267 install_requires = []
273 268
274 269 # add readline
275 270 if sys.platform == 'darwin':
276 271 if 'bdist_wheel' in sys.argv[1:] or not setupext.check_for_readline():
277 272 install_requires.append('gnureadline')
278 273 elif sys.platform.startswith('win'):
279 274 extras_require['terminal'].append('pyreadline>=2.0')
280 275
276 everything = set()
277 for deps in extras_require.values():
278 everything.update(deps)
279 extras_require['all'] = everything
281 280
282 281 if 'setuptools' in sys.modules:
283 282 # setup.py develop should check for submodules
284 283 from setuptools.command.develop import develop
285 284 setup_args['cmdclass']['develop'] = require_submodules(develop)
286 285 setup_args['cmdclass']['bdist_wheel'] = css_js_prerelease(get_bdist_wheel())
287 286
288 287 setuptools_extra_args['zip_safe'] = False
289 288 setuptools_extra_args['entry_points'] = {
290 289 'console_scripts': find_entry_points(),
291 290 'pygments.lexers': [
292 291 'ipythonconsole = IPython.nbconvert.utils.lexers:IPythonConsoleLexer',
293 292 'ipython = IPython.nbconvert.utils.lexers:IPythonLexer',
294 293 'ipython3 = IPython.nbconvert.utils.lexers:IPython3Lexer',
295 294 ],
296 295 }
297 296 setup_args['extras_require'] = extras_require
298 297 requires = setup_args['install_requires'] = install_requires
299 298
300 299 # Script to be run by the windows binary installer after the default setup
301 300 # routine, to add shortcuts and similar windows-only things. Windows
302 301 # post-install scripts MUST reside in the scripts/ dir, otherwise distutils
303 302 # doesn't find them.
304 303 if 'bdist_wininst' in sys.argv:
305 304 if len(sys.argv) > 2 and \
306 305 ('sdist' in sys.argv or 'bdist_rpm' in sys.argv):
307 306 print("ERROR: bdist_wininst must be run alone. Exiting.", file=sys.stderr)
308 307 sys.exit(1)
309 308 setup_args['data_files'].append(
310 309 ['Scripts', ('scripts/ipython.ico', 'scripts/ipython_nb.ico')])
311 310 setup_args['scripts'] = [pjoin('scripts','ipython_win_post_install.py')]
312 311 setup_args['options'] = {"bdist_wininst":
313 312 {"install_script":
314 313 "ipython_win_post_install.py"}}
315 314
316 315 else:
317 316 # If we are installing without setuptools, call this function which will
318 317 # check for dependencies an inform the user what is needed. This is
319 318 # just to make life easy for users.
320 319 for install_cmd in ('install', 'symlink'):
321 320 if install_cmd in sys.argv:
322 321 check_for_dependencies()
323 322 break
324 323 # scripts has to be a non-empty list, or install_scripts isn't called
325 324 setup_args['scripts'] = [e.split('=')[0].strip() for e in find_entry_points()]
326 325
327 326 setup_args['cmdclass']['build_scripts'] = build_scripts_entrypt
328 327
329 328 #---------------------------------------------------------------------------
330 329 # Do the actual setup now
331 330 #---------------------------------------------------------------------------
332 331
333 332 setup_args.update(setuptools_extra_args)
334 333
335 334 def main():
336 335 setup(**setup_args)
337 336
338 337 if __name__ == '__main__':
339 338 main()
General Comments 0
You need to be logged in to leave comments. Login now