4634.119.10
by John Arbash Meinel
Prepare 2.0.4 final |
1 |
# Copyright (C) 2005-2010 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 |
||
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. |
40 |
import sys |
1
by mbp at sourcefrog
import from baz patch-364 |
41 |
|
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. |
42 |
|
5
by mbp at sourcefrog
.bzrignore support |
43 |
IGNORE_FILENAME = ".bzrignore" |
44 |
||
1955.2.2
by John Arbash Meinel
Change the name of the test classes (test_lang => test_locale), move the function into osutils.py |
45 |
|
4634.145.2
by Martin Pool
Update copyright |
46 |
__copyright__ = "Copyright 2005-2010 Canonical Ltd." |
1702.1.2
by Martin Pool
Prepare for 0.8 release |
47 |
|
1704.2.8
by Martin Pool
Bump version to 0.9.0 |
48 |
# same format as sys.version_info: "A tuple containing the five components of
|
1702.1.2
by Martin Pool
Prepare for 0.8 release |
49 |
# the version number: major, minor, micro, releaselevel, and serial. All
|
50 |
# values except releaselevel are integers; the release level is 'alpha',
|
|
51 |
# 'beta', 'candidate', or 'final'. The version_info value corresponding to the
|
|
1704.2.8
by Martin Pool
Bump version to 0.9.0 |
52 |
# Python version 2.0 is (2, 0, 0, 'final', 0)." Additionally we use a
|
53 |
# releaselevel of 'dev' for unreleased under-development code.
|
|
54 |
||
5474.1.2
by Vincent Ladeuil
Open trunk again as 2.3dev3 |
55 |
version_info = (2, 3, 0, 'dev', 3) |
1704.2.8
by Martin Pool
Bump version to 0.9.0 |
56 |
|
5036.1.1
by Martin Pool
merge 2.1 back to trunk |
57 |
# API compatibility version
|
5468.1.1
by Vincent Ladeuil
Bump API version to 2.3.0. |
58 |
api_minimum_version = (2, 3, 0) |
2550.2.2
by Robert Collins
Add helpers to get api versions from objects. |
59 |
|
4574.3.1
by Martin Pool
Give a warning when failing to load _chunks_to_lines_pyx |
60 |
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
61 |
def _format_version_tuple(version_info): |
4098.2.1
by Robert Collins
Allow self documenting hooks. |
62 |
"""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" |
63 |
|
64 |
This format matches <http://docs.python.org/dist/meta-data.html>
|
|
65 |
and the typical presentation used in Python output.
|
|
66 |
||
67 |
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. |
68 |
zero for final releases.
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
69 |
|
3185.1.13
by Martin Pool
Fix doctest syntax |
70 |
>>> print _format_version_tuple((1, 0, 0, 'final', 0))
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
71 |
1.0.0
|
3185.1.13
by Martin Pool
Fix doctest syntax |
72 |
>>> print _format_version_tuple((1, 2, 0, 'dev', 0))
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
73 |
1.2.0dev
|
5485.3.1
by Martin
Don't rely on bzrlib importing itself in _format_version_tuple doctest |
74 |
>>> print _format_version_tuple((1, 2, 0, 'dev', 1))
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
75 |
1.2.0dev1
|
3185.1.13
by Martin Pool
Fix doctest syntax |
76 |
>>> print _format_version_tuple((1, 1, 1, 'candidate', 2))
|
77 |
1.1.1rc2
|
|
5485.3.1
by Martin
Don't rely on bzrlib importing itself in _format_version_tuple doctest |
78 |
>>> print _format_version_tuple((2, 1, 0, 'beta', 1))
|
5160.1.1
by Martin Pool
Show beta versions as 2.2b1 |
79 |
2.1b1
|
3388.1.1
by Martin Pool
_format_version_tuple can take a 3-tuple |
80 |
>>> print _format_version_tuple((1, 4, 0))
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
81 |
1.4.0
|
4098.2.1
by Robert Collins
Allow self documenting hooks. |
82 |
>>> print _format_version_tuple((1, 4))
|
83 |
1.4
|
|
5485.3.1
by Martin
Don't rely on bzrlib importing itself in _format_version_tuple doctest |
84 |
>>> print _format_version_tuple((2, 1, 0, 'final', 1))
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
85 |
Traceback (most recent call last):
|
86 |
...
|
|
87 |
ValueError: version_info (2, 1, 0, 'final', 1) not valid
|
|
3726.1.1
by Martin Pool
Correct exception expression in _format_version_tuple (Mark Hammond) |
88 |
>>> print _format_version_tuple((1, 4, 0, 'wibble', 0))
|
89 |
Traceback (most recent call last):
|
|
90 |
...
|
|
91 |
ValueError: version_info (1, 4, 0, 'wibble', 0) not valid
|
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
92 |
"""
|
4634.50.1
by John Arbash Meinel
Change 'bzr --version' to always give the major.minor.micro version |
93 |
if len(version_info) == 2: |
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
94 |
main_version = '%d.%d' % version_info[:2] |
95 |
else: |
|
96 |
main_version = '%d.%d.%d' % version_info[:3] |
|
3388.1.1
by Martin Pool
_format_version_tuple can take a 3-tuple |
97 |
if len(version_info) <= 3: |
98 |
return main_version |
|
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 |
release_type = version_info[3] |
101 |
sub = version_info[4] |
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
102 |
|
103 |
# check they're consistent
|
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
104 |
if release_type == 'final' and sub == 0: |
105 |
sub_string = '' |
|
106 |
elif release_type == 'dev' and sub == 0: |
|
107 |
sub_string = 'dev' |
|
4634.50.2
by John Arbash Meinel
Fix the tests. |
108 |
elif release_type == 'dev': |
109 |
sub_string = 'dev' + str(sub) |
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
110 |
elif release_type in ('alpha', 'beta'): |
5160.1.1
by Martin Pool
Show beta versions as 2.2b1 |
111 |
if version_info[2] == 0: |
112 |
main_version = '%d.%d' % version_info[:2] |
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
113 |
sub_string = release_type[0] + str(sub) |
114 |
elif release_type == 'candidate': |
|
115 |
sub_string = 'rc' + str(sub) |
|
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
116 |
else: |
3726.1.1
by Martin Pool
Correct exception expression in _format_version_tuple (Mark Hammond) |
117 |
raise ValueError("version_info %r not valid" % (version_info,)) |
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
118 |
|
3849.2.1
by John Arbash Meinel
Cleanup variable names inside a function. |
119 |
return main_version + sub_string |
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
120 |
|
4122.1.1
by Martin Pool
Merge back 1.13 and bump version to 1.14dev |
121 |
|
5327.1.1
by Parth Malwankar
fixed import order of lazy_regex w.r.t _format_version_tuple definition in bzrlib |
122 |
# lazy_regex import must be done after _format_version_tuple definition
|
5327.1.2
by Parth Malwankar
fixed comment |
123 |
# to avoid "no attribute '_format_version_tuple'" error when using
|
124 |
# 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 |
125 |
if getattr(sys, '_bzr_lazy_regex', False): |
126 |
# The 'bzr' executable sets _bzr_lazy_regex. We install the lazy regex
|
|
127 |
# hack as soon as possible so that as much of the standard library can
|
|
128 |
# benefit, including the 'string' module.
|
|
129 |
del sys._bzr_lazy_regex |
|
130 |
import bzrlib.lazy_regex |
|
131 |
bzrlib.lazy_regex.install_lazy_compile() |
|
132 |
||
133 |
||
3185.1.9
by Martin Pool
Show short version in a more terse form, like "1.2dev" |
134 |
__version__ = _format_version_tuple(version_info) |
3185.1.12
by Martin Pool
Restore bzrlib.version_string variable |
135 |
version_string = __version__ |
3185.1.5
by Martin Pool
Use a shorter version number, and check that it makes sense. |
136 |
|
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. |
137 |
# bzr has various bits of global state that are slowly being eliminated.
|
138 |
# 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. |
139 |
# to a library_state.BzrLibraryState object rather than getting new global
|
140 |
# variables that need to be hunted down. Accessing the current BzrLibraryState
|
|
141 |
# through this variable is not encouraged: it is better to pass it around as
|
|
142 |
# part of the context of an operation than to look it up directly, but when
|
|
143 |
# that is too hard, it is better to use this variable than to make a branch new
|
|
144 |
# global variable.
|
|
5222.2.10
by Robert Collins
More NEWS about the bzrlib.initialize contract change, and typographical error fixes for __init__.py. |
145 |
# 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. |
146 |
# it is important to store the reference you get, rather than looking it up
|
147 |
# repeatedly; that way your code will behave properly in the bzrlib test suite
|
|
148 |
# and from programs that do use multiple library contexts.
|
|
149 |
global_state = None |
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
150 |
|
151 |
||
5222.2.4
by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state. |
152 |
def initialize(setup_ui=True, stdin=None, stdout=None, stderr=None): |
5017.1.1
by Martin Pool
Add bzrlib.initialize |
153 |
"""Set up everything needed for normal use of bzrlib.
|
154 |
||
155 |
Most applications that embed bzrlib, including bzr itself, should call
|
|
156 |
this function to initialize various subsystems.
|
|
157 |
||
158 |
More options may be added in future so callers should use named arguments.
|
|
159 |
||
160 |
: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. |
161 |
some other ui_factory must be assigned to `bzrlib.ui.ui_factory` by
|
162 |
the caller.
|
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
163 |
:param stdin, stdout, stderr: If provided, use these for terminal IO;
|
164 |
otherwise use the files in `sys`.
|
|
5222.2.7
by Robert Collins
Document bzrlib.initialize a little better, and explicitly propogate exceptions in the new __exit__ methods. |
165 |
:return: A context manager for the use of bzrlib. The __enter__ method of
|
5222.2.10
by Robert Collins
More NEWS about the bzrlib.initialize contract change, and typographical error fixes for __init__.py. |
166 |
this context needs to be called before it takes effect, and the __exit__
|
5222.2.9
by Robert Collins
Write up some doc about bzrlib.initialize. |
167 |
should be called by the caller before exiting their process or
|
168 |
otherwise stopping use of bzrlib. Advanced callers can use
|
|
169 |
BzrLibraryState directly.
|
|
5017.1.1
by Martin Pool
Add bzrlib.initialize |
170 |
"""
|
5327.2.4
by Parth Malwankar
single import line for library_state and trace |
171 |
from bzrlib import library_state, trace |
5320.2.3
by Robert Collins
Restore the original ui_factory when existing BzrLibraryState. |
172 |
if setup_ui: |
173 |
import bzrlib.ui |
|
174 |
stdin = stdin or sys.stdin |
|
175 |
stdout = stdout or sys.stdout |
|
176 |
stderr = stderr or sys.stderr |
|
177 |
ui_factory = bzrlib.ui.make_ui_for_terminal(stdin, stdout, stderr) |
|
178 |
else: |
|
179 |
ui_factory = None |
|
5327.2.3
by Parth Malwankar
updated te import style for bzrlib.trace |
180 |
tracer = trace.DefaultConfig() |
5327.2.4
by Parth Malwankar
single import line for library_state and trace |
181 |
return library_state.BzrLibraryState(ui=ui_factory, trace=tracer) |
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. |
182 |
|
183 |
||
184 |
def test_suite(): |
|
185 |
import tests |
|
186 |
return tests.test_suite() |