45
by Martin Pool
- add setup.py and install instructions |
1 |
#! /usr/bin/env python
|
2 |
||
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
3 |
"""Installation script for bzr.
|
4 |
Run it with
|
|
5 |
'./setup.py install', or
|
|
6 |
'./setup.py --help' for more options
|
|
7 |
"""
|
|
8 |
||
1930.3.1
by John Arbash Meinel
Change setup.py to auto-generate the list of packages to install |
9 |
import os |
3185.1.7
by Martin Pool
Always take README text from the right directory (thanks jam) |
10 |
import os.path |
1930.3.1
by John Arbash Meinel
Change setup.py to auto-generate the list of packages to install |
11 |
import sys |
12 |
||
3260.1.2
by Alexander Belchenko
use sys.version_info |
13 |
if sys.version_info < (2, 4): |
3260.1.1
by Alexander Belchenko
setup.py script explicitly checks for Python version. (#200569) |
14 |
sys.stderr.write("[ERROR] Not a supported Python version. Need 2.4+\n") |
15 |
sys.exit(1) |
|
16 |
||
3185.1.7
by Martin Pool
Always take README text from the right directory (thanks jam) |
17 |
# NOTE: The directory containing setup.py, whether run by 'python setup.py' or
|
18 |
# './setup.py' or the equivalent with another path, should always be at the
|
|
19 |
# start of the path, so this should find the right one...
|
|
1861.2.21
by Alexander Belchenko
setup.py: automatically grab version info from bzrlib |
20 |
import bzrlib |
21 |
||
3185.1.7
by Martin Pool
Always take README text from the right directory (thanks jam) |
22 |
def get_long_description(): |
23 |
dirname = os.path.dirname(__file__) |
|
24 |
readme = os.path.join(dirname, 'README') |
|
25 |
f = open(readme, 'rb') |
|
26 |
try: |
|
27 |
return f.read() |
|
28 |
finally: |
|
29 |
f.close() |
|
30 |
||
31 |
||
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
32 |
##
|
33 |
# META INFORMATION FOR SETUP
|
|
3185.1.2
by Martin Pool
Add more metadata to setup.py (#183391) |
34 |
# see http://docs.python.org/dist/meta-data.html
|
35 |
META_INFO = { |
|
36 |
'name': 'bzr', |
|
37 |
'version': bzrlib.__version__, |
|
38 |
'author': 'Canonical Ltd', |
|
39 |
'author_email': 'bazaar@lists.canonical.com', |
|
4797.36.2
by Ian Clatworthy
tweak project URL and copyright years |
40 |
'url': 'http://bazaar.canonical.com/', |
3185.1.2
by Martin Pool
Add more metadata to setup.py (#183391) |
41 |
'description': 'Friendly distributed version control system', |
42 |
'license': 'GNU GPL v2', |
|
4634.92.1
by John Arbash Meinel
Update the download location registered with pypi. |
43 |
'download_url': 'https://launchpad.net/bzr/+download', |
3185.1.7
by Martin Pool
Always take README text from the right directory (thanks jam) |
44 |
'long_description': get_long_description(), |
3185.1.2
by Martin Pool
Add more metadata to setup.py (#183391) |
45 |
'classifiers': [ |
46 |
'Development Status :: 6 - Mature', |
|
47 |
'Environment :: Console', |
|
48 |
'Intended Audience :: Developers', |
|
49 |
'Intended Audience :: System Administrators', |
|
50 |
'License :: OSI Approved :: GNU General Public License (GPL)', |
|
51 |
'Operating System :: Microsoft :: Windows', |
|
52 |
'Operating System :: OS Independent', |
|
53 |
'Operating System :: POSIX', |
|
54 |
'Programming Language :: Python', |
|
55 |
'Programming Language :: C', |
|
56 |
'Topic :: Software Development :: Version Control', |
|
57 |
],
|
|
58 |
}
|
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
59 |
|
1930.3.3
by John Arbash Meinel
Fix a stupid error in code declaration order |
60 |
# The list of packages is automatically generated later. Add other things
|
61 |
# that are part of BZRLIB here.
|
|
62 |
BZRLIB = {} |
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
63 |
|
1911.1.1
by Alexander Belchenko
setup.py: need to install data files for selftest from bzrlib/tests/test_patched_data |
64 |
PKG_DATA = {# install files from selftest suite |
65 |
'package_data': {'bzrlib': ['doc/api/*.txt', |
|
66 |
'tests/test_patches_data/*', |
|
3089.3.6
by Ian Clatworthy
make help topics more discoverable |
67 |
'help_topics/en/*.txt', |
4610.1.1
by Denys Duchier
install keys and certs. fixes bug #392401. |
68 |
'tests/ssl_certs/server_without_pass.key', |
69 |
'tests/ssl_certs/server_with_pass.key', |
|
70 |
'tests/ssl_certs/server.crt'
|
|
1911.1.1
by Alexander Belchenko
setup.py: need to install data files for selftest from bzrlib/tests/test_patched_data |
71 |
]},
|
72 |
}
|
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
73 |
|
1185.29.5
by Wouter van Heyst
Add reinvocation code to ensure setup.py is run by python2.4 |
74 |
|
1930.3.1
by John Arbash Meinel
Change setup.py to auto-generate the list of packages to install |
75 |
def get_bzrlib_packages(): |
76 |
"""Recurse through the bzrlib directory, and extract the package names"""
|
|
77 |
||
78 |
packages = [] |
|
79 |
base_path = os.path.dirname(os.path.abspath(bzrlib.__file__)) |
|
80 |
for root, dirs, files in os.walk(base_path): |
|
81 |
if '__init__.py' in files: |
|
82 |
assert root.startswith(base_path) |
|
83 |
# Get just the path below bzrlib
|
|
84 |
package_path = root[len(base_path):] |
|
85 |
# Remove leading and trailing slashes
|
|
86 |
package_path = package_path.strip('\\/') |
|
87 |
if not package_path: |
|
88 |
package_name = 'bzrlib' |
|
89 |
else: |
|
90 |
package_name = ('bzrlib.' + |
|
91 |
package_path.replace('/', '.').replace('\\', '.')) |
|
92 |
packages.append(package_name) |
|
93 |
return sorted(packages) |
|
94 |
||
95 |
||
1930.3.3
by John Arbash Meinel
Fix a stupid error in code declaration order |
96 |
BZRLIB['packages'] = get_bzrlib_packages() |
97 |
||
98 |
||
4584.1.1
by Alexander Belchenko
Bundle imageformats plugins for PyQt4 into bzr.exe installer to enable support of many image formats in QBzr. |
99 |
from distutils import log |
45
by Martin Pool
- add setup.py and install instructions |
100 |
from distutils.core import setup |
1185.23.1
by Aaron Bentley
win32 setup fixes from Belchenko |
101 |
from distutils.command.install_scripts import install_scripts |
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
102 |
from distutils.command.install_data import install_data |
1185.29.3
by Wouter van Heyst
Create bzr.1 manpage from setup.py |
103 |
from distutils.command.build import build |
1185.1.40
by Robert Collins
Merge what applied of Alexander Belchenko's win32 patch. |
104 |
|
105 |
###############################
|
|
106 |
# Overridden distutils actions
|
|
107 |
###############################
|
|
108 |
||
1185.23.1
by Aaron Bentley
win32 setup fixes from Belchenko |
109 |
class my_install_scripts(install_scripts): |
110 |
""" Customized install_scripts distutils action.
|
|
1185.1.40
by Robert Collins
Merge what applied of Alexander Belchenko's win32 patch. |
111 |
Create bzr.bat for win32.
|
112 |
"""
|
|
113 |
def run(self): |
|
1185.23.1
by Aaron Bentley
win32 setup fixes from Belchenko |
114 |
install_scripts.run(self) # standard action |
115 |
||
1185.1.40
by Robert Collins
Merge what applied of Alexander Belchenko's win32 patch. |
116 |
if sys.platform == "win32": |
1185.23.1
by Aaron Bentley
win32 setup fixes from Belchenko |
117 |
try: |
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
118 |
scripts_dir = os.path.join(sys.prefix, 'Scripts') |
1861.2.10
by Alexander Belchenko
setup.py: improved bzr.bat creation |
119 |
script_path = self._quoted_path(os.path.join(scripts_dir, |
120 |
"bzr")) |
|
121 |
python_exe = self._quoted_path(sys.executable) |
|
122 |
args = self._win_batch_args() |
|
123 |
batch_str = "@%s %s %s" % (python_exe, script_path, args) |
|
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
124 |
batch_path = os.path.join(self.install_dir, "bzr.bat") |
1185.23.1
by Aaron Bentley
win32 setup fixes from Belchenko |
125 |
f = file(batch_path, "w") |
126 |
f.write(batch_str) |
|
127 |
f.close() |
|
128 |
print "Created:", batch_path |
|
129 |
except Exception, e: |
|
130 |
print "ERROR: Unable to create %s: %s" % (batch_path, e) |
|
1185.1.40
by Robert Collins
Merge what applied of Alexander Belchenko's win32 patch. |
131 |
|
1861.2.10
by Alexander Belchenko
setup.py: improved bzr.bat creation |
132 |
def _quoted_path(self, path): |
133 |
if ' ' in path: |
|
134 |
return '"' + path + '"' |
|
135 |
else: |
|
136 |
return path |
|
137 |
||
138 |
def _win_batch_args(self): |
|
2245.4.4
by Alexander Belchenko
setup.py: fix plain 'python setup.py install' for win98 |
139 |
from bzrlib.win32utils import winver |
140 |
if winver == 'Windows NT': |
|
1861.2.10
by Alexander Belchenko
setup.py: improved bzr.bat creation |
141 |
return '%*' |
142 |
else: |
|
143 |
return '%1 %2 %3 %4 %5 %6 %7 %8 %9' |
|
144 |
#/class my_install_scripts
|
|
145 |
||
1185.1.40
by Robert Collins
Merge what applied of Alexander Belchenko's win32 patch. |
146 |
|
1185.29.3
by Wouter van Heyst
Create bzr.1 manpage from setup.py |
147 |
class bzr_build(build): |
148 |
"""Customized build distutils action.
|
|
149 |
Generate bzr.1.
|
|
150 |
"""
|
|
3759.1.1
by John Arbash Meinel
Default to requiring extensions. |
151 |
|
1185.29.3
by Wouter van Heyst
Create bzr.1 manpage from setup.py |
152 |
def run(self): |
153 |
build.run(self) |
|
154 |
||
4070.12.1
by Martin Pool
Minor review correction from John |
155 |
from tools import generate_docs |
1551.3.11
by Aaron Bentley
Merge from Robert |
156 |
generate_docs.main(argv=["bzr", "man"]) |
1185.29.3
by Wouter van Heyst
Create bzr.1 manpage from setup.py |
157 |
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
158 |
|
1185.1.40
by Robert Collins
Merge what applied of Alexander Belchenko's win32 patch. |
159 |
########################
|
160 |
## Setup
|
|
161 |
########################
|
|
162 |
||
1739.1.1
by Robert Collins
First cut at adding pyrex facilities. |
163 |
command_classes = {'install_scripts': my_install_scripts, |
2571.3.1
by Alexander Belchenko
Building Python-based installer for bot Python 2.4 and 2.5 |
164 |
'build': bzr_build} |
2814.4.1
by Lukáš Lalinský
Don't abort ``python setup.py install`` if building of a C extension is not possible. |
165 |
from distutils import log |
2814.4.2
by Alexander Belchenko
support for win32 |
166 |
from distutils.errors import CCompilerError, DistutilsPlatformError |
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
167 |
from distutils.extension import Extension |
1739.1.1
by Robert Collins
First cut at adding pyrex facilities. |
168 |
ext_modules = [] |
169 |
try: |
|
4719.3.1
by Chris Mellon
Add Cython fallback in case Pyrex is not present |
170 |
try: |
171 |
from Pyrex.Distutils import build_ext |
|
172 |
from Pyrex.Compiler.Version import version as pyrex_version |
|
173 |
except ImportError: |
|
174 |
print "No Pyrex, trying Cython..." |
|
175 |
from Cython.Distutils import build_ext |
|
176 |
from Cython.Compiler.Version import version as pyrex_version |
|
1739.1.1
by Robert Collins
First cut at adding pyrex facilities. |
177 |
except ImportError: |
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
178 |
have_pyrex = False |
1739.1.1
by Robert Collins
First cut at adding pyrex facilities. |
179 |
# try to build the extension from the prior generated source.
|
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
180 |
print
|
2617.1.2
by John Arbash Meinel
Try another form of comment |
181 |
print ("The python package 'Pyrex' is not available." |
182 |
" If the .c files are available,") |
|
183 |
print ("they will be built," |
|
184 |
" but modifying the .pyx files will not rebuild them.") |
|
2617.1.3
by John Arbash Meinel
Add another blank line to make it show up better |
185 |
print
|
1739.1.4
by Robert Collins
Fix building of C modules without pyrex installed. |
186 |
from distutils.command.build_ext import build_ext |
1739.1.1
by Robert Collins
First cut at adding pyrex facilities. |
187 |
else: |
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
188 |
have_pyrex = True |
4797.32.3
by John Arbash Meinel
We were using a list, and comparing against a tuple, compare the same types. |
189 |
pyrex_version_info = tuple(map(int, pyrex_version.split('.'))) |
2814.4.1
by Lukáš Lalinský
Don't abort ``python setup.py install`` if building of a C extension is not possible. |
190 |
|
191 |
||
192 |
class build_ext_if_possible(build_ext): |
|
193 |
||
3759.1.1
by John Arbash Meinel
Default to requiring extensions. |
194 |
user_options = build_ext.user_options + [ |
195 |
('allow-python-fallback', None, |
|
196 |
"When an extension cannot be built, allow falling"
|
|
197 |
" back to the pure-python implementation.") |
|
198 |
]
|
|
199 |
||
200 |
def initialize_options(self): |
|
201 |
build_ext.initialize_options(self) |
|
202 |
self.allow_python_fallback = False |
|
203 |
||
2814.4.2
by Alexander Belchenko
support for win32 |
204 |
def run(self): |
205 |
try: |
|
206 |
build_ext.run(self) |
|
207 |
except DistutilsPlatformError, e: |
|
3759.1.1
by John Arbash Meinel
Default to requiring extensions. |
208 |
if not self.allow_python_fallback: |
209 |
log.warn('\n Cannot build extensions.\n' |
|
3928.4.1
by John Arbash Meinel
Change the warning from setup.py to make it a bit more obvious how to install |
210 |
' Use "build_ext --allow-python-fallback" to use'
|
211 |
' slower python implementations instead.\n') |
|
3759.1.1
by John Arbash Meinel
Default to requiring extensions. |
212 |
raise
|
2814.4.4
by Alexander Belchenko
changes suggested by Aaron and Martin |
213 |
log.warn(str(e)) |
3759.1.1
by John Arbash Meinel
Default to requiring extensions. |
214 |
log.warn('\n Extensions cannot be built.\n' |
215 |
' Using the slower Python implementations instead.\n') |
|
2814.4.2
by Alexander Belchenko
support for win32 |
216 |
|
2814.4.1
by Lukáš Lalinský
Don't abort ``python setup.py install`` if building of a C extension is not possible. |
217 |
def build_extension(self, ext): |
218 |
try: |
|
219 |
build_ext.build_extension(self, ext) |
|
220 |
except CCompilerError: |
|
3759.1.1
by John Arbash Meinel
Default to requiring extensions. |
221 |
if not self.allow_python_fallback: |
4086.2.1
by John Arbash Meinel
Fix a small bug in setup.py when an extension fails to build |
222 |
log.warn('\n Cannot build extension "%s".\n' |
3928.4.1
by John Arbash Meinel
Change the warning from setup.py to make it a bit more obvious how to install |
223 |
' Use "build_ext --allow-python-fallback" to use'
|
3928.4.3
by John Arbash Meinel
fix typo in setup.py |
224 |
' slower python implementations instead.\n' |
3759.1.1
by John Arbash Meinel
Default to requiring extensions. |
225 |
% (ext.name,)) |
226 |
raise
|
|
227 |
log.warn('\n Building of "%s" extension failed.\n' |
|
228 |
' Using the slower Python implementation instead.'
|
|
229 |
% (ext.name,)) |
|
2814.4.1
by Lukáš Lalinský
Don't abort ``python setup.py install`` if building of a C extension is not possible. |
230 |
|
231 |
||
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
232 |
# Override the build_ext if we have Pyrex available
|
2814.4.1
by Lukáš Lalinský
Don't abort ``python setup.py install`` if building of a C extension is not possible. |
233 |
command_classes['build_ext'] = build_ext_if_possible |
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
234 |
unavailable_files = [] |
235 |
||
2617.1.2
by John Arbash Meinel
Try another form of comment |
236 |
|
4241.6.1
by Ian Clatworthy
chk_map code from brisbane-core |
237 |
def add_pyrex_extension(module_name, libraries=None, extra_source=[]): |
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
238 |
"""Add a pyrex module to build.
|
239 |
||
240 |
This will use Pyrex to auto-generate the .c file if it is available.
|
|
241 |
Otherwise it will fall back on the .c file. If the .c file is not
|
|
242 |
available, it will warn, and not add anything.
|
|
243 |
||
244 |
You can pass any extra options to Extension through kwargs. One example is
|
|
245 |
'libraries = []'.
|
|
246 |
||
247 |
:param module_name: The python path to the module. This will be used to
|
|
248 |
determine the .pyx and .c files to use.
|
|
249 |
"""
|
|
250 |
path = module_name.replace('.', '/') |
|
251 |
pyrex_name = path + '.pyx' |
|
252 |
c_name = path + '.c' |
|
3763.5.3
by Martin Pool
Review feedback on add_pyrex_extension |
253 |
define_macros = [] |
3763.5.2
by Martin Pool
Set -DWIN32 for all pyrex extensions, not one by one |
254 |
if sys.platform == 'win32': |
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
255 |
# pyrex uses the macro WIN32 to detect the platform, even though it
|
256 |
# should be using something like _WIN32 or MS_WINDOWS, oh well, we can
|
|
257 |
# give it the right value.
|
|
3763.5.2
by Martin Pool
Set -DWIN32 for all pyrex extensions, not one by one |
258 |
define_macros.append(('WIN32', None)) |
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
259 |
if have_pyrex: |
4241.6.1
by Ian Clatworthy
chk_map code from brisbane-core |
260 |
source = [pyrex_name] |
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
261 |
else: |
262 |
if not os.path.isfile(c_name): |
|
263 |
unavailable_files.append(c_name) |
|
4241.6.1
by Ian Clatworthy
chk_map code from brisbane-core |
264 |
return
|
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
265 |
else: |
4241.6.1
by Ian Clatworthy
chk_map code from brisbane-core |
266 |
source = [c_name] |
267 |
source.extend(extra_source) |
|
268 |
ext_modules.append(Extension(module_name, source, |
|
269 |
define_macros=define_macros, libraries=libraries)) |
|
3763.5.2
by Martin Pool
Set -DWIN32 for all pyrex extensions, not one by one |
270 |
|
271 |
||
4454.3.43
by John Arbash Meinel
Initial implementation of a Pyrex annotator. |
272 |
add_pyrex_extension('bzrlib._annotator_pyx') |
4398.5.4
by John Arbash Meinel
A bit of code restructuring. |
273 |
add_pyrex_extension('bzrlib._bencode_pyx') |
274 |
add_pyrex_extension('bzrlib._chunks_to_lines_pyx') |
|
3735.31.1
by John Arbash Meinel
Bring the groupcompress plugin into the brisbane-core branch. |
275 |
add_pyrex_extension('bzrlib._groupcompress_pyx', |
276 |
extra_source=['bzrlib/diff-delta.c']) |
|
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
277 |
add_pyrex_extension('bzrlib._knit_load_data_pyx') |
4371.3.19
by John Arbash Meinel
Get an initial pyrex implementation. |
278 |
add_pyrex_extension('bzrlib._known_graph_pyx') |
4354.3.2
by Jelmer Vernooij
Provide custom implementation of _read_stanza_utf8 in Pyrex. |
279 |
add_pyrex_extension('bzrlib._rio_pyx') |
3504.4.3
by John Arbash Meinel
Start working on an extension specifically for win32, |
280 |
if sys.platform == 'win32': |
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
281 |
add_pyrex_extension('bzrlib._dirstate_helpers_pyx', |
3763.5.2
by Martin Pool
Set -DWIN32 for all pyrex extensions, not one by one |
282 |
libraries=['Ws2_32']) |
283 |
add_pyrex_extension('bzrlib._walkdirs_win32') |
|
3696.3.10
by Robert Collins
Review feedback. |
284 |
else: |
4797.32.1
by John Arbash Meinel
Require pyrex 0.9.6.3 as the minimum version to build the static_tuple extensions. |
285 |
if have_pyrex and pyrex_version_info[:3] == (0,9,4): |
3757.2.1
by John Arbash Meinel
Work around bug #276868 by blacklisting pyrex 0.9.4.1 for that extension |
286 |
# Pyrex 0.9.4.1 fails to compile this extension correctly
|
3757.2.2
by John Arbash Meinel
Request from Martin, clearly comment the problem. |
287 |
# The code it generates re-uses a "local" pointer and
|
288 |
# calls "PY_DECREF" after having set it to NULL. (It mixes PY_XDECREF
|
|
289 |
# which is NULL safe with PY_DECREF which is not.)
|
|
4634.121.1
by Martin Pool
Refuse to build with pyrex 0.9.4* |
290 |
# <https://bugs.edge.launchpad.net/bzr/+bug/449372>
|
291 |
# <https://bugs.edge.launchpad.net/bzr/+bug/276868>
|
|
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
292 |
print 'Cannot build extension "bzrlib._dirstate_helpers_pyx" using' |
3757.2.2
by John Arbash Meinel
Request from Martin, clearly comment the problem. |
293 |
print 'your version of pyrex "%s". Please upgrade your pyrex' % ( |
3757.2.1
by John Arbash Meinel
Work around bug #276868 by blacklisting pyrex 0.9.4.1 for that extension |
294 |
pyrex_version,) |
3757.2.2
by John Arbash Meinel
Request from Martin, clearly comment the problem. |
295 |
print 'install. For now, the non-compiled (python) version will' |
3757.2.1
by John Arbash Meinel
Work around bug #276868 by blacklisting pyrex 0.9.4.1 for that extension |
296 |
print 'be used instead.' |
297 |
else: |
|
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
298 |
add_pyrex_extension('bzrlib._dirstate_helpers_pyx') |
3696.3.10
by Robert Collins
Review feedback. |
299 |
add_pyrex_extension('bzrlib._readdir_pyx') |
5165.1.1
by Martin
Use python builtin crc32 function rather than zlib C api for _chk_map_pyx |
300 |
add_pyrex_extension('bzrlib._chk_map_pyx') |
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
301 |
ext_modules.append(Extension('bzrlib._patiencediff_c', |
302 |
['bzrlib/_patiencediff_c.c'])) |
|
4797.32.1
by John Arbash Meinel
Require pyrex 0.9.6.3 as the minimum version to build the static_tuple extensions. |
303 |
if have_pyrex and pyrex_version_info < (0, 9, 6, 3): |
304 |
print
|
|
305 |
print 'Your Pyrex/Cython version %s is too old to build the simple_set' % ( |
|
306 |
pyrex_version) |
|
307 |
print 'and static_tuple extensions.' |
|
308 |
print 'Please upgrade to at least Pyrex 0.9.6.3' |
|
309 |
print
|
|
310 |
# TODO: Should this be a fatal error?
|
|
311 |
else: |
|
312 |
# We only need 0.9.6.3 to build _simple_set_pyx, but static_tuple depends
|
|
313 |
# on simple_set
|
|
314 |
add_pyrex_extension('bzrlib._simple_set_pyx') |
|
315 |
ext_modules.append(Extension('bzrlib._static_tuple_c', |
|
316 |
['bzrlib/_static_tuple_c.c'])) |
|
4679.7.1
by John Arbash Meinel
Merge the 2.1-static-tuple-no-use branch, but restore the |
317 |
add_pyrex_extension('bzrlib._btree_serializer_pyx') |
318 |
||
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
319 |
|
320 |
if unavailable_files: |
|
321 |
print 'C extension(s) not found:' |
|
322 |
print ' %s' % ('\n '.join(unavailable_files),) |
|
323 |
print 'The python versions will be used instead.' |
|
324 |
print
|
|
325 |
||
3565.5.9
by Mark Hammond
Address John's review comments |
326 |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
327 |
def get_tbzr_py2exe_info(includes, excludes, packages, console_targets, |
3871.1.6
by Mark Hammond
remerge setup changes |
328 |
gui_targets, data_files): |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
329 |
packages.append('tbzrcommands') |
330 |
||
331 |
# ModuleFinder can't handle runtime changes to __path__, but
|
|
332 |
# win32com uses them. Hook this in so win32com.shell is found.
|
|
333 |
import modulefinder |
|
334 |
import win32com |
|
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
335 |
import cPickle as pickle |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
336 |
for p in win32com.__path__[1:]: |
337 |
modulefinder.AddPackagePath("win32com", p) |
|
338 |
for extra in ["win32com.shell"]: |
|
339 |
__import__(extra) |
|
340 |
m = sys.modules[extra] |
|
341 |
for p in m.__path__[1:]: |
|
342 |
modulefinder.AddPackagePath(extra, p) |
|
343 |
||
344 |
# TBZR points to the TBZR directory
|
|
345 |
tbzr_root = os.environ["TBZR"] |
|
346 |
||
347 |
# Ensure tbzrlib itself is on sys.path
|
|
348 |
sys.path.append(tbzr_root) |
|
349 |
||
350 |
packages.append("tbzrlib") |
|
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
351 |
|
352 |
# collect up our icons.
|
|
353 |
cwd = os.getcwd() |
|
354 |
ico_root = os.path.join(tbzr_root, 'tbzrlib', 'resources') |
|
3688.3.2
by Mark Hammond
build the list of icons without changing directory. |
355 |
icos = [] # list of (path_root, relative_ico_path) |
356 |
# First always bzr's icon and its in the root of the bzr tree.
|
|
357 |
icos.append(('', 'bzr.ico')) |
|
358 |
for root, dirs, files in os.walk(ico_root): |
|
359 |
icos.extend([(ico_root, os.path.join(root, f)[len(ico_root)+1:]) |
|
360 |
for f in files if f.endswith('.ico')]) |
|
361 |
# allocate an icon ID for each file and the full path to the ico
|
|
362 |
icon_resources = [(rid, os.path.join(ico_dir, ico_name)) |
|
363 |
for rid, (ico_dir, ico_name) in enumerate(icos)] |
|
364 |
# create a string resource with the mapping. Might as well save the
|
|
365 |
# runtime some effort and write a pickle.
|
|
366 |
# Runtime expects unicode objects with forward-slash seps.
|
|
367 |
fse = sys.getfilesystemencoding() |
|
368 |
map_items = [(f.replace('\\', '/').decode(fse), rid) |
|
369 |
for rid, (_, f) in enumerate(icos)] |
|
370 |
ico_map = dict(map_items) |
|
371 |
# Create a new resource type of 'ICON_MAP', and use ID=1
|
|
372 |
other_resources = [ ("ICON_MAP", 1, pickle.dumps(ico_map))] |
|
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
373 |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
374 |
excludes.extend("""pywin pywin.dialogs pywin.dialogs.list |
375 |
win32ui crawler.Crawler""".split()) |
|
376 |
||
377 |
# tbzrcache executables - a "console" version for debugging and a
|
|
378 |
# GUI version that is generally used.
|
|
379 |
tbzrcache = dict( |
|
3871.1.6
by Mark Hammond
remerge setup changes |
380 |
script = os.path.join(tbzr_root, "scripts", "tbzrcache.py"), |
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
381 |
icon_resources = icon_resources, |
382 |
other_resources = other_resources, |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
383 |
)
|
384 |
console_targets.append(tbzrcache) |
|
385 |
||
386 |
# Make a windows version which is the same except for the base name.
|
|
387 |
tbzrcachew = tbzrcache.copy() |
|
388 |
tbzrcachew["dest_base"]="tbzrcachew" |
|
389 |
gui_targets.append(tbzrcachew) |
|
390 |
||
391 |
# ditto for the tbzrcommand tool
|
|
392 |
tbzrcommand = dict( |
|
3871.1.6
by Mark Hammond
remerge setup changes |
393 |
script = os.path.join(tbzr_root, "scripts", "tbzrcommand.py"), |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
394 |
icon_resources = [(0,'bzr.ico')], |
395 |
)
|
|
396 |
console_targets.append(tbzrcommand) |
|
397 |
tbzrcommandw = tbzrcommand.copy() |
|
398 |
tbzrcommandw["dest_base"]="tbzrcommandw" |
|
399 |
gui_targets.append(tbzrcommandw) |
|
400 |
||
3871.1.6
by Mark Hammond
remerge setup changes |
401 |
# A utility to see python output from both C++ and Python based shell
|
402 |
# extensions
|
|
403 |
tracer = dict(script=os.path.join(tbzr_root, "scripts", "tbzrtrace.py")) |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
404 |
console_targets.append(tracer) |
405 |
||
3871.1.6
by Mark Hammond
remerge setup changes |
406 |
# The C++ implemented shell extensions.
|
4634.76.1
by Naoki INADA
TBZR: Remove tbzr_old.dll, refactoring directory tree. |
407 |
dist_dir = os.path.join(tbzr_root, "shellext", "build") |
3871.1.6
by Mark Hammond
remerge setup changes |
408 |
data_files.append(('', [os.path.join(dist_dir, 'tbzrshellext_x86.dll')])) |
409 |
data_files.append(('', [os.path.join(dist_dir, 'tbzrshellext_x64.dll')])) |
|
410 |
||
3565.5.9
by Mark Hammond
Address John's review comments |
411 |
|
4584.1.1
by Alexander Belchenko
Bundle imageformats plugins for PyQt4 into bzr.exe installer to enable support of many image formats in QBzr. |
412 |
def get_qbzr_py2exe_info(includes, excludes, packages, data_files): |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
413 |
# PyQt4 itself still escapes the plugin detection code for some reason...
|
414 |
packages.append('PyQt4') |
|
415 |
excludes.append('PyQt4.elementtree.ElementTree') |
|
4921.1.1
by John Arbash Meinel
Add an exclude to get the build process to work with python2.6 and PyQt4.6.2 |
416 |
excludes.append('PyQt4.uic.port_v3') |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
417 |
includes.append('sip') # extension module required for Qt. |
418 |
packages.append('pygments') # colorizer for qbzr |
|
3697.9.1
by Mark Hammond
include docutils for tbzr to use formatting bzr help topics as HTML |
419 |
packages.append('docutils') # html formatting |
4634.48.1
by Alexander Belchenko
trivial improvement re collecting dependencies for QBzr. |
420 |
includes.append('win32event') # for qsubprocess stuff |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
421 |
# but we can avoid many Qt4 Dlls.
|
422 |
dll_excludes.extend( |
|
423 |
"""QtAssistantClient4.dll QtCLucene4.dll QtDesigner4.dll
|
|
424 |
QtHelp4.dll QtNetwork4.dll QtOpenGL4.dll QtScript4.dll
|
|
425 |
QtSql4.dll QtTest4.dll QtWebKit4.dll QtXml4.dll
|
|
426 |
qscintilla2.dll""".split()) |
|
427 |
# the qt binaries might not be on PATH...
|
|
4584.1.2
by John Arbash Meinel
Rework the setup.py a little bit, to support other versions of PyQt |
428 |
# They seem to install to a place like C:\Python25\PyQt4\*
|
429 |
# Which is not the same as C:\Python25\Lib\site-packages\PyQt4
|
|
430 |
pyqt_dir = os.path.join(sys.prefix, "PyQt4") |
|
431 |
pyqt_bin_dir = os.path.join(pyqt_dir, "bin") |
|
432 |
if os.path.isdir(pyqt_bin_dir): |
|
433 |
path = os.environ.get("PATH", "") |
|
434 |
if pyqt_bin_dir.lower() not in [p.lower() for p in path.split(os.pathsep)]: |
|
435 |
os.environ["PATH"] = path + os.pathsep + pyqt_bin_dir |
|
436 |
# also add all imageformat plugins to distribution
|
|
437 |
# We will look in 2 places, dirname(PyQt4.__file__) and pyqt_dir
|
|
438 |
base_dirs_to_check = [] |
|
439 |
if os.path.isdir(pyqt_dir): |
|
440 |
base_dirs_to_check.append(pyqt_dir) |
|
4584.1.1
by Alexander Belchenko
Bundle imageformats plugins for PyQt4 into bzr.exe installer to enable support of many image formats in QBzr. |
441 |
try: |
442 |
import PyQt4 |
|
443 |
except ImportError: |
|
4584.1.2
by John Arbash Meinel
Rework the setup.py a little bit, to support other versions of PyQt |
444 |
pass
|
445 |
else: |
|
446 |
pyqt4_base_dir = os.path.dirname(PyQt4.__file__) |
|
447 |
if pyqt4_base_dir != pyqt_dir: |
|
448 |
base_dirs_to_check.append(pyqt4_base_dir) |
|
449 |
if not base_dirs_to_check: |
|
450 |
log.warn("Can't find PyQt4 installation -> not including imageformat" |
|
451 |
" plugins") |
|
452 |
else: |
|
453 |
files = [] |
|
454 |
for base_dir in base_dirs_to_check: |
|
455 |
plug_dir = os.path.join(base_dir, 'plugins', 'imageformats') |
|
456 |
if os.path.isdir(plug_dir): |
|
457 |
for fname in os.listdir(plug_dir): |
|
458 |
# Include plugin dlls, but not debugging dlls
|
|
459 |
fullpath = os.path.join(plug_dir, fname) |
|
460 |
if fname.endswith('.dll') and not fname.endswith('d4.dll'): |
|
461 |
files.append(fullpath) |
|
462 |
if files: |
|
463 |
data_files.append(('imageformats', files)) |
|
464 |
else: |
|
465 |
log.warn('PyQt4 was found, but we could not find any imageformat' |
|
466 |
' plugins. Are you sure your configuration is correct?') |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
467 |
|
1739.1.1
by Robert Collins
First cut at adding pyrex facilities. |
468 |
|
3995.6.1
by John Arbash Meinel
add subvertpy as a necessary library. |
469 |
def get_svn_py2exe_info(includes, excludes, packages): |
470 |
packages.append('subvertpy') |
|
5116.1.2
by Ian Clatworthy
it's sqlite3, not just sqlite |
471 |
packages.append('sqlite3') |
3995.6.1
by John Arbash Meinel
add subvertpy as a necessary library. |
472 |
|
473 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
474 |
if 'bdist_wininst' in sys.argv: |
2691.1.18
by Alexander Belchenko
teach windows python installer to find docs in all subdirectories |
475 |
def find_docs(): |
476 |
docs = [] |
|
477 |
for root, dirs, files in os.walk('doc'): |
|
478 |
r = [] |
|
479 |
for f in files: |
|
3224.2.1
by Alexander Belchenko
(bialix) Include quick-start-summary.svg file to python-based installer for Windows (bug #192924) |
480 |
if (os.path.splitext(f)[1] in ('.html','.css','.png','.pdf') |
481 |
or f == 'quick-start-summary.svg'): |
|
2691.1.18
by Alexander Belchenko
teach windows python installer to find docs in all subdirectories |
482 |
r.append(os.path.join(root, f)) |
483 |
if r: |
|
484 |
relative = root[4:] |
|
485 |
if relative: |
|
486 |
target = os.path.join('Doc\\Bazaar', relative) |
|
487 |
else: |
|
488 |
target = 'Doc\\Bazaar' |
|
489 |
docs.append((target, r)) |
|
490 |
return docs |
|
491 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
492 |
# python's distutils-based win32 installer
|
493 |
ARGS = {'scripts': ['bzr', 'tools/win32/bzr-win32-bdist-postinstall.py'], |
|
2571.3.1
by Alexander Belchenko
Building Python-based installer for bot Python 2.4 and 2.5 |
494 |
'ext_modules': ext_modules, |
1860.1.3
by Alexander Belchenko
python-installer: |
495 |
# help pages
|
2691.1.18
by Alexander Belchenko
teach windows python installer to find docs in all subdirectories |
496 |
'data_files': find_docs(), |
2571.3.1
by Alexander Belchenko
Building Python-based installer for bot Python 2.4 and 2.5 |
497 |
# for building pyrex extensions
|
2814.4.1
by Lukáš Lalinský
Don't abort ``python setup.py install`` if building of a C extension is not possible. |
498 |
'cmdclass': {'build_ext': build_ext_if_possible}, |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
499 |
}
|
1821.1.2
by Alexander Belchenko
resurrected python's distutils based installer for win32 |
500 |
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
501 |
ARGS.update(META_INFO) |
502 |
ARGS.update(BZRLIB) |
|
1911.1.1
by Alexander Belchenko
setup.py: need to install data files for selftest from bzrlib/tests/test_patched_data |
503 |
ARGS.update(PKG_DATA) |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
504 |
|
505 |
setup(**ARGS) |
|
506 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
507 |
elif 'py2exe' in sys.argv: |
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
508 |
import glob |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
509 |
# py2exe setup
|
510 |
import py2exe |
|
511 |
||
512 |
# pick real bzr version
|
|
513 |
import bzrlib |
|
514 |
||
515 |
version_number = [] |
|
516 |
for i in bzrlib.version_info[:4]: |
|
517 |
try: |
|
518 |
i = int(i) |
|
519 |
except ValueError: |
|
520 |
i = 0 |
|
521 |
version_number.append(str(i)) |
|
522 |
version_str = '.'.join(version_number) |
|
523 |
||
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
524 |
# An override to install_data used only by py2exe builds, which arranges
|
525 |
# to byte-compile any .py files in data_files (eg, our plugins)
|
|
526 |
# Necessary as we can't rely on the user having the relevant permissions
|
|
527 |
# to the "Program Files" directory to generate them on the fly.
|
|
528 |
class install_data_with_bytecompile(install_data): |
|
529 |
def run(self): |
|
530 |
from distutils.util import byte_compile |
|
531 |
||
532 |
install_data.run(self) |
|
533 |
||
534 |
py2exe = self.distribution.get_command_obj('py2exe', False) |
|
535 |
optimize = py2exe.optimize |
|
536 |
compile_names = [f for f in self.outfiles if f.endswith('.py')] |
|
537 |
byte_compile(compile_names, |
|
538 |
optimize=optimize, |
|
539 |
force=self.force, prefix=self.install_dir, |
|
540 |
dry_run=self.dry_run) |
|
541 |
if optimize: |
|
542 |
suffix = 'o' |
|
543 |
else: |
|
544 |
suffix = 'c' |
|
545 |
self.outfiles.extend([f + suffix for f in compile_names]) |
|
546 |
# end of class install_data_with_bytecompile
|
|
547 |
||
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
548 |
target = py2exe.build_exe.Target(script = "bzr", |
549 |
dest_base = "bzr", |
|
550 |
icon_resources = [(0,'bzr.ico')], |
|
551 |
name = META_INFO['name'], |
|
552 |
version = version_str, |
|
553 |
description = META_INFO['description'], |
|
554 |
author = META_INFO['author'], |
|
4797.36.2
by Ian Clatworthy
tweak project URL and copyright years |
555 |
copyright = "(c) Canonical Ltd, 2005-2010", |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
556 |
company_name = "Canonical Ltd.", |
557 |
comments = META_INFO['description'], |
|
558 |
)
|
|
2231.1.1
by Alexander Belchenko
Python 2.5 fixes for win32 installer |
559 |
|
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
560 |
packages = BZRLIB['packages'] |
561 |
packages.remove('bzrlib') |
|
562 |
packages = [i for i in packages if not i.startswith('bzrlib.plugins')] |
|
563 |
includes = [] |
|
564 |
for i in glob.glob('bzrlib\\*.py'): |
|
565 |
module = i[:-3].replace('\\', '.') |
|
3193.7.9
by Alexander Belchenko
Ian's review |
566 |
if module.endswith('__init__'): |
567 |
module = module[:-len('__init__')] |
|
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
568 |
includes.append(module) |
569 |
||
3193.7.7
by Alexander Belchenko
custom module finder to find additional dependencies for built-in plugins (to bundle additional packages and modules into bzr.exe's library.zip) |
570 |
additional_packages = set() |
2231.1.1
by Alexander Belchenko
Python 2.5 fixes for win32 installer |
571 |
if sys.version.startswith('2.4'): |
572 |
# adding elementtree package
|
|
3193.7.7
by Alexander Belchenko
custom module finder to find additional dependencies for built-in plugins (to bundle additional packages and modules into bzr.exe's library.zip) |
573 |
additional_packages.add('elementtree') |
5111.1.1
by Ian Clatworthy
Support Python 2.6 in our py2exe scripts |
574 |
elif sys.version.startswith('2.6') or sys.version.startswith('2.5'): |
3193.7.7
by Alexander Belchenko
custom module finder to find additional dependencies for built-in plugins (to bundle additional packages and modules into bzr.exe's library.zip) |
575 |
additional_packages.add('xml.etree') |
2234.5.2
by Wouter van Heyst
(Alexander Belchenko) add windows installer check for python2.5 |
576 |
else: |
577 |
import warnings |
|
578 |
warnings.warn('Unknown Python version.\n' |
|
579 |
'Please check setup.py script for compatibility.') |
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
580 |
|
581 |
# Although we currently can't enforce it, we consider it an error for
|
|
582 |
# py2exe to report any files are "missing". Such modules we know aren't
|
|
583 |
# used should be listed here.
|
|
584 |
excludes = """Tkinter psyco ElementPath r_hmac |
|
585 |
ImaginaryModule cElementTree elementtree.ElementTree
|
|
586 |
Crypto.PublicKey._fastmath
|
|
587 |
medusa medusa.filesys medusa.ftp_server
|
|
4070.11.12
by Martin Pool
Move tools.doc_generate into bzrlib |
588 |
tools
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
589 |
resource validate""".split() |
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
590 |
dll_excludes = [] |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
591 |
|
2571.3.2
by Alexander Belchenko
Build pyrex/C extensions for bzr.exe |
592 |
# email package from std python library use lazy import,
|
593 |
# so we need to explicitly add all package
|
|
3193.7.7
by Alexander Belchenko
custom module finder to find additional dependencies for built-in plugins (to bundle additional packages and modules into bzr.exe's library.zip) |
594 |
additional_packages.add('email') |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
595 |
# And it uses funky mappings to conver to 'Oldname' to 'newname'. As
|
596 |
# a result, packages like 'email.Parser' show as missing. Tell py2exe
|
|
597 |
# to exclude them.
|
|
598 |
import email |
|
599 |
for oldname in getattr(email, '_LOWERNAMES', []): |
|
600 |
excludes.append("email." + oldname) |
|
601 |
for oldname in getattr(email, '_MIMENAMES', []): |
|
602 |
excludes.append("email.MIME" + oldname) |
|
2231.1.1
by Alexander Belchenko
Python 2.5 fixes for win32 installer |
603 |
|
3087.2.4
by Alexander Belchenko
Help topics can now be loaded from files (based on Ian's patch, adapted to proper support various windows installers). |
604 |
# text files for help topis
|
3089.3.6
by Ian Clatworthy
make help topics more discoverable |
605 |
text_topics = glob.glob('bzrlib/help_topics/en/*.txt') |
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
606 |
topics_files = [('lib/help_topics/en', text_topics)] |
607 |
||
608 |
# built-in plugins
|
|
609 |
plugins_files = [] |
|
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
610 |
# XXX - should we consider having the concept of an 'official' build,
|
611 |
# which hard-codes the list of plugins, gets more upset if modules are
|
|
612 |
# missing, etc?
|
|
613 |
plugins = None # will be a set after plugin sniffing... |
|
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
614 |
for root, dirs, files in os.walk('bzrlib/plugins'): |
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
615 |
if root == 'bzrlib/plugins': |
616 |
plugins = set(dirs) |
|
3871.1.7
by Mark Hammond
change comment as requested by John |
617 |
# We ship plugins as normal files on the file-system - however,
|
618 |
# the build process can cause *some* of these plugin files to end
|
|
619 |
# up in library.zip. Thus, we saw (eg) "plugins/svn/test" in
|
|
620 |
# library.zip, and then saw import errors related to that as the
|
|
621 |
# rest of the svn plugin wasn't. So we tell py2exe to leave the
|
|
622 |
# plugins out of the .zip file
|
|
3871.1.6
by Mark Hammond
remerge setup changes |
623 |
excludes.extend(["bzrlib.plugins." + d for d in dirs]) |
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
624 |
x = [] |
625 |
for i in files: |
|
4797.36.1
by Ian Clatworthy
Fix plugin data file packaging |
626 |
# Throw away files we don't want packaged. Note that plugins may
|
627 |
# have data files with all sorts of extensions so we need to
|
|
628 |
# be conservative here about what we ditch.
|
|
629 |
ext = os.path.splitext(i)[1] |
|
630 |
if ext.endswith('~') or ext in [".pyc", ".swp"]: |
|
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
631 |
continue
|
632 |
if i == '__init__.py' and root == 'bzrlib/plugins': |
|
633 |
continue
|
|
634 |
x.append(os.path.join(root, i)) |
|
635 |
if x: |
|
3193.7.7
by Alexander Belchenko
custom module finder to find additional dependencies for built-in plugins (to bundle additional packages and modules into bzr.exe's library.zip) |
636 |
target_dir = root[len('bzrlib/'):] # install to 'plugins/...' |
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
637 |
plugins_files.append((target_dir, x)) |
3193.7.7
by Alexander Belchenko
custom module finder to find additional dependencies for built-in plugins (to bundle additional packages and modules into bzr.exe's library.zip) |
638 |
# find modules for built-in plugins
|
639 |
import tools.package_mf |
|
640 |
mf = tools.package_mf.CustomModuleFinder() |
|
641 |
mf.run_package('bzrlib/plugins') |
|
642 |
packs, mods = mf.get_result() |
|
643 |
additional_packages.update(packs) |
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
644 |
includes.extend(mods) |
645 |
||
646 |
console_targets = [target, |
|
647 |
'tools/win32/bzr_postinstall.py', |
|
648 |
]
|
|
649 |
gui_targets = [] |
|
3871.1.6
by Mark Hammond
remerge setup changes |
650 |
data_files = topics_files + plugins_files |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
651 |
|
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
652 |
if 'qbzr' in plugins: |
4584.1.1
by Alexander Belchenko
Bundle imageformats plugins for PyQt4 into bzr.exe installer to enable support of many image formats in QBzr. |
653 |
get_qbzr_py2exe_info(includes, excludes, packages, data_files) |
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
654 |
|
3995.6.1
by John Arbash Meinel
add subvertpy as a necessary library. |
655 |
if 'svn' in plugins: |
656 |
get_svn_py2exe_info(includes, excludes, packages) |
|
657 |
||
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
658 |
if "TBZR" in os.environ: |
3565.5.9
by Mark Hammond
Address John's review comments |
659 |
# TORTOISE_OVERLAYS_MSI_WIN32 must be set to the location of the
|
660 |
# TortoiseOverlays MSI installer file. It is in the TSVN svn repo and
|
|
661 |
# can be downloaded from (username=guest, blank password):
|
|
4343.2.1
by John Arbash Meinel
Give a better error message when we cannot find the TortoiseOverlays files. |
662 |
# http://tortoisesvn.tigris.org/svn/tortoisesvn/TortoiseOverlays
|
663 |
# look for: version-1.0.4/bin/TortoiseOverlays-1.0.4.11886-win32.msi
|
|
3871.1.6
by Mark Hammond
remerge setup changes |
664 |
# Ditto for TORTOISE_OVERLAYS_MSI_X64, pointing at *-x64.msi.
|
665 |
for needed in ('TORTOISE_OVERLAYS_MSI_WIN32', |
|
666 |
'TORTOISE_OVERLAYS_MSI_X64'): |
|
4343.2.1
by John Arbash Meinel
Give a better error message when we cannot find the TortoiseOverlays files. |
667 |
url = ('http://guest:@tortoisesvn.tigris.org/svn/tortoisesvn' |
668 |
'/TortoiseOverlays') |
|
3871.1.6
by Mark Hammond
remerge setup changes |
669 |
if not os.path.isfile(os.environ.get(needed, '<nofile>')): |
4343.2.1
by John Arbash Meinel
Give a better error message when we cannot find the TortoiseOverlays files. |
670 |
raise RuntimeError( |
671 |
"\nPlease set %s to the location of the relevant" |
|
672 |
"\nTortoiseOverlays .msi installer file." |
|
673 |
" The installers can be found at"
|
|
674 |
"\n %s" |
|
675 |
"\ncheck in the version-X.Y.Z/bin/ subdir" % (needed, url)) |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
676 |
get_tbzr_py2exe_info(includes, excludes, packages, console_targets, |
3871.1.6
by Mark Hammond
remerge setup changes |
677 |
gui_targets, data_files) |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
678 |
else: |
679 |
# print this warning to stderr as output is redirected, so it is seen
|
|
680 |
# at build time. Also to stdout so it appears in the log
|
|
681 |
for f in (sys.stderr, sys.stdout): |
|
682 |
print >> f, \ |
|
683 |
"Skipping TBZR binaries - please set TBZR to a directory to enable"
|
|
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
684 |
|
3514.1.1
by John Arbash Meinel
Updates to allow building with mingw, and to exclude Vista system dlls |
685 |
# MSWSOCK.dll is a system-specific library, which py2exe accidentally pulls
|
686 |
# in on Vista.
|
|
3995.3.9
by John Arbash Meinel
Local modification to exclude certain system DLLs |
687 |
dll_excludes.extend(["MSWSOCK.dll", "MSVCP60.dll", "powrprof.dll"]) |
3193.7.7
by Alexander Belchenko
custom module finder to find additional dependencies for built-in plugins (to bundle additional packages and modules into bzr.exe's library.zip) |
688 |
options_list = {"py2exe": {"packages": packages + list(additional_packages), |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
689 |
"includes": includes, |
690 |
"excludes": excludes, |
|
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
691 |
"dll_excludes": dll_excludes, |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
692 |
"dist_dir": "win32_bzr.exe", |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
693 |
"optimize": 1, |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
694 |
},
|
695 |
}
|
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
696 |
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
697 |
setup(options=options_list, |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
698 |
console=console_targets, |
699 |
windows=gui_targets, |
|
3087.2.4
by Alexander Belchenko
Help topics can now be loaded from files (based on Ian's patch, adapted to proper support various windows installers). |
700 |
zipfile='lib/library.zip', |
3871.1.6
by Mark Hammond
remerge setup changes |
701 |
data_files=data_files, |
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
702 |
cmdclass={'install_data': install_data_with_bytecompile}, |
3087.2.4
by Alexander Belchenko
Help topics can now be loaded from files (based on Ian's patch, adapted to proper support various windows installers). |
703 |
)
|
1860.1.2
by Alexander Belchenko
setup.py: |
704 |
|
705 |
else: |
|
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
706 |
# ad-hoc for easy_install
|
707 |
DATA_FILES = [] |
|
708 |
if not 'bdist_egg' in sys.argv: |
|
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
709 |
# generate and install bzr.1 only with plain install, not the
|
710 |
# easy_install one
|
|
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
711 |
DATA_FILES = [('man/man1', ['bzr.1'])] |
712 |
||
4797.33.13
by Martin Pool
Install apport package hook and bug db config, only if running as root |
713 |
if sys.platform != 'win32': |
714 |
# see https://wiki.kubuntu.org/Apport/DeveloperHowTo
|
|
715 |
#
|
|
716 |
# checking the paths and hardcoding the check for root is a bit gross,
|
|
717 |
# but I don't see a cleaner way to find out the locations in a way
|
|
718 |
# that's going to align with the hardcoded paths in apport.
|
|
719 |
if os.geteuid() == 0: |
|
720 |
DATA_FILES += [ |
|
721 |
('/usr/share/apport/package-hooks', |
|
722 |
['apport/source_bzr.py']), |
|
723 |
('/etc/apport/crashdb.conf.d/', |
|
724 |
['apport/bzr-crashdb.conf']),] |
|
725 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
726 |
# std setup
|
727 |
ARGS = {'scripts': ['bzr'], |
|
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
728 |
'data_files': DATA_FILES, |
1739.1.3
by Robert Collins
Merge bzr.dev. |
729 |
'cmdclass': command_classes, |
730 |
'ext_modules': ext_modules, |
|
1860.1.2
by Alexander Belchenko
setup.py: |
731 |
}
|
2666.2.1
by Alexander Belchenko
change generated documentation extension from htm to html |
732 |
|
1860.1.2
by Alexander Belchenko
setup.py: |
733 |
ARGS.update(META_INFO) |
734 |
ARGS.update(BZRLIB) |
|
1911.1.1
by Alexander Belchenko
setup.py: need to install data files for selftest from bzrlib/tests/test_patched_data |
735 |
ARGS.update(PKG_DATA) |
1860.1.2
by Alexander Belchenko
setup.py: |
736 |
|
737 |
setup(**ARGS) |