/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
7119.1.1 by Vincent Ladeuil
Release 3.0a1.
54
version_info = (3, 0, 0, 'alpha', 1)
1704.2.8 by Martin Pool
Bump version to 0.9.0
55
7143.15.2 by Jelmer Vernooij
Run autopep8.
56
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
57
def _format_version_tuple(version_info):
4098.2.1 by Robert Collins
Allow self documenting hooks.
58
    """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"
59
60
    This format matches <http://docs.python.org/dist/meta-data.html>
61
    and the typical presentation used in Python output.
62
63
    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.
64
    zero for final releases.
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
65
7045.2.17 by Jelmer Vernooij
Some more.
66
    >>> print(_format_version_tuple((1, 0, 0, 'final', 0)))
4634.50.2 by John Arbash Meinel
Fix the tests.
67
    1.0.0
7045.2.17 by Jelmer Vernooij
Some more.
68
    >>> print(_format_version_tuple((1, 2, 0, 'dev', 0)))
4634.50.2 by John Arbash Meinel
Fix the tests.
69
    1.2.0dev
7045.2.17 by Jelmer Vernooij
Some more.
70
    >>> print(_format_version_tuple((1, 2, 0, 'dev', 1)))
4634.50.2 by John Arbash Meinel
Fix the tests.
71
    1.2.0dev1
7045.2.17 by Jelmer Vernooij
Some more.
72
    >>> print(_format_version_tuple((1, 1, 1, 'candidate', 2)))
3185.1.13 by Martin Pool
Fix doctest syntax
73
    1.1.1rc2
7045.2.17 by Jelmer Vernooij
Some more.
74
    >>> print(_format_version_tuple((2, 1, 0, 'beta', 1)))
5160.1.1 by Martin Pool
Show beta versions as 2.2b1
75
    2.1b1
7045.2.17 by Jelmer Vernooij
Some more.
76
    >>> print(_format_version_tuple((1, 4, 0)))
4634.50.2 by John Arbash Meinel
Fix the tests.
77
    1.4.0
7045.2.17 by Jelmer Vernooij
Some more.
78
    >>> print(_format_version_tuple((1, 4)))
4098.2.1 by Robert Collins
Allow self documenting hooks.
79
    1.4
7045.2.17 by Jelmer Vernooij
Some more.
80
    >>> print(_format_version_tuple((2, 1, 0, 'final', 42)))
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
81
    2.1.0.42
7045.2.17 by Jelmer Vernooij
Some more.
82
    >>> print(_format_version_tuple((1, 4, 0, 'wibble', 0)))
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
83
    1.4.0.wibble.0
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
84
    """
4634.50.1 by John Arbash Meinel
Change 'bzr --version' to always give the major.minor.micro version
85
    if len(version_info) == 2:
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
86
        main_version = '%d.%d' % version_info[:2]
87
    else:
88
        main_version = '%d.%d.%d' % version_info[:3]
3388.1.1 by Martin Pool
_format_version_tuple can take a 3-tuple
89
    if len(version_info) <= 3:
90
        return main_version
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
91
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
92
    release_type = version_info[3]
93
    sub = version_info[4]
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
94
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
95
    if release_type == 'final' and sub == 0:
96
        sub_string = ''
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
97
    elif release_type == 'final':
98
        sub_string = '.' + str(sub)
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
99
    elif release_type == 'dev' and sub == 0:
100
        sub_string = 'dev'
4634.50.2 by John Arbash Meinel
Fix the tests.
101
    elif release_type == 'dev':
102
        sub_string = 'dev' + str(sub)
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
103
    elif release_type in ('alpha', 'beta'):
5160.1.1 by Martin Pool
Show beta versions as 2.2b1
104
        if version_info[2] == 0:
105
            main_version = '%d.%d' % version_info[:2]
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
106
        sub_string = release_type[0] + str(sub)
107
    elif release_type == 'candidate':
108
        sub_string = 'rc' + str(sub)
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
109
    else:
5851.2.1 by Martin Pool
_format_version_tuple tolerates more different tuples
110
        return '.'.join(map(str, version_info))
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
111
3849.2.1 by John Arbash Meinel
Cleanup variable names inside a function.
112
    return main_version + sub_string
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
113
4122.1.1 by Martin Pool
Merge back 1.13 and bump version to 1.14dev
114
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
115
__version__ = _format_version_tuple(version_info)
3185.1.12 by Martin Pool
Restore bzrlib.version_string variable
116
version_string = __version__
3185.1.5 by Martin Pool
Use a shorter version number, and check that it makes sense.
117
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
118
119
def _patch_filesystem_default_encoding(new_enc):
120
    """Change the Python process global encoding for filesystem names
7143.15.2 by Jelmer Vernooij
Run autopep8.
121
6352.3.5 by Martin Packman
Add to docstring as suggested by vila in review
122
    The effect is to change how open() and other builtin functions handle
123
    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
124
125
    The new encoding string passed to this function must survive until process
126
    termination, otherwise the interpreter may access uninitialized memory.
127
    The use of intern() may defer breakage is but is not enough, the string
128
    object should be secure against module reloading and during teardown.
129
    """
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
130
    is_py3 = sys.version_info > (3,)
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
131
    try:
132
        import ctypes
6437.13.1 by Martin Packman
Catch ValueError from ctypes to detect lack of CPython api for filesystemencoding patch
133
        old_ptr = ctypes.c_void_p.in_dll(ctypes.pythonapi,
7143.15.2 by Jelmer Vernooij
Run autopep8.
134
                                         "Py_FileSystemDefaultEncoding")
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
135
        if is_py3:
