/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
6615.6.1 by Vincent Ladeuil
Open 2.7.1 for bug fixes
1
# Copyright (C) 2005-2013, 2016, 2017 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
6622.2.1 by Jelmer Vernooij
bzr => brz in docs, explain fork.
19
Developer documentation for Bazaar is available at
20
http://doc.bazaar.canonical.com/bzr.dev/developers/,
21
it should mostly also apply to Breezy.
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
22
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
23
Some particularly interesting things in breezy are:
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
24
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
25
 * breezy.initialize -- setup the library for use
26
 * breezy.plugin.load_plugins -- load all installed plugins
27
 * breezy.branch.Branch.open -- open a branch
28
 * breezy.workingtree.WorkingTree.open -- open a working tree
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
29
30
We hope you enjoy this library.
31
"""
1 by mbp at sourcefrog
import from baz patch-364
32
6379.6.7 by Jelmer Vernooij
Move importing from future until after doc string, otherwise the doc string will disappear.
33
from __future__ import absolute_import
34
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)
35
import time
36
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
37
# Keep track of when breezy was first imported, so that we can give rough
38
# timestamps relative to program start in the log file kept by breezy.trace.
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)
39
_start_time = time.time()
40
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
41
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.
42
import sys
1 by mbp at sourcefrog
import from baz patch-364
43
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.
44
6437.1.1 by Vincent Ladeuil
Open trunk as 2.6dev1
45
__copyright__ = "Copyright 2005-2012 Canonical Ltd."
1702.1.2 by Martin Pool
Prepare for 0.8 release
46
1704.2.8 by Martin Pool
Bump version to 0.9.0
47
# same format as sys.version_info: "A tuple containing the five components of
1702.1.2 by Martin Pool
Prepare for 0.8 release
48
# the version number: major, minor, micro, releaselevel, and serial. All
49
# values except releaselevel are integers; the release level is 'alpha',
50
# 'beta', 'candidate', or 'final'. The version_info value corresponding to the
1704.2.8 by Martin Pool
Bump version to 0.9.0
51
# Python version 2.0 is (2, 0, 0, 'final', 0)."  Additionally we use a
52
# releaselevel of 'dev' for unreleased under-development code.
53
6622.1.31 by Jelmer Vernooij
Fix more tests.
54
version_info = (3, 0, 0, 'dev', 1)
1704.2.8 by Martin Pool
Bump version to 0.9.0
55
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
56
def _format_version_tuple(version_info):
4098.2.1 by Robert Collins
Allow self documenting hooks.
57
    """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"
58
59
    This format matches <http://docs.python.org/dist/meta-data.html>
60
    and the typical presentation used in Python output.
61
62
    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.
63
    zero for final releases.
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
64
7045.2.17 by Jelmer Vernooij
Some more.
65
    >>> print(_format_version_tuple((1, 0, 0, 'final', 0)))
4634.50.2 by John Arbash Meinel
Fix the tests.
66
    1.0.0
7045.2.17 by Jelmer Vernooij
Some more.
67
    >>> print(_format_version_tuple((1, 2, 0, 'dev', 0)))
4634.50.2 by John Arbash Meinel
Fix the tests.
68
    1.2.0dev
7045.2.17 by Jelmer Vernooij
Some more.
69
    >>> print(_format_version_tuple((1, 2, 0, 'dev', 1)))
4634.50.2 by John Arbash Meinel
Fix the tests.
70
    1.2.0dev1
7045.2.17 by Jelmer Vernooij
Some more.
71
    >>> print(_format_version_tuple((1, 1, 1, 'candidate', 2)))
3185.1.13 by Martin Pool
Fix doctest syntax
72
    1.1.1rc2
7045.2.17 by Jelmer Vernooij
Some more.
73
    >>> print(_format_version_tuple((2, 1, 0, 'beta', 1)))
5160.1.1 by Martin Pool
Show beta versions as 2.2b1
74
    2.1b1
7045.2.17 by Jelmer Vernooij
Some more.
75
    >>> print(_format_version_tuple((1, 4, 0)))
4634.50.2 by John Arbash Meinel
Fix the tests.
76
    1.4.0
7045.2.17 by Jelmer Vernooij
Some more.
77
    >>> print(_format_version_tuple((1, 4)))
4098.2.1 by Robert Collins
Allow self documenting hooks.
78
    1.4
7045.2.17 by Jelmer Vernooij
Some more.
79
    >>> print(_format_version_tuple((2, 1, 0, 'final', 42)))
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
80
    2.1.0.42
