/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
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)
32
import time
33
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
34
# Keep track of when breezy was first imported, so that we can give rough
35
# 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)
36
_start_time = time.time()
37
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
38
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.
39
import sys
1 by mbp at sourcefrog
import from baz patch-364
40
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.
41
7331.1.1 by Martin
Update breezy.__copyright__ field
42
__copyright__ = (
43
    "Copyright 2005-2012 Canonical Ltd.\n"
7492.1.1 by Jelmer Vernooij
drop use of future.
44
    "Copyright 2017-2020 Breezy developers"
7331.1.1 by Martin
Update breezy.__copyright__ field
45
)
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
7490.1.1 by Jelmer Vernooij
Start on 3.2.
54
version_info = (3, 2, 0, 'dev', 0)
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
    """
130
    try:
131
        import ctypes
7490.56.1 by Jelmer Vernooij
Cope with pypy not having ctypes.pythonapi.
132
        pythonapi = getattr(ctypes, 'pythonapi', None)
133
        if pythonapi is not None:
134
            old_ptr = ctypes.c_void_p.in_dll(pythonapi,
135
                                             "Py_FileSystemDefaultEncoding")
7515.1.1 by Jelmer Vernooij
Merge lp:brz/3.1.
136
            has_enc = ctypes.c_int.in_dll(pythonapi,
137
                                          "Py_HasFileSystemDefaultEncoding")
138
            as_utf8 = ctypes.PYFUNCTYPE(
139
                ctypes.POINTER(ctypes.c_char), ctypes.py_object)(
140
                    ("PyUnicode_AsUTF8", 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
7479.2.1 by Jelmer Vernooij
Drop python2 support.
143
    new_enc = sys.intern(new_enc)
144
    enc_ptr = as_utf8(new_enc)
145
    has_enc.value = 1
6631.5.1 by Martin
Make _patch_filesystem_default_encoding Python 3 compatible
146
    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
147
    if sys.getfilesystemencoding() != new_enc:
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
148
        raise RuntimeError("Failed to change the filesystem default encoding")
149
    return new_enc
150
151
6622.1.31 by Jelmer Vernooij
Fix more tests.
152
# When running under the brz script, override bad filesystem default encoding.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
153
# 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
154
# just ensure a usable locale is set via the $LANG variable on posix systems.
155
_fs_enc = sys.getfilesystemencoding()
6622.1.31 by Jelmer Vernooij
Fix more tests.
156
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
157
    if (_fs_enc is None or codecs.lookup(_fs_enc).name == "ascii"):
6622.1.31 by Jelmer Vernooij
Fix more tests.
158
        _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
159
if _fs_enc is None:
160
    _fs_enc = "ascii"
6352.3.4 by Martin Packman
Minor tweaks including normalising _fs_enc value
161
else:
162
    _fs_enc = codecs.lookup(_fs_enc).name
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
163
164
6622.1.31 by Jelmer Vernooij
Fix more tests.
165
# 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.
166
# 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.
167
# to a library_state.BzrLibraryState object rather than getting new global
168
# variables that need to be hunted down. Accessing the current BzrLibraryState
169
# through this variable is not encouraged: it is better to pass it around as
170
# 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
171
# 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.
172
# global variable.
5222.2.10 by Robert Collins
More NEWS about the bzrlib.initialize contract change, and typographical error fixes for __init__.py.
173
# 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.
174
# it is important to store the reference you get, rather than looking it up
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
175
# 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.
176
# and from programs that do use multiple library contexts.
6759.4.2 by Jelmer Vernooij
Use get_global_state>
177
_global_state = None
5017.1.1 by Martin Pool
Add bzrlib.initialize
178
179
5222.2.4 by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state.
180
def initialize(setup_ui=True, stdin=None, stdout=None, stderr=None):
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
181
    """Set up everything needed for normal use of breezy.
5017.1.1 by Martin Pool
Add bzrlib.initialize
182
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
183
    Most applications that embed breezy, including brz itself, should call
6622.1.31 by Jelmer Vernooij
Fix more tests.
184
    this function to initialize various subsystems.
5017.1.1 by Martin Pool
Add bzrlib.initialize
185
186
    More options may be added in future so callers should use named arguments.
187
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
188
    The object returned by this function can be used as a contex manager
189
    through the 'with' statement to automatically shut down when the process
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
190
    is finished with breezy.  However it's not necessary to
191
    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
192
    go when this function returns.
193
6622.1.31 by Jelmer Vernooij
Fix more tests.
194
    :param setup_ui: If true (default) use a terminal UI; otherwise
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
195
        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.
196
        the caller.
5017.1.1 by Martin Pool
Add bzrlib.initialize
197
    :param stdin, stdout, stderr: If provided, use these for terminal IO;
198
        otherwise use the files in `sys`.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
199
    :return: A context manager for the use of breezy. The __exit__
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
200
        should be called by the caller before exiting their process or
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
201
        otherwise stopping use of breezy. Advanced callers can use
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
202
        BzrLibraryState directly.
5017.1.1 by Martin Pool
Add bzrlib.initialize
203
    """
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
204
    from breezy import library_state, trace
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
205
    if setup_ui:
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
206
        import breezy.ui
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
207
        stdin = stdin or sys.stdin
208
        stdout = stdout or sys.stdout
209
        stderr = stderr or sys.stderr
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
210
        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.
211
    else:
212
        ui_factory = None
5327.2.3 by Parth Malwankar
updated te import style for bzrlib.trace
213
    tracer = trace.DefaultConfig()
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
214
    state = library_state.BzrLibraryState(ui=ui_factory, trace=tracer)
215
    # Start automatically in case people don't realize this returns a context.
216
    state._start()
217
    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.
218
219
6759.4.2 by Jelmer Vernooij
Use get_global_state>
220
def get_global_state():
221
    if _global_state is None:
222
        return initialize()
223
    return _global_state
224
225
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.
226
def test_suite():
227
    import tests
228
    return tests.test_suite()