bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
|
5609.1.1
by Vincent Ladeuil
Release 2.3b5 |
1 |
# Copyright (C) 2005-2011 Canonical Ltd
|
|
2052.3.5
by John Arbash Meinel
Guide people to how to add files to the list of exceptions |
2 |
#
|
|
1
by mbp at sourcefrog
import from baz patch-364 |
3 |
# This program is free software; you can redistribute it and/or modify
|
4 |
# it under the terms of the GNU General Public License as published by
|
|
5 |
# the Free Software Foundation; either version 2 of the License, or
|
|
6 |
# (at your option) any later version.
|
|
|
2052.3.1
by John Arbash Meinel
Add tests to cleanup the copyright of all source files |
7 |
#
|
|
1
by mbp at sourcefrog
import from baz patch-364 |
8 |
# This program is distributed in the hope that it will be useful,
|
9 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
10 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
11 |
# GNU General Public License for more details.
|
|
|
2052.3.1
by John Arbash Meinel
Add tests to cleanup the copyright of all source files |
12 |
#
|
|
1
by mbp at sourcefrog
import from baz patch-364 |
13 |
# You should have received a copy of the GNU General Public License
|
14 |
# along with this program; if not, write to the Free Software
|
|
|
4183.7.1
by Sabin Iacob
update FSF mailing address |
15 |
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
1
by mbp at sourcefrog
import from baz patch-364 |
16 |
|
|
5222.2.9
by Robert Collins
Write up some doc about bzrlib.initialize. |
17 |
"""All of bzr.
|
18 |
||
19 |
Developer documentation is available at
|
|
20 |
http://doc.bazaar.canonical.com/bzr.dev/developers/
|
|
21 |
||
22 |
The project website is at http://bazaar.canonical.com/
|
|
23 |
||
24 |
Some particularly interesting things in bzrlib are:
|
|
25 |
||
26 |
* bzrlib.initialize -- setup the library for use
|
|
27 |
* bzrlib.plugin.load_plugins -- load all installed plugins
|
|
28 |
* bzrlib.branch.Branch.open -- open a branch
|
|
29 |
* bzrlib.workingtree.WorkingTree.open -- open a working tree
|
|
30 |
||
31 |
We hope you enjoy this library.
|
|
32 |
"""
|
|
|
1
by mbp at sourcefrog
import from baz patch-364 |
33 |
|
|
3195.1.1
by Andrew Bennetts
Always include timestamps in the trace file (i.e. remove -Dtimes in favour of having it switched on permanently) |
34 |
import time |
35 |
||
36 |
# Keep track of when bzrlib was first imported, so that we can give rough
|
|
37 |
# timestamps relative to program start in the log file kept by bzrlib.trace.
|
|
38 |
_start_time = time.time() |
|
39 |
||
|
6352.3.2
by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes |
40 |
import codecs |
|
3224.5.29
by Andrew Bennetts
Install lazy_regex code sooner, so that it is there before the stdlib gets a chance to 'import string', which compiles regexes. |
41 |
import sys |
|
1
by mbp at sourcefrog
import from baz patch-364 |
42 |
|
|
3224.5.37
by Andrew Bennetts
Reinstate bzrlib.user_encoding because plugins may still use it, and we don't (yet) have a good way to mark it as deprecated. |
43 |
|
|
5
by mbp at sourcefrog
.bzrignore support |
44 |
IGNORE_FILENAME = ".bzrignore" |
45 |
||
|
1955.2.2
by John Arbash Meinel
Change the name of the test classes (test_lang => test_locale), move the function into osutils.py |
46 |
|
|
5609.38.2
by Vincent Ladeuil
Open 2.3.4 for bugfixes |
47 |
__copyright__ = "Copyright 2005-2011 Canonical Ltd." |
|
1702.1.2
by Martin Pool
Prepare for 0.8 release |
48 |
|
|
1704.2.8
by Martin Pool
Bump version to 0.9.0 |
49 |
# same format as sys.version_info: "A tuple containing the five components of
|
|
1702.1.2
by Martin Pool
Prepare for 0.8 release |
50 |
# the version number: major, minor, micro, releaselevel, and serial. All
|
51 |
# values except releaselevel are integers; the release level is 'alpha',
|
|
52 |
# 'beta', 'candidate', or 'final'. The version_info value corresponding to the
|
|
|
1704.2.8
by Martin Pool
Bump version to 0.9.0 |
53 |
# Python version 2.0 is (2, 0, 0, 'final', 0)." Additionally we use a
|
54 |
# releaselevel of 'dev' for unreleased under-development code.
|
|
55 |
||
|
6350.1.1
by Vincent Ladeuil
Open 2.5b5 for bug fixes |
56 |
version_info = (2, 5, 0, 'dev', 5) |
|
1704.2.8
by Martin Pool
Bump version to 0.9.0 |
57 |
|
|
5036.1.1
by Martin Pool
merge 2.1 back to trunk |
58 |
# API compatibility version
|
|
5609.3.2
by Vincent Ladeuil
Open trunk as 2.4dev1, bumping api_minimum_version to 2.4.0. |
59 |
api_minimum_version = (2, 4, 0) |
|
2550.2.2
by Robert Collins
Add helpers to get api versions from objects. |
60 |
|
|
4574.3.1
by Martin Pool
Give a warning when failing to load _chunks_to_lines_pyx |
61 |
|
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
62 |
def _format_version_tuple(version_info): |
|
4098.2.1
by Robert Collins
Allow self documenting hooks. |
63 |
"""Turn a version number 2, 3 or 5-tuple into a short string. |
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
64 |
|
65 |
This format matches <http://docs.python.org/dist/meta-data.html>
|
|
66 |
and the typical presentation used in Python output.
|
|
67 |
||
68 |
This also checks that the version is reasonable: the sub-release must be
|
|
|
3847.1.1
by Matt Nordhoff
Let _format_version_tuple accept alphas/betas/rcs with a subrelease of 0. |
69 |
zero for final releases.
|
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
70 |
|
|
3185.1.13
by Martin Pool
Fix doctest syntax |
71 |
>>> print _format_version_tuple((1, 0, 0, 'final', 0))
|
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
72 |
1.0.0
|
|
3185.1.13
by Martin Pool
Fix doctest syntax |
73 |
>>> print _format_version_tuple((1, 2, 0, 'dev', 0))
|
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
74 |
1.2.0dev
|
|
5485.3.1
by Martin
Don't rely on bzrlib importing itself in _format_version_tuple doctest |
75 |
>>> print _format_version_tuple((1, 2, 0, 'dev', 1))
|
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
76 |
1.2.0dev1
|
|
3185.1.13
by Martin Pool
Fix doctest syntax |
77 |
>>> print _format_version_tuple((1, 1, 1, 'candidate', 2))
|
78 |
1.1.1rc2
|
|
|
5485.3.1
by Martin
Don't rely on bzrlib importing itself in _format_version_tuple doctest |
79 |
>>> print _format_version_tuple((2, 1, 0, 'beta', 1))
|
|
5160.1.1
by Martin Pool
Show beta versions as 2.2b1 |
80 |
2.1b1
|
|
3388.1.1
by Martin Pool
_format_version_tuple can take a 3-tuple |
81 |
>>> print _format_version_tuple((1, 4, 0))
|
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
82 |
1.4.0
|
|
4098.2.1
by Robert Collins
Allow self documenting hooks. |
83 |
>>> print _format_version_tuple((1, 4))
|
84 |
1.4
|
|
|
5851.2.1
by Martin Pool
_format_version_tuple tolerates more different tuples |
85 |
>>> print _format_version_tuple((2, 1, 0, 'final', 42))
|
86 |
2.1.0.42
|
|
|
3726.1.1
by Martin Pool
Correct exception expression in _format_version_tuple (Mark Hammond) |
87 |
>>> print _format_version_tuple((1, 4, 0, 'wibble', 0))
|
|
5851.2.1
by Martin Pool
_format_version_tuple tolerates more different tuples |
88 |
1.4.0.wibble.0
|
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
89 |
"""
|
|
4634.50.1
by John Arbash Meinel
Change 'bzr --version' to always give the major.minor.micro version |
90 |
if len(version_info) == 2: |
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
91 |
main_version = '%d.%d' % version_info[:2] |
92 |
else: |
|
93 |
main_version = '%d.%d.%d' % version_info[:3] |
|
|
3388.1.1
by Martin Pool
_format_version_tuple can take a 3-tuple |
94 |
if len(version_info) <= 3: |
95 |
return main_version |
|
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
96 |
|
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
97 |
release_type = version_info[3] |
98 |
sub = version_info[4] |
|
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
99 |
|
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
100 |
if release_type == 'final' and sub == 0: |
101 |
sub_string = '' |
|
|
5851.2.1
by Martin Pool
_format_version_tuple tolerates more different tuples |
102 |
elif release_type == 'final': |
103 |
sub_string = '.' + str(sub) |
|
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
104 |
elif release_type == 'dev' and sub == 0: |
105 |
sub_string = 'dev' |
|
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
106 |
elif release_type == 'dev': |
107 |
sub_string = 'dev' + str(sub) |
|
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
108 |
elif release_type in ('alpha', 'beta'): |
|
5160.1.1
by Martin Pool
Show beta versions as 2.2b1 |
109 |
if version_info[2] == 0: |
110 |
main_version = '%d.%d' % version_info[:2] |
|
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
111 |
sub_string = release_type[0] + str(sub) |
112 |
elif release_type == 'candidate': |
|
113 |
sub_string = 'rc' + str(sub) |
|
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
114 |
else: |
|
5851.2.1
by Martin Pool
_format_version_tuple tolerates more different tuples |
115 |
return '.'.join(map(str, version_info)) |
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
116 |
|
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
117 |
return main_version + sub_string |
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
118 |
|
|
4122.1.1
by Martin Pool
Merge back 1.13 and bump version to 1.14dev |
119 |
|
|
5327.1.1
by Parth Malwankar
fixed import order of lazy_regex w.r.t _format_version_tuple definition in bzrlib |
120 |
# lazy_regex import must be done after _format_version_tuple definition
|
|
5327.1.2
by Parth Malwankar
fixed comment |
121 |
# to avoid "no attribute '_format_version_tuple'" error when using
|
122 |
# deprecated_function in the lazy_regex module.
|
|
|
5327.1.1
by Parth Malwankar
fixed import order of lazy_regex w.r.t _format_version_tuple definition in bzrlib |
123 |
if getattr(sys, '_bzr_lazy_regex', False): |
124 |
# The 'bzr' executable sets _bzr_lazy_regex. We install the lazy regex
|
|
125 |
# hack as soon as possible so that as much of the standard library can
|
|
126 |
# benefit, including the 'string' module.
|
|
127 |
del sys._bzr_lazy_regex |
|
128 |
import bzrlib.lazy_regex |
|
129 |
bzrlib.lazy_regex.install_lazy_compile() |
|
130 |
||
131 |
||
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
132 |
__version__ = _format_version_tuple(version_info) |
|
3185.1.12
by Martin Pool
Restore bzrlib.version_string variable |
133 |
version_string = __version__ |
|
3185.1.5
by Martin Pool
Use a shorter version number, and check that it makes sense. |
134 |
|
|
6352.3.2
by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes |
135 |
|
136 |
def _patch_filesystem_default_encoding(new_enc): |
|
137 |
"""Change the Python process global encoding for filesystem names |
|
138 |
|
|
|
6352.3.5
by Martin Packman
Add to docstring as suggested by vila in review |
139 |
The effect is to change how open() and other builtin functions handle
|
140 |
unicode filenames on posix systems. This should only be done near startup.
|
|
|
6352.3.2
by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes |
141 |
|
142 |
The new encoding string passed to this function must survive until process
|
|
143 |
termination, otherwise the interpreter may access uninitialized memory.
|
|
144 |
The use of intern() may defer breakage is but is not enough, the string
|
|
145 |
object should be secure against module reloading and during teardown.
|
|
146 |
"""
|
|
147 |
try: |
|
148 |
import ctypes |
|
149 |
except ImportError: |
|
150 |
return
|
|
151 |
pythonapi = getattr(ctypes, "pythonapi", None) |
|
152 |
if pythonapi is None: |
|
153 |
# Not CPython ctypes implementation
|
|
154 |
return
|
|
155 |
old_ptr = ctypes.c_void_p.in_dll(pythonapi, "Py_FileSystemDefaultEncoding") |
|
156 |
new_ptr = ctypes.cast(ctypes.c_char_p(intern(new_enc)), ctypes.c_void_p) |
|
157 |
old_ptr.value = new_ptr.value |
|
|
6352.3.4
by Martin Packman
Minor tweaks including normalising _fs_enc value |
158 |
if sys.getfilesystemencoding() != new_enc: |
|
6352.3.2
by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes |
159 |
raise RuntimeError("Failed to change the filesystem default encoding") |
160 |
return new_enc |
|
161 |
||
162 |
||
163 |
# When running under the bzr script, override bad filesystem default encoding.
|
|
164 |
# This is not safe to do for all users of bzrlib, other scripts should instead
|
|
165 |
# just ensure a usable locale is set via the $LANG variable on posix systems.
|
|
166 |
_fs_enc = sys.getfilesystemencoding() |
|
|
6352.3.8
by Martin Packman
Fix getattr error caught by PQM testing |
167 |
if getattr(sys, "_bzr_default_fs_enc", None) is not None: |
|
6352.3.2
by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes |
168 |
if (_fs_enc is None or codecs.lookup(_fs_enc).name == "ascii"): |
169 |
_fs_enc = _patch_filesystem_default_encoding(sys._bzr_default_fs_enc) |
|
170 |
if _fs_enc is None: |
|
171 |
_fs_enc = "ascii" |
|
|
6352.3.4
by Martin Packman
Minor tweaks including normalising _fs_enc value |
172 |
else: |
173 |
_fs_enc = codecs.lookup(_fs_enc).name |
|
|
6352.3.2
by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes |
174 |
|
175 |
||
|
5222.2.8
by Robert Collins
Store the library state as a global variable so that code with no other way of finding the BzrLibraryState can access it. |
176 |
# bzr has various bits of global state that are slowly being eliminated.
|
177 |
# This variable is intended to permit any new state-like things to be attached
|
|
|
5320.2.2
by Robert Collins
Move BzrLibraryState to its own module and prepare to start testing it. |
178 |
# to a library_state.BzrLibraryState object rather than getting new global
|
179 |
# variables that need to be hunted down. Accessing the current BzrLibraryState
|
|
180 |
# through this variable is not encouraged: it is better to pass it around as
|
|
181 |
# part of the context of an operation than to look it up directly, but when
|
|
|
6161.1.1
by Vincent Ladeuil
Allow config options to be overridden from the command line |
182 |
# that is too hard, it is better to use this variable than to make a brand new
|
|
5320.2.2
by Robert Collins
Move BzrLibraryState to its own module and prepare to start testing it. |
183 |
# global variable.
|
|
5222.2.10
by Robert Collins
More NEWS about the bzrlib.initialize contract change, and typographical error fixes for __init__.py. |
184 |
# If using this variable by looking it up (because it can't be easily obtained)
|
|
5222.2.8
by Robert Collins
Store the library state as a global variable so that code with no other way of finding the BzrLibraryState can access it. |
185 |
# it is important to store the reference you get, rather than looking it up
|
186 |
# repeatedly; that way your code will behave properly in the bzrlib test suite
|
|
187 |
# and from programs that do use multiple library contexts.
|
|
188 |
global_state = None |
|
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
189 |
|
190 |
||
|
5222.2.4
by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state. |
191 |
def initialize(setup_ui=True, stdin=None, stdout=None, stderr=None): |
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
192 |
"""Set up everything needed for normal use of bzrlib. |
193 |
||
194 |
Most applications that embed bzrlib, including bzr itself, should call
|
|
195 |
this function to initialize various subsystems.
|
|
196 |
||
197 |
More options may be added in future so callers should use named arguments.
|
|
198 |
||
|
5728.4.1
by Martin Pool
bzrlib.initialize now does what you'd expect |
199 |
The object returned by this function can be used as a contex manager
|
200 |
through the 'with' statement to automatically shut down when the process
|
|
201 |
is finished with bzrlib. However (from bzr 2.4) it's not necessary to
|
|
202 |
separately enter the context as well as starting bzr: bzrlib is ready to
|
|
203 |
go when this function returns.
|
|
204 |
||
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
205 |
:param setup_ui: If true (default) use a terminal UI; otherwise
|
|
5222.2.4
by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state. |
206 |
some other ui_factory must be assigned to `bzrlib.ui.ui_factory` by
|
207 |
the caller.
|
|
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
208 |
:param stdin, stdout, stderr: If provided, use these for terminal IO;
|
209 |
otherwise use the files in `sys`.
|
|
|
5728.4.1
by Martin Pool
bzrlib.initialize now does what you'd expect |
210 |
:return: A context manager for the use of bzrlib. The __exit__
|
|
5222.2.9
by Robert Collins
Write up some doc about bzrlib.initialize. |
211 |
should be called by the caller before exiting their process or
|
212 |
otherwise stopping use of bzrlib. Advanced callers can use
|
|
213 |
BzrLibraryState directly.
|
|
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
214 |
"""
|
|
5327.2.4
by Parth Malwankar
single import line for library_state and trace |
215 |
from bzrlib import library_state, trace |
|
5320.2.3
by Robert Collins
Restore the original ui_factory when existing BzrLibraryState. |
216 |
if setup_ui: |
217 |
import bzrlib.ui |
|
218 |
stdin = stdin or sys.stdin |
|
219 |
stdout = stdout or sys.stdout |
|
220 |
stderr = stderr or sys.stderr |
|
221 |
ui_factory = bzrlib.ui.make_ui_for_terminal(stdin, stdout, stderr) |
|
222 |
else: |
|
223 |
ui_factory = None |
|
|
5327.2.3
by Parth Malwankar
updated te import style for bzrlib.trace |
224 |
tracer = trace.DefaultConfig() |
|
5728.4.1
by Martin Pool
bzrlib.initialize now does what you'd expect |
225 |
state = library_state.BzrLibraryState(ui=ui_factory, trace=tracer) |
226 |
# Start automatically in case people don't realize this returns a context.
|
|
227 |
state._start() |
|
228 |
return state |
|
|
5222.2.8
by Robert Collins
Store the library state as a global variable so that code with no other way of finding the BzrLibraryState can access it. |
229 |
|
230 |
||
231 |
def test_suite(): |
|
232 |
import tests |
|
233 |
return tests.test_suite() |