/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
6437.1.1 by Vincent Ladeuil
Open trunk as 2.6dev1
44
__copyright__ = "Copyright 2005-2012 Canonical Ltd."
1702.1.2 by Martin Pool
Prepare for 0.8 release
45
1704.2.8 by Martin Pool
Bump version to 0.9.0
46
# same format as sys.version_info: "A tuple containing the five components of
1702.1.2 by Martin Pool
Prepare for 0.8 release
47
# the version number: major, minor, micro, releaselevel, and serial. All
48
# values except releaselevel are integers; the release level is 'alpha',
49
# 'beta', 'candidate', or 'final'. The version_info value corresponding to the
1704.2.8 by Martin Pool
Bump version to 0.9.0
50
# Python version 2.0 is (2, 0, 0, 'final', 0)."  Additionally we use a
51
# releaselevel of 'dev' for unreleased under-development code.
52
7240.6.2 by Jelmer Vernooij
Prepare for 3.0beta1.
53
version_info = (3, 0, 0, 'beta', 1)
1704.2.8 by Martin Pool
Bump version to 0.9.0
54
7143.15.2 by Jelmer Vernooij
Run autopep8.
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
3185.1.9 by Martin Pool
Show short version in a more terse form, like "1.2dev"
114
__version__ = _format_version_tuple(version_info)
3185.1.12 by Martin Pool
Restore bzrlib.version_string variable
115
version_string = __version__
3185.1.5 by Martin Pool
Use a shorter version number, and check that it makes sense.
116
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
117
118
def _patch_filesystem_default_encoding(new_enc):
119
    """Change the Python process global encoding for filesystem names
7143.15.2 by Jelmer Vernooij
Run autopep8.
120
6352.3.5 by Martin Packman
Add to docstring as suggested by vila in review
121
    The effect is to change how open() and other builtin functions handle
122
    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
123
124
    The new encoding string passed to this function must survive until process
125
    termination, otherwise the interpreter may access uninitialized memory.
126
    The use of intern() may defer breakage is but is not enough, the string
127
    object should be secure against module reloading and during teardown.
128
    """
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
129
    is_py3 = sys.version_info > (3,)
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
130
    try:
131
        import ctypes
6437.13.1 by Martin Packman
Catch ValueError from ctypes to detect lack of CPython api for filesystemencoding patch
132
        old_ptr = ctypes.c_void_p.in_dll(ctypes.pythonapi,
7143.15.2 by Jelmer Vernooij
Run autopep8.
133
                                         "Py_FileSystemDefaultEncoding")
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
134
        if is_py3:
135
            has_enc = ctypes.c_int.in_dll(ctypes.pythonapi,
7143.15.2 by Jelmer Vernooij
Run autopep8.
136
                                          "Py_HasFileSystemDefaultEncoding")
6631.5.1 by Martin
Make _patch_filesystem_default_encoding Python 3 compatible
137
            as_utf8 = ctypes.PYFUNCTYPE(
138
                ctypes.POINTER(ctypes.c_char), ctypes.py_object)(
139
                    ("PyUnicode_AsUTF8", ctypes.pythonapi))
6437.13.1 by Martin Packman
Catch ValueError from ctypes to detect lack of CPython api for filesystemencoding patch
140
    except (ImportError, ValueError):
7143.15.2 by Jelmer Vernooij
Run autopep8.
141
        return  # No ctypes or not CPython implementation, do nothing
6690.4.3 by Martin
Fix on Python 2.7 from has flag not existing
142
    if is_py3:
143
        new_enc = sys.intern(new_enc)
144
        enc_ptr = as_utf8(new_enc)
145
        has_enc.value = 1
146
    else:
147
        new_enc = intern(new_enc)
148
        enc_ptr = ctypes.c_char_p(new_enc)
6631.5.1 by Martin
Make _patch_filesystem_default_encoding Python 3 compatible
149
    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
150
    if sys.getfilesystemencoding() != new_enc:
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
151
        raise RuntimeError("Failed to change the filesystem default encoding")
152
    return new_enc