7045.2.17 by Jelmer Vernooij
Some more.
81
    >>> print(_format_version_tuple((1, 4, 0, 'wibble', 0)))
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
82
    1.4.0.wibble.0
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
83
    """
4634.50.1 by John Arbash Meinel
Change 'bzr --version' to always give the major.minor.micro version
84
    if len(version_info) == 2:
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
85
        main_version = '%d.%d' % version_info[:2]
86
    else:
87
        main_version = '%d.%d.%d' % version_info[:3]
3388.1.1 by Martin Pool
_format_version_tuple can take a 3-tuple
88
    if len(version_info) <= 3:
89
        return main_version
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
90
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
91
    release_type = version_info[3]
92
    sub = version_info[4]
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
93
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
94
    if release_type == 'final' and sub == 0:
95
        sub_string = ''
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
96
    elif release_type == 'final':
97
        sub_string = '.' + str(sub)
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
98
    elif release_type == 'dev' and sub == 0:
99
        sub_string = 'dev'
4634.50.2 by John Arbash Meinel
Fix the tests.
100
    elif release_type == 'dev':
101
        sub_string = 'dev' + str(sub)
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
102
    elif release_type in ('alpha', 'beta'):
5160.1.1 by Martin Pool
Show beta versions as 2.2b1
103
        if version_info[2] == 0:
104
            main_version = '%d.%d' % version_info[:2]
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
105
        sub_string = release_type[0] + str(sub)
106
    elif release_type == 'candidate':
107
        sub_string = 'rc' + str(sub)
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
108
    else:
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
109
        return '.'.join(map(str, version_info))
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
110
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
111
    return main_version + sub_string
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
112
4122.1.1 by Martin Pool
Merge back 1.13 and bump version to 1.14dev
113
5327.1.1 by Parth Malwankar
fixed import order of lazy_regex w.r.t _format_version_tuple definition in bzrlib
114
# lazy_regex import must be done after _format_version_tuple definition
5327.1.2 by Parth Malwankar
fixed comment
115
# to avoid "no attribute '_format_version_tuple'" error when using
116
# deprecated_function in the lazy_regex module.
6622.1.1 by Jelmer Vernooij
Rename bzrlib => brzlib, bzr => brz.
117
if getattr(sys, '_brz_lazy_regex', False):
6622.1.31 by Jelmer Vernooij
Fix more tests.
118
    # The 'brz' executable sets _brz_lazy_regex.  We install the lazy regex
5327.1.1 by Parth Malwankar
fixed import order of lazy_regex w.r.t _format_version_tuple definition in bzrlib
119
    # hack as soon as possible so that as much of the standard library can
120
    # benefit, including the 'string' module.
6622.1.1 by Jelmer Vernooij
Rename bzrlib => brzlib, bzr => brz.
121
    del sys._brz_lazy_regex
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
122
    import breezy.lazy_regex
123
    breezy.lazy_regex.install_lazy_compile()
5327.1.1 by Parth Malwankar
fixed import order of lazy_regex w.r.t _format_version_tuple definition in bzrlib
124
125
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
126
__version__ = _format_version_tuple(version_info)
3185.1.12 by Martin Pool
Restore bzrlib.version_string variable
127
version_string = __version__
3185.1.5 by Martin Pool
Use a shorter version number, and check that it makes sense.
128
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
129
130
def _patch_filesystem_default_encoding(new_enc):
131
    """Change the Python process global encoding for filesystem names
132
    
6352.3.5 by Martin Packman
Add to docstring as suggested by vila in review
133
    The effect is to change how open() and other builtin functions handle
134
    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
135
136
    The new encoding string passed to this function must survive until process
137
    termination, otherwise the interpreter may access uninitialized memory.
138
    The use of intern() may defer breakage is but is not enough, the string
139
    object should be secure against module reloading and during teardown.
