1
1
#! /usr/bin/env python
3
# This is an installation script for bzr. Run it with
4
# './setup.py install', or
5
# './setup.py --help' for more options
3
"""Installation script for bzr.
5
'./setup.py install', or
6
'./setup.py --help' for more options
15
# META INFORMATION FOR SETUP
17
META_INFO = {'name': 'bzr',
18
'version': bzrlib.__version__,
19
'author': 'Canonical Ltd',
20
'author_email': 'bazaar@lists.canonical.com',
21
'url': 'http://www.bazaar-vcs.org/',
22
'description': 'Friendly distributed version control system',
23
'license': 'GNU GPL v2',
26
# The list of packages is automatically generated later. Add other things
27
# that are part of BZRLIB here.
30
PKG_DATA = {# install files from selftest suite
31
'package_data': {'bzrlib': ['doc/api/*.txt',
32
'tests/test_patches_data/*',
36
######################################################################
7
37
# Reinvocation stolen from bzr, we need python2.4 by virtue of bzr_man
8
38
# including bzrlib.help
13
41
version_info = sys.version_info
14
42
except AttributeError:
30
58
print >>sys.stderr, "bzr: error: cannot find a suitable python interpreter"
31
59
print >>sys.stderr, " (need %d.%d or later)" % NEED_VERS
33
if hasattr(os, "unsetenv"):
61
if getattr(os, "unsetenv", None) is not None:
34
62
os.unsetenv(REINVOKE)
65
def get_bzrlib_packages():
66
"""Recurse through the bzrlib directory, and extract the package names"""
69
base_path = os.path.dirname(os.path.abspath(bzrlib.__file__))
70
for root, dirs, files in os.walk(base_path):
71
if '__init__.py' in files:
72
assert root.startswith(base_path)
73
# Get just the path below bzrlib
74
package_path = root[len(base_path):]
75
# Remove leading and trailing slashes
76
package_path = package_path.strip('\\/')
78
package_name = 'bzrlib'
80
package_name = ('bzrlib.' +
81
package_path.replace('/', '.').replace('\\', '.'))
82
packages.append(package_name)
83
return sorted(packages)
86
BZRLIB['packages'] = get_bzrlib_packages()
37
89
from distutils.core import setup
38
90
from distutils.command.install_scripts import install_scripts
39
91
from distutils.command.build import build
143
generate_docs.main(argv=["bzr", "man"])
79
146
########################
81
148
########################
86
author_email='mbp@sourcefrog.net',
87
url='http://www.bazaar-ng.org/',
88
description='Friendly distributed version control system',
95
'bzrlib.tests.blackbox',
99
'bzrlib.util.elementtree',
100
'bzrlib.util.effbot.org',
101
'bzrlib.util.configobj',
104
cmdclass={'install_scripts': my_install_scripts, 'build': bzr_build},
105
data_files=[('man/man1', ['bzr.1'])],
150
command_classes = {'install_scripts': my_install_scripts,
152
from distutils.extension import Extension
155
from Pyrex.Distutils import build_ext
158
# try to build the extension from the prior generated source.
160
print ("The python package 'Pyrex' is not available."
161
" If the .c files are available,")
162
print ("they will be built,"
163
" but modifying the .pyx files will not rebuild them.")
165
from distutils.command.build_ext import build_ext
168
# Override the build_ext if we have Pyrex available
169
command_classes['build_ext'] = build_ext
170
unavailable_files = []
173
def add_pyrex_extension(module_name, **kwargs):
174
"""Add a pyrex module to build.
176
This will use Pyrex to auto-generate the .c file if it is available.
177
Otherwise it will fall back on the .c file. If the .c file is not
178
available, it will warn, and not add anything.
180
You can pass any extra options to Extension through kwargs. One example is
183
:param module_name: The python path to the module. This will be used to
184
determine the .pyx and .c files to use.
186
path = module_name.replace('.', '/')
187
pyrex_name = path + '.pyx'
190
ext_modules.append(Extension(module_name, [pyrex_name]))
192
if not os.path.isfile(c_name):
193
unavailable_files.append(c_name)
195
ext_modules.append(Extension(module_name, [c_name]))
198
add_pyrex_extension('bzrlib._dirstate_helpers_c')
199
add_pyrex_extension('bzrlib._knit_load_data_c')
202
if unavailable_files:
203
print 'C extension(s) not found:'
204
print ' %s' % ('\n '.join(unavailable_files),)
205
print 'The python versions will be used instead.'
209
if 'bdist_wininst' in sys.argv:
212
docs = glob.glob('doc/*.htm') + ['doc/default.css']
213
dev_docs = glob.glob('doc/developers/*.htm')
214
# python's distutils-based win32 installer
215
ARGS = {'scripts': ['bzr', 'tools/win32/bzr-win32-bdist-postinstall.py'],
216
'ext_modules': ext_modules,
218
'data_files': [('Doc/Bazaar', docs),
219
('Doc/Bazaar/developers', dev_docs),
221
# for building pyrex extensions
222
'cmdclass': {'build_ext': build_ext},
225
ARGS.update(META_INFO)
227
ARGS.update(PKG_DATA)
231
elif 'py2exe' in sys.argv:
235
# pick real bzr version
239
for i in bzrlib.version_info[:4]:
244
version_number.append(str(i))
245
version_str = '.'.join(version_number)
247
target = py2exe.build_exe.Target(script = "bzr",
249
icon_resources = [(0,'bzr.ico')],
250
name = META_INFO['name'],
251
version = version_str,
252
description = META_INFO['description'],
253
author = META_INFO['author'],
254
copyright = "(c) Canonical Ltd, 2005-2007",
255
company_name = "Canonical Ltd.",
256
comments = META_INFO['description'],
259
additional_packages = []
260
if sys.version.startswith('2.4'):
261
# adding elementtree package
262
additional_packages.append('elementtree')
263
elif sys.version.startswith('2.5'):
264
additional_packages.append('xml.etree')
267
warnings.warn('Unknown Python version.\n'
268
'Please check setup.py script for compatibility.')
269
# email package from std python library use lazy import,
270
# so we need to explicitly add all package
271
additional_packages.append('email')
273
options_list = {"py2exe": {"packages": BZRLIB['packages'] +
275
"excludes": ["Tkinter", "medusa", "tools"],
276
"dist_dir": "win32_bzr.exe",
279
setup(options=options_list,
281
'tools/win32/bzr_postinstall.py',
283
zipfile='lib/library.zip')
286
# ad-hoc for easy_install
288
if not 'bdist_egg' in sys.argv:
289
# generate and install bzr.1 only with plain install, not easy_install one
290
DATA_FILES = [('man/man1', ['bzr.1'])]
293
ARGS = {'scripts': ['bzr'],
294
'data_files': DATA_FILES,
295
'cmdclass': command_classes,
296
'ext_modules': ext_modules,
299
ARGS.update(META_INFO)
301
ARGS.update(PKG_DATA)