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') |
|
4360.8.1
by Alexander Belchenko
using zdll on Windows to build _chk_map_pyx extension |
284 |
z_lib = 'zdll' |
3696.3.10
by Robert Collins
Review feedback. |
285 |
else: |
4797.32.1
by John Arbash Meinel
Require pyrex 0.9.6.3 as the minimum version to build the static_tuple extensions. |
286 |
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 |
287 |
# 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. |
288 |
# The code it generates re-uses a "local" pointer and
|
289 |
# calls "PY_DECREF" after having set it to NULL. (It mixes PY_XDECREF
|
|
290 |
# which is NULL safe with PY_DECREF which is not.)
|
|
4634.121.1
by Martin Pool
Refuse to build with pyrex 0.9.4* |
291 |
# <https://bugs.edge.launchpad.net/bzr/+bug/449372>
|
292 |
# <https://bugs.edge.launchpad.net/bzr/+bug/276868>
|
|
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
293 |
print 'Cannot build extension "bzrlib._dirstate_helpers_pyx" using' |
3757.2.2
by John Arbash Meinel
Request from Martin, clearly comment the problem. |
294 |
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 |
295 |
pyrex_version,) |
3757.2.2
by John Arbash Meinel
Request from Martin, clearly comment the problem. |
296 |
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 |
297 |
print 'be used instead.' |
298 |
else: |
|
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
299 |
add_pyrex_extension('bzrlib._dirstate_helpers_pyx') |
3696.3.10
by Robert Collins
Review feedback. |
300 |
add_pyrex_extension('bzrlib._readdir_pyx') |
4360.8.1
by Alexander Belchenko
using zdll on Windows to build _chk_map_pyx extension |
301 |
z_lib = 'z' |
4679.3.74
by John Arbash Meinel
Revert back to before I started trying to move to pyrex/cython code. |
302 |
add_pyrex_extension('bzrlib._chk_map_pyx', libraries=[z_lib]) |
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
303 |
ext_modules.append(Extension('bzrlib._patiencediff_c', |
304 |
['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. |
305 |
if have_pyrex and pyrex_version_info < (0, 9, 6, 3): |
306 |
print
|
|
307 |
print 'Your Pyrex/Cython version %s is too old to build the simple_set' % ( |
|
308 |
pyrex_version) |
|
309 |
print 'and static_tuple extensions.' |
|
310 |
print 'Please upgrade to at least Pyrex 0.9.6.3' |
|
311 |
print
|
|
312 |
# TODO: Should this be a fatal error?
|
|
313 |
else: |
|
314 |
# We only need 0.9.6.3 to build _simple_set_pyx, but static_tuple depends
|
|
315 |
# on simple_set
|
|
316 |
add_pyrex_extension('bzrlib._simple_set_pyx') |
|
317 |
ext_modules.append(Extension('bzrlib._static_tuple_c', |
|
318 |
['bzrlib/_static_tuple_c.c'])) |
|
4679.7.1
by John Arbash Meinel
Merge the 2.1-static-tuple-no-use branch, but restore the |
319 |
add_pyrex_extension('bzrlib._btree_serializer_pyx') |
320 |
||
2617.1.1
by John Arbash Meinel
Update setup.py to just skip extensions that are not available. |
321 |
|
322 |
if unavailable_files: |
|
323 |
print 'C extension(s) not found:' |
|
324 |
print ' %s' % ('\n '.join(unavailable_files),) |
|
325 |
print 'The python versions will be used instead.' |
|
326 |
print
|
|
327 |
||
3565.5.9
by Mark Hammond
Address John's review comments |
328 |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
329 |
def get_tbzr_py2exe_info(includes, excludes, packages, console_targets, |
3871.1.6
by Mark Hammond
remerge setup changes |
330 |
gui_targets, data_files): |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
331 |
packages.append('tbzrcommands') |
332 |
||
333 |
# ModuleFinder can't handle runtime changes to __path__, but
|
|
334 |
# win32com uses them. Hook this in so win32com.shell is found.
|
|
335 |
import modulefinder |
|
336 |
import win32com |
|
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
337 |
import cPickle as pickle |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
338 |
for p in win32com.__path__[1:]: |
339 |
modulefinder.AddPackagePath("win32com", p) |
|
340 |
for extra in ["win32com.shell"]: |
|
341 |
__import__(extra) |
|
342 |
m = sys.modules[extra] |
|
343 |
for p in m.__path__[1:]: |
|
344 |
modulefinder.AddPackagePath(extra, p) |
|
345 |
||
346 |
# TBZR points to the TBZR directory
|
|
347 |
tbzr_root = os.environ["TBZR"] |
|
348 |
||
349 |
# Ensure tbzrlib itself is on sys.path
|
|
350 |
sys.path.append(tbzr_root) |
|
351 |
||
352 |
packages.append("tbzrlib") |
|
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
353 |
|
354 |
# collect up our icons.
|
|
355 |
cwd = os.getcwd() |
|
356 |
ico_root = os.path.join(tbzr_root, 'tbzrlib', 'resources') |
|
3688.3.2
by Mark Hammond
build the list of icons without changing directory. |
357 |
icos = [] # list of (path_root, relative_ico_path) |
358 |
# First always bzr's icon and its in the root of the bzr tree.
|
|
359 |
icos.append(('', 'bzr.ico')) |
|
360 |
for root, dirs, files in os.walk(ico_root): |
|
361 |
icos.extend([(ico_root, os.path.join(root, f)[len(ico_root)+1:]) |
|
362 |
for f in files if f.endswith('.ico')]) |
|
363 |
# allocate an icon ID for each file and the full path to the ico
|
|
364 |
icon_resources = [(rid, os.path.join(ico_dir, ico_name)) |
|
365 |
for rid, (ico_dir, ico_name) in enumerate(icos)] |
|
366 |
# create a string resource with the mapping. Might as well save the
|
|
367 |
# runtime some effort and write a pickle.
|
|
368 |
# Runtime expects unicode objects with forward-slash seps.
|
|
369 |
fse = sys.getfilesystemencoding() |
|
370 |
map_items = [(f.replace('\\', '/').decode(fse), rid) |
|
371 |
for rid, (_, f) in enumerate(icos)] |
|
372 |
ico_map = dict(map_items) |
|
373 |
# Create a new resource type of 'ICON_MAP', and use ID=1
|
|
374 |
other_resources = [ ("ICON_MAP", 1, pickle.dumps(ico_map))] |
|
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
375 |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
376 |
excludes.extend("""pywin pywin.dialogs pywin.dialogs.list |
377 |
win32ui crawler.Crawler""".split()) |
|
378 |
||
379 |
# tbzrcache executables - a "console" version for debugging and a
|
|
380 |
# GUI version that is generally used.
|
|
381 |
tbzrcache = dict( |
|
3871.1.6
by Mark Hammond
remerge setup changes |
382 |
script = os.path.join(tbzr_root, "scripts", "tbzrcache.py"), |
3684.2.1
by Mark Hammond
include tbzr icons in windows binary distributions |
383 |
icon_resources = icon_resources, |
384 |
other_resources = other_resources, |
|
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
385 |
)
|
386 |
console_targets.append(tbzrcache) |
|
387 |
||
388 |
# Make a windows version which is the same except for the base name.
|
|
389 |
tbzrcachew = tbzrcache.copy() |
|
390 |
tbzrcachew["dest_base"]="tbzrcachew" |
|
391 |
gui_targets.append(tbzrcachew) |
|
392 |
||
393 |
# ditto for the tbzrcommand tool
|
|
394 |
tbzrcommand = dict( |
|
3871.1.6
by Mark Hammond
remerge setup changes |
395 |
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. |
396 |
icon_resources = [(0,'bzr.ico')], |
397 |
)
|
|
398 |
console_targets.append(tbzrcommand) |
|
399 |
tbzrcommandw = tbzrcommand.copy() |
|
400 |
tbzrcommandw["dest_base"]="tbzrcommandw" |
|
401 |
gui_targets.append(tbzrcommandw) |
|
402 |
||
3871.1.6
by Mark Hammond
remerge setup changes |
403 |
# A utility to see python output from both C++ and Python based shell
|
404 |
# extensions
|
|
405 |
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. |
406 |
console_targets.append(tracer) |
407 |
||
3871.1.6
by Mark Hammond
remerge setup changes |
408 |
# The C++ implemented shell extensions.
|
4634.76.1
by Naoki INADA
TBZR: Remove tbzr_old.dll, refactoring directory tree. |
409 |
dist_dir = os.path.join(tbzr_root, "shellext", "build") |
3871.1.6
by Mark Hammond
remerge setup changes |
410 |
data_files.append(('', [os.path.join(dist_dir, 'tbzrshellext_x86.dll')])) |
411 |
data_files.append(('', [os.path.join(dist_dir, 'tbzrshellext_x64.dll')])) |
|
412 |
||
3565.5.9
by Mark Hammond
Address John's review comments |
413 |
|
4584.1.1
by Alexander Belchenko
Bundle imageformats plugins for PyQt4 into bzr.exe installer to enable support of many image formats in QBzr. |
414 |
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. |
415 |
# PyQt4 itself still escapes the plugin detection code for some reason...
|
416 |
packages.append('PyQt4') |
|
417 |
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 |
418 |
excludes.append('PyQt4.uic.port_v3') |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
419 |
includes.append('sip') # extension module required for Qt. |
420 |
packages.append('pygments') # colorizer for qbzr |
|
3697.9.1
by Mark Hammond
include docutils for tbzr to use formatting bzr help topics as HTML |
421 |
packages.append('docutils') # html formatting |
4634.48.1
by Alexander Belchenko
trivial improvement re collecting dependencies for QBzr. |
422 |
includes.append('win32event') # for qsubprocess stuff |
3565.5.6
by Mark Hammond
move tbzr and qbzr py2exe config code into their own functions. |
423 |
# but we can avoid many Qt4 Dlls.
|
424 |
dll_excludes.extend( |
|
425 |
"""QtAssistantClient4.dll QtCLucene4.dll QtDesigner4.dll
|
|
426 |
QtHelp4.dll QtNetwork4.dll QtOpenGL4.dll QtScript4.dll
|
|
427 |
QtSql4.dll QtTest4.dll QtWebKit4.dll QtXml4.dll
|
|
428 |
qscintilla2.dll""".split()) |
|
429 |
# 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 |
430 |
# They seem to install to a place like C:\Python25\PyQt4\*
|
431 |
# Which is not the same as C:\Python25\Lib\site-packages\PyQt4
|
|
432 |
pyqt_dir = os.path.join(sys.prefix, "PyQt4") |
|
433 |
pyqt_bin_dir = os.path.join(pyqt_dir, "bin") |
|
434 |
if os.path.isdir(pyqt_bin_dir): |
|
435 |
path = os.environ.get("PATH", "") |
|
436 |
if pyqt_bin_dir.lower() not in [p.lower() for p in path.split(os.pathsep)]: |
|
437 |
os.environ["PATH"] = path + os.pathsep + pyqt_bin_dir |
|
438 |
# also add all imageformat plugins to distribution
|
|
439 |
# We will look in 2 places, dirname(PyQt4.__file__) and pyqt_dir
|
|
440 |
base_dirs_to_check = [] |
|
441 |
if os.path.isdir(pyqt_dir): |
|
442 |
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. |
443 |
try: |
444 |
import PyQt4 |
|
445 |
except ImportError: |
|
4584.1.2
by John Arbash Meinel
Rework the setup.py a little bit, to support other versions of PyQt |
446 |
pass
|
447 |
else: |
|
448 |
pyqt4_base_dir = os.path.dirname(PyQt4.__file__) |
|
449 |
if pyqt4_base_dir != pyqt_dir: |
|
450 |
base_dirs_to_check.append(pyqt4_base_dir) |
|
451 |
if not base_dirs_to_check: |
|
452 |
log.warn("Can't find PyQt4 installation -> not including imageformat" |
|
453 |
" plugins") |
|
454 |
else: |
|
455 |
files = [] |
|
456 |
for base_dir in base_dirs_to_check: |
|
457 |
plug_dir = os.path.join(base_dir, 'plugins', 'imageformats') |
|
458 |
if os.path.isdir(plug_dir): |
|
459 |
for fname in os.listdir(plug_dir): |
|
460 |
# Include plugin dlls, but not debugging dlls
|
|
461 |
fullpath = os.path.join(plug_dir, fname) |
|
462 |
if fname.endswith('.dll') and not fname.endswith('d4.dll'): |
|
463 |
files.append(fullpath) |
|
464 |
if files: |
|
465 |
data_files.append(('imageformats', files)) |
|
466 |
else: |
|
467 |
log.warn('PyQt4 was found, but we could not find any imageformat' |
|
468 |
' 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. |
469 |
|
1739.1.1
by Robert Collins
First cut at adding pyrex facilities. |
470 |
|
3995.6.1
by John Arbash Meinel
add subvertpy as a necessary library. |
471 |
def get_svn_py2exe_info(includes, excludes, packages): |
472 |
packages.append('subvertpy') |
|
5116.1.2
by Ian Clatworthy
it's sqlite3, not just sqlite |
473 |
packages.append('sqlite3') |
3995.6.1
by John Arbash Meinel
add subvertpy as a necessary library. |
474 |
|
475 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
476 |
if 'bdist_wininst' in sys.argv: |
2691.1.18
by Alexander Belchenko
teach windows python installer to find docs in all subdirectories |
477 |
def find_docs(): |
478 |
docs = [] |
|
479 |
for root, dirs, files in os.walk('doc'): |
|
480 |
r = [] |
|
481 |
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) |
482 |
if (os.path.splitext(f)[1] in ('.html','.css','.png','.pdf') |
483 |
or f == 'quick-start-summary.svg'): |
|
2691.1.18
by Alexander Belchenko
teach windows python installer to find docs in all subdirectories |
484 |
r.append(os.path.join(root, f)) |
485 |
if r: |
|
486 |
relative = root[4:] |
|
487 |
if relative: |
|
488 |
target = os.path.join('Doc\\Bazaar', relative) |
|
489 |
else: |
|
490 |
target = 'Doc\\Bazaar' |
|
491 |
docs.append((target, r)) |
|
492 |
return docs |
|
493 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
494 |
# python's distutils-based win32 installer
|
495 |
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 |
496 |
'ext_modules': ext_modules, |
1860.1.3
by Alexander Belchenko
python-installer: |
497 |
# help pages
|
2691.1.18
by Alexander Belchenko
teach windows python installer to find docs in all subdirectories |
498 |
'data_files': find_docs(), |
2571.3.1
by Alexander Belchenko
Building Python-based installer for bot Python 2.4 and 2.5 |
499 |
# 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. |
500 |
'cmdclass': {'build_ext': build_ext_if_possible}, |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
501 |
}
|
1821.1.2
by Alexander Belchenko
resurrected python's distutils based installer for win32 |
502 |
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
503 |
ARGS.update(META_INFO) |
504 |
ARGS.update(BZRLIB) |
|
1911.1.1
by Alexander Belchenko
setup.py: need to install data files for selftest from bzrlib/tests/test_patched_data |
505 |
ARGS.update(PKG_DATA) |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
506 |
|
507 |
setup(**ARGS) |
|
508 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
509 |
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 |
510 |
import glob |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
511 |
# py2exe setup
|
512 |
import py2exe |
|
513 |
||
514 |
# pick real bzr version
|
|
515 |
import bzrlib |
|
516 |
||
517 |
version_number = [] |
|
518 |
for i in bzrlib.version_info[:4]: |
|
519 |
try: |
|
520 |
i = int(i) |
|
521 |
except ValueError: |
|
522 |
i = 0 |
|
523 |
version_number.append(str(i)) |
|
524 |
version_str = '.'.join(version_number) |
|
525 |
||
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
526 |
# An override to install_data used only by py2exe builds, which arranges
|
527 |
# to byte-compile any .py files in data_files (eg, our plugins)
|
|
528 |
# Necessary as we can't rely on the user having the relevant permissions
|
|
529 |
# to the "Program Files" directory to generate them on the fly.
|
|
530 |
class install_data_with_bytecompile(install_data): |
|
531 |
def run(self): |
|
532 |
from distutils.util import byte_compile |
|
533 |
||
534 |
install_data.run(self) |
|
535 |
||
536 |
py2exe = self.distribution.get_command_obj('py2exe', False) |
|
537 |
optimize = py2exe.optimize |
|
538 |
compile_names = [f for f in self.outfiles if f.endswith('.py')] |
|
539 |
byte_compile(compile_names, |
|
540 |
optimize=optimize, |
|
541 |
force=self.force, prefix=self.install_dir, |
|
542 |
dry_run=self.dry_run) |
|
543 |
if optimize: |
|
544 |
suffix = 'o' |
|
545 |
else: |
|
546 |
suffix = 'c' |
|
547 |
self.outfiles.extend([f + suffix for f in compile_names]) |
|
548 |
# end of class install_data_with_bytecompile
|
|
549 |
||
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
550 |
target = py2exe.build_exe.Target(script = "bzr", |
551 |
dest_base = "bzr", |
|
552 |
icon_resources = [(0,'bzr.ico')], |
|
553 |
name = META_INFO['name'], |
|
554 |
version = version_str, |
|
555 |
description = META_INFO['description'], |
|
556 |
author = META_INFO['author'], |
|
4797.36.2
by Ian Clatworthy
tweak project URL and copyright years |
557 |
copyright = "(c) Canonical Ltd, 2005-2010", |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
558 |
company_name = "Canonical Ltd.", |
559 |
comments = META_INFO['description'], |
|
560 |
)
|
|
2231.1.1
by Alexander Belchenko
Python 2.5 fixes for win32 installer |
561 |
|
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
562 |
packages = BZRLIB['packages'] |
563 |
packages.remove('bzrlib') |
|
564 |
packages = [i for i in packages if not i.startswith('bzrlib.plugins')] |
|
565 |
includes = [] |
|
566 |
for i in glob.glob('bzrlib\\*.py'): |
|
567 |
module = i[:-3].replace('\\', '.') |
|
3193.7.9
by Alexander Belchenko
Ian's review |
568 |
if module.endswith('__init__'): |
569 |
module = module[:-len('__init__')] |
|
3193.7.3
by Alexander Belchenko
bzr.exe: move builtin plugins (launchpad, multiparent) out of library.zip to plugins directory |
570 |
includes.append(module) |
571 |
||
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) |
572 |
additional_packages = set() |
2231.1.1
by Alexander Belchenko
Python 2.5 fixes for win32 installer |
573 |
if sys.version.startswith('2.4'): |
574 |
# 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) |
575 |
additional_packages.add('elementtree') |
5111.1.1
by Ian Clatworthy
Support Python 2.6 in our py2exe scripts |
576 |
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) |
577 |
additional_packages.add('xml.etree') |
2234.5.2
by Wouter van Heyst
(Alexander Belchenko) add windows installer check for python2.5 |
578 |
else: |
579 |
import warnings |
|
580 |
warnings.warn('Unknown Python version.\n' |
|
581 |
'Please check setup.py script for compatibility.') |
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
582 |
|
583 |
# Although we currently can't enforce it, we consider it an error for
|
|
584 |
# py2exe to report any files are "missing". Such modules we know aren't
|
|
585 |
# used should be listed here.
|
|
586 |
excludes = """Tkinter psyco ElementPath r_hmac |
|
587 |
ImaginaryModule cElementTree elementtree.ElementTree
|
|
588 |
Crypto.PublicKey._fastmath
|
|
589 |
medusa medusa.filesys medusa.ftp_server
|
|
4070.11.12
by Martin Pool
Move tools.doc_generate into bzrlib |
590 |
tools
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
591 |
resource validate""".split() |
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
592 |
dll_excludes = [] |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
593 |
|
2571.3.2
by Alexander Belchenko
Build pyrex/C extensions for bzr.exe |
594 |
# email package from std python library use lazy import,
|
595 |
# 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) |
596 |
additional_packages.add('email') |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
597 |
# And it uses funky mappings to conver to 'Oldname' to 'newname'. As
|
598 |
# a result, packages like 'email.Parser' show as missing. Tell py2exe
|
|
599 |
# to exclude them.
|
|
600 |
import email |
|
601 |
for oldname in getattr(email, '_LOWERNAMES', []): |
|
602 |
excludes.append("email." + oldname) |
|
603 |
for oldname in getattr(email, '_MIMENAMES', []): |
|
604 |
excludes.append("email.MIME" + oldname) |
|
2231.1.1
by Alexander Belchenko
Python 2.5 fixes for win32 installer |
605 |
|
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). |
606 |
# text files for help topis
|
3089.3.6
by Ian Clatworthy
make help topics more discoverable |
607 |
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 |
608 |
topics_files = [('lib/help_topics/en', text_topics)] |
609 |
||
610 |
# built-in plugins
|
|
611 |
plugins_files = [] |
|
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
612 |
# XXX - should we consider having the concept of an 'official' build,
|
613 |
# which hard-codes the list of plugins, gets more upset if modules are
|
|
614 |
# missing, etc?
|
|
615 |
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 |
616 |
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. |
617 |
if root == 'bzrlib/plugins': |
618 |
plugins = set(dirs) |
|
3871.1.7
by Mark Hammond
change comment as requested by John |
619 |
# We ship plugins as normal files on the file-system - however,
|
620 |
# the build process can cause *some* of these plugin files to end
|
|
621 |
# up in library.zip. Thus, we saw (eg) "plugins/svn/test" in
|
|
622 |
# library.zip, and then saw import errors related to that as the
|
|
623 |
# rest of the svn plugin wasn't. So we tell py2exe to leave the
|
|
624 |
# plugins out of the .zip file
|
|
3871.1.6
by Mark Hammond
remerge setup changes |
625 |
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 |
626 |
x = [] |
627 |
for i in files: |
|
4797.36.1
by Ian Clatworthy
Fix plugin data file packaging |
628 |
# Throw away files we don't want packaged. Note that plugins may
|
629 |
# have data files with all sorts of extensions so we need to
|
|
630 |
# be conservative here about what we ditch.
|
|
631 |
ext = os.path.splitext(i)[1] |
|
632 |
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 |
633 |
continue
|
634 |
if i == '__init__.py' and root == 'bzrlib/plugins': |
|
635 |
continue
|
|
636 |
x.append(os.path.join(root, i)) |
|
637 |
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) |
638 |
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 |
639 |
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) |
640 |
# find modules for built-in plugins
|
641 |
import tools.package_mf |
|
642 |
mf = tools.package_mf.CustomModuleFinder() |
|
643 |
mf.run_package('bzrlib/plugins') |
|
644 |
packs, mods = mf.get_result() |
|
645 |
additional_packages.update(packs) |
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
646 |
includes.extend(mods) |
647 |
||
648 |
console_targets = [target, |
|
649 |
'tools/win32/bzr_postinstall.py', |
|
650 |
]
|
|
651 |
gui_targets = [] |
|
3871.1.6
by Mark Hammond
remerge setup changes |
652 |
data_files = topics_files + plugins_files |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
653 |
|
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
654 |
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. |
655 |
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. |
656 |
|
3995.6.1
by John Arbash Meinel
add subvertpy as a necessary library. |
657 |
if 'svn' in plugins: |
658 |
get_svn_py2exe_info(includes, excludes, packages) |
|
659 |
||
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
660 |
if "TBZR" in os.environ: |
3565.5.9
by Mark Hammond
Address John's review comments |
661 |
# TORTOISE_OVERLAYS_MSI_WIN32 must be set to the location of the
|
662 |
# TortoiseOverlays MSI installer file. It is in the TSVN svn repo and
|
|
663 |
# 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. |
664 |
# http://tortoisesvn.tigris.org/svn/tortoisesvn/TortoiseOverlays
|
665 |
# look for: version-1.0.4/bin/TortoiseOverlays-1.0.4.11886-win32.msi
|
|
3871.1.6
by Mark Hammond
remerge setup changes |
666 |
# Ditto for TORTOISE_OVERLAYS_MSI_X64, pointing at *-x64.msi.
|
667 |
for needed in ('TORTOISE_OVERLAYS_MSI_WIN32', |
|
668 |
'TORTOISE_OVERLAYS_MSI_X64'): |
|
4343.2.1
by John Arbash Meinel
Give a better error message when we cannot find the TortoiseOverlays files. |
669 |
url = ('http://guest:@tortoisesvn.tigris.org/svn/tortoisesvn' |
670 |
'/TortoiseOverlays') |
|
3871.1.6
by Mark Hammond
remerge setup changes |
671 |
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. |
672 |
raise RuntimeError( |
673 |
"\nPlease set %s to the location of the relevant" |
|
674 |
"\nTortoiseOverlays .msi installer file." |
|
675 |
" The installers can be found at"
|
|
676 |
"\n %s" |
|
677 |
"\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. |
678 |
get_tbzr_py2exe_info(includes, excludes, packages, console_targets, |
3871.1.6
by Mark Hammond
remerge setup changes |
679 |
gui_targets, data_files) |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
680 |
else: |
681 |
# print this warning to stderr as output is redirected, so it is seen
|
|
682 |
# at build time. Also to stdout so it appears in the log
|
|
683 |
for f in (sys.stderr, sys.stdout): |
|
684 |
print >> f, \ |
|
685 |
"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 |
686 |
|
3514.1.1
by John Arbash Meinel
Updates to allow building with mingw, and to exclude Vista system dlls |
687 |
# MSWSOCK.dll is a system-specific library, which py2exe accidentally pulls
|
688 |
# in on Vista.
|
|
3995.3.9
by John Arbash Meinel
Local modification to exclude certain system DLLs |
689 |
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) |
690 |
options_list = {"py2exe": {"packages": packages + list(additional_packages), |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
691 |
"includes": includes, |
692 |
"excludes": excludes, |
|
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
693 |
"dll_excludes": dll_excludes, |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
694 |
"dist_dir": "win32_bzr.exe", |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
695 |
"optimize": 1, |
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
696 |
},
|
697 |
}
|
|
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
698 |
|
1821.1.1
by Alexander Belchenko
win32 installer for bzr.dev.0.9 |
699 |
setup(options=options_list, |
3565.5.1
by Mark Hammond
merge setup.py changes for tbzr |
700 |
console=console_targets, |
701 |
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). |
702 |
zipfile='lib/library.zip', |
3871.1.6
by Mark Hammond
remerge setup changes |
703 |
data_files=data_files, |
3565.5.4
by Mark Hammond
byte-compile plugins; tweaks so qbzr and bzrsvn can be packaged. |
704 |
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). |
705 |
)
|
1860.1.2
by Alexander Belchenko
setup.py: |
706 |
|
707 |
else: |
|
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
708 |
# ad-hoc for easy_install
|
709 |
DATA_FILES = [] |
|
710 |
if not 'bdist_egg' in sys.argv: |
|
4459.2.1
by Vincent Ladeuil
Use a consistent scheme for naming pyrex source files. |
711 |
# generate and install bzr.1 only with plain install, not the
|
712 |
# easy_install one
|
|
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
713 |
DATA_FILES = [('man/man1', ['bzr.1'])] |
714 |
||
4797.33.13
by Martin Pool
Install apport package hook and bug db config, only if running as root |
715 |
if sys.platform != 'win32': |
716 |
# see https://wiki.kubuntu.org/Apport/DeveloperHowTo
|
|
717 |
#
|
|
718 |
# checking the paths and hardcoding the check for root is a bit gross,
|
|
719 |
# but I don't see a cleaner way to find out the locations in a way
|
|
720 |
# that's going to align with the hardcoded paths in apport.
|
|
721 |
if os.geteuid() == 0: |
|
722 |
DATA_FILES += [ |
|
723 |
('/usr/share/apport/package-hooks', |
|
724 |
['apport/source_bzr.py']), |
|
725 |
('/etc/apport/crashdb.conf.d/', |
|
726 |
['apport/bzr-crashdb.conf']),] |
|
727 |
||
1860.1.2
by Alexander Belchenko
setup.py: |
728 |
# std setup
|
729 |
ARGS = {'scripts': ['bzr'], |
|
2662.1.1
by Alexander Belchenko
allow ``easy_install bzr`` runs without fatal errors. (Alexander Belchenko, #125521) |
730 |
'data_files': DATA_FILES, |
1739.1.3
by Robert Collins
Merge bzr.dev. |
731 |
'cmdclass': command_classes, |
732 |
'ext_modules': ext_modules, |
|
1860.1.2
by Alexander Belchenko
setup.py: |
733 |
}
|
2666.2.1
by Alexander Belchenko
change generated documentation extension from htm to html |
734 |
|
1860.1.2
by Alexander Belchenko
setup.py: |
735 |
ARGS.update(META_INFO) |
736 |
ARGS.update(BZRLIB) |
|
1911.1.1
by Alexander Belchenko
setup.py: need to install data files for selftest from bzrlib/tests/test_patched_data |
737 |
ARGS.update(PKG_DATA) |
1860.1.2
by Alexander Belchenko
setup.py: |
738 |
|
739 |
setup(**ARGS) |