6
6
'./setup.py --help' for more options
15
10
# META INFORMATION FOR SETUP
17
12
META_INFO = {'name': 'bzr',
18
'version': bzrlib.__version__,
19
14
'author': 'Canonical Ltd',
20
'author_email': 'bazaar@lists.canonical.com',
15
'author_email': 'bazaar-ng@lists.ubuntu.com',
21
16
'url': 'http://www.bazaar-vcs.org/',
22
17
'description': 'Friendly distributed version control system',
23
18
'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
######################################################################
21
BZRLIB = {'packages': ['bzrlib',
24
'bzrlib.bundle.serializer',
29
'bzrlib.plugins.launchpad',
31
'bzrlib.store.revision',
32
'bzrlib.store.versioned',
34
'bzrlib.tests.blackbox',
35
'bzrlib.tests.branch_implementations',
36
'bzrlib.tests.bzrdir_implementations',
37
'bzrlib.tests.interrepository_implementations',
38
'bzrlib.tests.interversionedfile_implementations',
39
'bzrlib.tests.repository_implementations',
40
'bzrlib.tests.revisionstore_implementations',
41
'bzrlib.tests.workingtree_implementations',
43
'bzrlib.transport.http',
46
'bzrlib.util.configobj',
47
'bzrlib.util.effbot.org',
48
'bzrlib.util.elementtree',
37
54
# Reinvocation stolen from bzr, we need python2.4 by virtue of bzr_man
38
55
# including bzrlib.help
41
61
version_info = sys.version_info
42
62
except AttributeError:
58
78
print >>sys.stderr, "bzr: error: cannot find a suitable python interpreter"
59
79
print >>sys.stderr, " (need %d.%d or later)" % NEED_VERS
61
if getattr(os, "unsetenv", None) is not None:
81
if hasattr(os, "unsetenv"):
62
82
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()
89
85
from distutils.core import setup
90
86
from distutils.command.install_scripts import install_scripts
91
87
from distutils.command.build import build
99
95
Create bzr.bat for win32.
102
101
install_scripts.run(self) # standard action
104
103
if sys.platform == "win32":
106
105
scripts_dir = self.install_dir
107
script_path = self._quoted_path(os.path.join(scripts_dir,
109
python_exe = self._quoted_path(sys.executable)
110
args = self._win_batch_args()
111
batch_str = "@%s %s %s" % (python_exe, script_path, args)
106
script_path = os.path.join(scripts_dir, "bzr")
107
batch_str = "@%s %s %%*\n" % (sys.executable, script_path)
112
108
batch_path = script_path + ".bat"
113
109
f = file(batch_path, "w")
114
110
f.write(batch_str)
117
113
except Exception, e:
118
114
print "ERROR: Unable to create %s: %s" % (batch_path, e)
120
def _quoted_path(self, path):
122
return '"' + path + '"'
126
def _win_batch_args(self):
127
from bzrlib.win32utils import winver
128
if winver == 'Windows NT':
131
return '%1 %2 %3 %4 %5 %6 %7 %8 %9'
132
#/class my_install_scripts
135
117
class bzr_build(build):
136
118
"""Customized build distutils action.
148
130
########################
150
command_classes = {'install_scripts': my_install_scripts,
154
from Pyrex.Distutils import build_ext
156
# try to build the extension from the prior generated source.
157
print ("Pyrex not available, while bzr will build, "
158
"you cannot modify the C extensions.")
159
from distutils.command.build_ext import build_ext
160
from distutils.extension import Extension
162
Extension("bzrlib.compiled.dirstate_helpers",
163
["bzrlib/compiled/dirstate_helpers.c"],
168
from distutils.extension import Extension
170
Extension("bzrlib.compiled.dirstate_helpers",
171
["bzrlib/compiled/dirstate_helpers.pyx"],
175
command_classes['build_ext'] = build_ext
177
132
if 'bdist_wininst' in sys.argv:
180
135
docs = glob.glob('doc/*.htm') + ['doc/default.css']
181
136
# python's distutils-based win32 installer
182
137
ARGS = {'scripts': ['bzr', 'tools/win32/bzr-win32-bdist-postinstall.py'],
138
# install the txt files from bzrlib.doc.api.
139
'package_data': {'bzrlib': ['doc/api/*.txt']},
184
141
'data_files': [('Doc/Bazaar', docs)],
187
144
ARGS.update(META_INFO)
188
145
ARGS.update(BZRLIB)
189
ARGS.update(PKG_DATA)
213
169
version = version_str,
214
170
description = META_INFO['description'],
215
171
author = META_INFO['author'],
216
copyright = "(c) Canonical Ltd, 2005-2007",
172
copyright = "(c) Canonical Ltd, 2005-2006",
217
173
company_name = "Canonical Ltd.",
218
174
comments = META_INFO['description'],
221
additional_packages = []
222
if sys.version.startswith('2.4'):
223
# adding elementtree package
224
additional_packages.append('elementtree')
225
elif sys.version.startswith('2.5'):
226
additional_packages.append('xml.etree')
229
warnings.warn('Unknown Python version.\n'
230
'Please check setup.py script for compatibility.')
232
176
options_list = {"py2exe": {"packages": BZRLIB['packages'] +
234
178
"excludes": ["Tkinter", "medusa"],
235
179
"dist_dir": "win32_bzr.exe",
246
190
ARGS = {'scripts': ['bzr'],
247
191
'data_files': [('man/man1', ['bzr.1'])],
248
'cmdclass': command_classes,
249
'ext_modules': ext_modules,
192
# install the txt files from bzrlib.doc.api.
193
'package_data': {'bzrlib': ['doc/api/*.txt']},
194
'cmdclass': {'build': bzr_build,
195
'install_scripts': my_install_scripts,
252
199
ARGS.update(META_INFO)
253
200
ARGS.update(BZRLIB)
254
ARGS.update(PKG_DATA)