140
    """
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
141
    is_py3 = sys.version_info > (3,)
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
142
    try:
143
        import ctypes
6437.13.1 by Martin Packman
Catch ValueError from ctypes to detect lack of CPython api for filesystemencoding patch
144
        old_ptr = ctypes.c_void_p.in_dll(ctypes.pythonapi,
145
            "Py_FileSystemDefaultEncoding")
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
146
        if is_py3:
147
            has_enc = ctypes.c_int.in_dll(ctypes.pythonapi,
148
                "Py_HasFileSystemDefaultEncoding")
6631.5.1 by Martin
Make _patch_filesystem_default_encoding Python 3 compatible
149
            as_utf8 = ctypes.PYFUNCTYPE(
150
                ctypes.POINTER(ctypes.c_char), ctypes.py_object)(
151
                    ("PyUnicode_AsUTF8", ctypes.pythonapi))
6437.13.1 by Martin Packman
Catch ValueError from ctypes to detect lack of CPython api for filesystemencoding patch
152
    except (ImportError, ValueError):
153
        return # No ctypes or not CPython implementation, do nothing
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
154
    if is_py3:
155
        new_enc = sys.intern(new_enc)
156
        enc_ptr = as_utf8(new_enc)
157
        has_enc.value = 1
158
    else:
159
        new_enc = intern(new_enc)
160
        enc_ptr = ctypes.c_char_p(new_enc)
6631.5.1 by Martin
Make _patch_filesystem_default_encoding Python 3 compatible
161
    old_ptr.value = ctypes.cast(enc_ptr, ctypes.c_void_p).value
6352.3.4 by Martin Packman
Minor tweaks including normalising _fs_enc value
162
    if sys.getfilesystemencoding() != new_enc:
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
163
        raise RuntimeError("Failed to change the filesystem default encoding")
164
    return new_enc
165
166
6622.1.31 by Jelmer Vernooij
Fix more tests.
167
# When running under the brz script, override bad filesystem default encoding.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
168
# This is not safe to do for all users of breezy, other scripts should instead
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
169
# just ensure a usable locale is set via the $LANG variable on posix systems.
170
_fs_enc = sys.getfilesystemencoding()
6622.1.31 by Jelmer Vernooij
Fix more tests.
171
if getattr(sys, "_brz_default_fs_enc", None) is not None:
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
172
    if (_fs_enc is None or codecs.lookup(_fs_enc).name == "ascii"):
6622.1.31 by Jelmer Vernooij
Fix more tests.
173
        _fs_enc = _patch_filesystem_default_encoding(sys._brz_default_fs_enc)
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
174
if _fs_enc is None:
175
    _fs_enc = "ascii"
6352.3.4 by Martin Packman
Minor tweaks including normalising _fs_enc value
176
else:
177
    _fs_enc = codecs.lookup(_fs_enc).name
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
178
179
6622.1.31 by Jelmer Vernooij
Fix more tests.
180
# brz has various bits of global state that are slowly being eliminated.
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.
181
# 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.
182
# to a library_state.BzrLibraryState object rather than getting new global
183
# variables that need to be hunted down. Accessing the current BzrLibraryState
184
# through this variable is not encouraged: it is better to pass it around as
185
# 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
186
# 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.
187
# global variable.
5222.2.10 by Robert Collins
More NEWS about the bzrlib.initialize contract change, and typographical error fixes for __init__.py.
188
# 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.
189
# it is important to store the reference you get, rather than looking it up
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
190
# repeatedly; that way your code will behave properly in the breezy test suite
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.
191
# and from programs that do use multiple library contexts.
6759.4.2 by Jelmer Vernooij
Use get_global_state>
192
_global_state = None
5017.1.1 by Martin Pool
Add bzrlib.initialize
193
194
5222.2.4 by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state.
195
def initialize(setup_ui=True, stdin=None, stdout=None, stderr=None):
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
196
    """Set up everything needed for normal use of breezy.
5017.1.1 by Martin Pool
Add bzrlib.initialize
197
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
198
    Most applications that embed breezy, including brz itself, should call
6622.1.31 by Jelmer Vernooij
Fix more tests.
199
    this function to initialize various subsystems.
5017.1.1 by Martin Pool
Add bzrlib.initialize
200
201
    More options may be added in future so callers should use named arguments.
202
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
203
    The object returned by this function can be used as a contex manager
204
    through the 'with' statement to automatically shut down when the process
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
205
    is finished with breezy.  However it's not necessary to
206
    separately enter the context as well as starting brz: breezy is ready to
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
207
    go when this function returns.
208
6622.1.31 by Jelmer Vernooij
Fix more tests.
209
    :param setup_ui: If true (default) use a terminal UI; otherwise
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
210
        some other ui_factory must be assigned to `breezy.ui.ui_factory` by
5222.2.4 by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state.
211
        the caller.
5017.1.1 by Martin Pool
Add bzrlib.initialize
212
    :param stdin, stdout, stderr: If provided, use these for terminal IO;
213
        otherwise use the files in `sys`.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
214
    :return: A context manager for the use of breezy. The __exit__
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
215
        should be called by the caller before exiting their process or
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
216
        otherwise stopping use of breezy. Advanced callers can use
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
217
        BzrLibraryState directly.
5017.1.1 by Martin Pool
Add bzrlib.initialize
218
    """
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
219
    from breezy import library_state, trace
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
220
    if setup_ui:
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
221
        import breezy.ui
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
222
        stdin = stdin or sys.stdin
223
        stdout = stdout or sys.stdout
224
        stderr = stderr or sys.stderr
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
225
        ui_factory = breezy.ui.make_ui_for_terminal(stdin, stdout, stderr)
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
226
    else:
227
        ui_factory = None
5327.2.3 by Parth Malwankar
updated te import style for bzrlib.trace
228
    tracer = trace.DefaultConfig()
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
229
    state = library_state.BzrLibraryState(ui=ui_factory, trace=tracer)
230
    # Start automatically in case people don't realize this returns a context.
231
    state._start()
232
    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.
233
234
6759.4.2 by Jelmer Vernooij
Use get_global_state>
235
def get_global_state():
236
    if _global_state is None:
237
        return initialize()
238
    return _global_state
239
240
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.
241
def test_suite():
242
    import tests
243
    return tests.test_suite()