136
            has_enc = ctypes.c_int.in_dll(ctypes.pythonapi,
7143.15.2 by Jelmer Vernooij
Run autopep8.
137
                                          "Py_HasFileSystemDefaultEncoding")
6631.5.1 by Martin
Make _patch_filesystem_default_encoding Python 3 compatible
138
            as_utf8 = ctypes.PYFUNCTYPE(
139
                ctypes.POINTER(ctypes.c_char), ctypes.py_object)(
140
                    ("PyUnicode_AsUTF8", ctypes.pythonapi))
6437.13.1 by Martin Packman
Catch ValueError from ctypes to detect lack of CPython api for filesystemencoding patch
141
    except (ImportError, ValueError):
7143.15.2 by Jelmer Vernooij
Run autopep8.
142
        return  # No ctypes or not CPython implementation, do nothing
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
143
    if is_py3:
144
        new_enc = sys.intern(new_enc)
145
        enc_ptr = as_utf8(new_enc)
146
        has_enc.value = 1
147
    else:
148
        new_enc = intern(new_enc)
149
        enc_ptr = ctypes.c_char_p(new_enc)
6631.5.1 by Martin
Make _patch_filesystem_default_encoding Python 3 compatible
150
    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
151
    if sys.getfilesystemencoding() != new_enc:
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
152
        raise RuntimeError("Failed to change the filesystem default encoding")
153
    return new_enc
154
155
6622.1.31 by Jelmer Vernooij
Fix more tests.
156
# When running under the brz script, override bad filesystem default encoding.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
157
# 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
158
# just ensure a usable locale is set via the $LANG variable on posix systems.
159
_fs_enc = sys.getfilesystemencoding()
6622.1.31 by Jelmer Vernooij
Fix more tests.
160
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
161
    if (_fs_enc is None or codecs.lookup(_fs_enc).name == "ascii"):
6622.1.31 by Jelmer Vernooij
Fix more tests.
162
        _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
163
if _fs_enc is None:
164
    _fs_enc = "ascii"
6352.3.4 by Martin Packman
Minor tweaks including normalising _fs_enc value
165
else:
166
    _fs_enc = codecs.lookup(_fs_enc).name
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
167
168
6622.1.31 by Jelmer Vernooij
Fix more tests.
169
# 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.
170
# 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.
171
# to a library_state.BzrLibraryState object rather than getting new global
172
# variables that need to be hunted down. Accessing the current BzrLibraryState
173
# through this variable is not encouraged: it is better to pass it around as
174
# 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
175
# 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.
176
# global variable.
5222.2.10 by Robert Collins
More NEWS about the bzrlib.initialize contract change, and typographical error fixes for __init__.py.
177
# 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.
178
# it is important to store the reference you get, rather than looking it up
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
179
# 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.
180
# and from programs that do use multiple library contexts.
6759.4.2 by Jelmer Vernooij
Use get_global_state>
181
_global_state = None
5017.1.1 by Martin Pool
Add bzrlib.initialize
182
183
5222.2.4 by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state.
184
def initialize(setup_ui=True, stdin=None, stdout=None, stderr=None):
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
185
    """Set up everything needed for normal use of breezy.
5017.1.1 by Martin Pool
Add bzrlib.initialize
186
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
187
    Most applications that embed breezy, including brz itself, should call
6622.1.31 by Jelmer Vernooij
Fix more tests.
188
    this function to initialize various subsystems.
5017.1.1 by Martin Pool
Add bzrlib.initialize
189
190
    More options may be added in future so callers should use named arguments.
191
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
192
    The object returned by this function can be used as a contex manager
193
    through the 'with' statement to automatically shut down when the process
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
194
    is finished with breezy.  However it's not necessary to
195
    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
196
    go when this function returns.
197
6622.1.31 by Jelmer Vernooij
Fix more tests.
198
    :param setup_ui: If true (default) use a terminal UI; otherwise
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
199
        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.
200
        the caller.
5017.1.1 by Martin Pool
Add bzrlib.initialize
201
    :param stdin, stdout, stderr: If provided, use these for terminal IO;
202
        otherwise use the files in `sys`.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
203
    :return: A context manager for the use of breezy. The __exit__
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
204
        should be called by the caller before exiting their process or
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
205
        otherwise stopping use of breezy. Advanced callers can use
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
206
        BzrLibraryState directly.
5017.1.1 by Martin Pool
Add bzrlib.initialize
207
    """
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
208
    from breezy import library_state, trace
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
209
    if setup_ui:
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
210
        import breezy.ui
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
211
        stdin = stdin or sys.stdin
212
        stdout = stdout or sys.stdout
213
        stderr = stderr or sys.stderr
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
214
        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.
215
    else:
216
        ui_factory = None
5327.2.3 by Parth Malwankar
updated te import style for bzrlib.trace
217
    tracer = trace.DefaultConfig()
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
218
    state = library_state.BzrLibraryState(ui=ui_factory, trace=tracer)
219
    # Start automatically in case people don't realize this returns a context.
220
    state._start()
221
    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.
222
223
6759.4.2 by Jelmer Vernooij
Use get_global_state>
224
def get_global_state():
225
    if _global_state is None:
226
        return initialize()
227
    return _global_state
228
229
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.
230
def test_suite():
231
    import tests
232
    return tests.test_suite()