153
154
6622.1.31 by Jelmer Vernooij
Fix more tests.
155
# When running under the brz script, override bad filesystem default encoding.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
156
# 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
157
# just ensure a usable locale is set via the $LANG variable on posix systems.
158
_fs_enc = sys.getfilesystemencoding()
6622.1.31 by Jelmer Vernooij
Fix more tests.
159
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
160
    if (_fs_enc is None or codecs.lookup(_fs_enc).name == "ascii"):
6622.1.31 by Jelmer Vernooij
Fix more tests.
161
        _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
162
if _fs_enc is None:
163
    _fs_enc = "ascii"
6352.3.4 by Martin Packman
Minor tweaks including normalising _fs_enc value
164
else:
165
    _fs_enc = codecs.lookup(_fs_enc).name
6352.3.2 by Martin Packman
Add mechanism for changing Py_FileSystemDefaultEncoding with ctypes
166
167
6622.1.31 by Jelmer Vernooij
Fix more tests.
168
# 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.
169
# 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.
170
# to a library_state.BzrLibraryState object rather than getting new global
171
# variables that need to be hunted down. Accessing the current BzrLibraryState
172
# through this variable is not encouraged: it is better to pass it around as
173
# 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
174
# 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.
175
# global variable.
5222.2.10 by Robert Collins
More NEWS about the bzrlib.initialize contract change, and typographical error fixes for __init__.py.
176
# 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.
177
# it is important to store the reference you get, rather than looking it up
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
178
# 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.
179
# and from programs that do use multiple library contexts.
6759.4.2 by Jelmer Vernooij
Use get_global_state>
180
_global_state = None
5017.1.1 by Martin Pool
Add bzrlib.initialize
181
182
5222.2.4 by Robert Collins
Rather than adding another global thing, use a context manager to represent all the global state.
183
def initialize(setup_ui=True, stdin=None, stdout=None, stderr=None):
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
184
    """Set up everything needed for normal use of breezy.
5017.1.1 by Martin Pool
Add bzrlib.initialize
185
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
186
    Most applications that embed breezy, including brz itself, should call
6622.1.31 by Jelmer Vernooij
Fix more tests.
187
    this function to initialize various subsystems.
5017.1.1 by Martin Pool
Add bzrlib.initialize
188
189
    More options may be added in future so callers should use named arguments.
190
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
191
    The object returned by this function can be used as a contex manager
192
    through the 'with' statement to automatically shut down when the process
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
193
    is finished with breezy.  However it's not necessary to
194
    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
195
    go when this function returns.
196
6622.1.31 by Jelmer Vernooij
Fix more tests.
197
    :param setup_ui: If true (default) use a terminal UI; otherwise
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
198
        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.
199
        the caller.
5017.1.1 by Martin Pool
Add bzrlib.initialize
200
    :param stdin, stdout, stderr: If provided, use these for terminal IO;
201
        otherwise use the files in `sys`.
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
202
    :return: A context manager for the use of breezy. The __exit__
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
203
        should be called by the caller before exiting their process or
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
204
        otherwise stopping use of breezy. Advanced callers can use
5222.2.9 by Robert Collins
Write up some doc about bzrlib.initialize.
205
        BzrLibraryState directly.
5017.1.1 by Martin Pool
Add bzrlib.initialize
206
    """
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
207
    from breezy import library_state, trace
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
208
    if setup_ui:
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
209
        import breezy.ui
5320.2.3 by Robert Collins
Restore the original ui_factory when existing BzrLibraryState.
210
        stdin = stdin or sys.stdin
211
        stdout = stdout or sys.stdout
212
        stderr = stderr or sys.stderr
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
213
        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.
214
    else:
215
        ui_factory = None
5327.2.3 by Parth Malwankar
updated te import style for bzrlib.trace
216
    tracer = trace.DefaultConfig()
5728.4.1 by Martin Pool
bzrlib.initialize now does what you'd expect
217
    state = library_state.BzrLibraryState(ui=ui_factory, trace=tracer)
218
    # Start automatically in case people don't realize this returns a context.
219
    state._start()
220
    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.
221
222
6759.4.2 by Jelmer Vernooij
Use get_global_state>
223
def get_global_state():
224
    if _global_state is None:
225
        return initialize()
226
    return _global_state
227
228
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.
229
def test_suite():
230
    import tests
231
    return tests.test_suite()