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