bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
2052.3.2
by John Arbash Meinel
Change Copyright .. by Canonical to Copyright ... Canonical |
1 |
# Copyright (C) 2005, 2006 Canonical Ltd
|
1887.1.1
by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines, |
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.
|
|
1887.1.1
by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines, |
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.
|
|
1887.1.1
by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines, |
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 |
|
1616.1.5
by Martin Pool
Cleanup and document some check code |
17 |
# TODO: Perhaps have a way to record errors other than by raising exceptions;
|
18 |
# would perhaps be enough to accumulate exception objects in a list without
|
|
19 |
# raising them. If there's more than one exception it'd be good to see them
|
|
20 |
# all.
|
|
21 |
||
4332.3.2
by Robert Collins
Extract repository access in WorkingTree._check to be data driven, adding a new _get_check_refs method to support this. |
22 |
"""Checking of bzr objects.
|
23 |
||
24 |
check_refs is a concept used for optimising check. Objects that depend on other
|
|
25 |
objects (e.g. tree on repository) can list the objects they would be requesting
|
|
26 |
so that when the dependent object is checked, matches can be pulled out and
|
|
27 |
evaluated in-line rather than re-reading the same data many times.
|
|
28 |
check_refs are tuples (kind, value). Currently defined kinds are:
|
|
5891.1.2
by Andrew Bennetts
Fix a bunch of docstring formatting nits, making pydoctor a bit happier. |
29 |
|
4332.3.5
by Robert Collins
Add Branch._get_check_refs. |
30 |
* 'trees', where value is a revid and the looked up objects are revision trees.
|
31 |
* 'lefthand-distance', where value is a revid and the looked up objects are the
|
|
32 |
distance along the lefthand path to NULL for that revid.
|
|
33 |
* 'revision-existence', where value is a revid, and the result is True or False
|
|
34 |
indicating that the revision was found/not found.
|
|
4332.3.2
by Robert Collins
Extract repository access in WorkingTree._check to be data driven, adding a new _get_check_refs method to support this. |
35 |
"""
|
36 |
||
7479.2.1
by Jelmer Vernooij
Drop python2 support. |
37 |
import contextlib |
38 |
||
6624
by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes') |
39 |
from . import ( |
5582.10.8
by Jelmer Vernooij
More fixes. |
40 |
errors, |
41 |
)
|
|
6624
by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes') |
42 |
from .controldir import ControlDir |
43 |
from .trace import note |
|
44 |
from .i18n import gettext |
|
5850.1.3
by Jelmer Vernooij
Add VersionedFileCheck. |
45 |
|
7143.15.2
by Jelmer Vernooij
Run autopep8. |
46 |
|
1347
by Martin Pool
- refactor check code into method object |
47 |
class Check(object): |
1732.2.4
by Martin Pool
Split check into Branch.check and Repository.check |
48 |
"""Check a repository""" |
1449
by Robert Collins
teach check about ghosts |
49 |
|
5850.1.3
by Jelmer Vernooij
Add VersionedFileCheck. |
50 |
def __init__(self, repository, check_repo=True): |
51 |
self.repository = repository |
|
52 |
||
53 |
def report_results(self, verbose): |
|
54 |
raise NotImplementedError(self.report_results) |
|
55 |
||
56 |
||
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
57 |
def scan_branch(branch, needed_refs, exit_stack): |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
58 |
"""Scan a branch for refs. |
59 |
||
60 |
:param branch: The branch to schedule for checking.
|
|
61 |
:param needed_refs: Refs we are accumulating.
|
|
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
62 |
:param exit_stack: The exit stack accumulating.
|
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
63 |
"""
|
6138.3.1
by Jonathan Riddell
use gettext() in more files |
64 |
note(gettext("Checking branch at '%s'.") % (branch.base,)) |
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
65 |
exit_stack.enter_context(branch.lock_read()) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
66 |
branch_refs = branch._get_check_refs() |
67 |
for ref in branch_refs: |
|
68 |
reflist = needed_refs.setdefault(ref, []) |
|
69 |
reflist.append(branch) |
|
70 |
||
71 |
||
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
72 |
def scan_tree(base_tree, tree, needed_refs, exit_stack): |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
73 |
"""Scan a tree for refs. |
74 |
||
75 |
:param base_tree: The original tree check opened, used to detect duplicate
|
|
76 |
tree checks.
|
|
77 |
:param tree: The tree to schedule for checking.
|
|
78 |
:param needed_refs: Refs we are accumulating.
|
|
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
79 |
:param exit_stack: The exit stack accumulating.
|
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
80 |
"""
|
81 |
if base_tree is not None and tree.basedir == base_tree.basedir: |
|
82 |
return
|
|
6138.3.1
by Jonathan Riddell
use gettext() in more files |
83 |
note(gettext("Checking working tree at '%s'.") % (tree.basedir,)) |
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
84 |
exit_stack.enter_context(tree.lock_read()) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
85 |
tree_refs = tree._get_check_refs() |
86 |
for ref in tree_refs: |
|
87 |
reflist = needed_refs.setdefault(ref, []) |
|
88 |
reflist.append(tree) |
|
89 |
||
90 |
||
3015.4.5
by Daniel Watkins
Each option selects only the specific thing to be checked. |
91 |
def check_dwim(path, verbose, do_branch=False, do_repo=False, do_tree=False): |
4332.3.35
by Robert Collins
Fix failing tests. |
92 |
"""Check multiple objects. |
93 |
||
94 |
If errors occur they are accumulated and reported as far as possible, and
|
|
95 |
an exception raised at the end of the process.
|
|
96 |
"""
|
|
3015.4.16
by Daniel Watkins
Added implementation of error reporting when objects are missing. |
97 |
try: |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
98 |
base_tree, branch, repo, relpath = \ |
7143.15.2
by Jelmer Vernooij
Run autopep8. |
99 |
ControlDir.open_containing_tree_branch_or_repository(path) |
3015.4.16
by Daniel Watkins
Added implementation of error reporting when objects are missing. |
100 |
except errors.NotBranchError: |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
101 |
base_tree = branch = repo = None |
3015.3.23
by Daniel Watkins
Abstracted discovery of elements away. |
102 |
|
7479.2.1
by Jelmer Vernooij
Drop python2 support. |
103 |
with contextlib.ExitStack() as exit_stack: |
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
104 |
needed_refs = {} |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
105 |
if base_tree is not None: |
106 |
# If the tree is a lightweight checkout we won't see it in
|
|
107 |
# repo.find_branches - add now.
|
|
108 |
if do_tree: |
|
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
109 |
scan_tree(None, base_tree, needed_refs, exit_stack) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
110 |
branch = base_tree.branch |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
111 |
if branch is not None: |
112 |
# We have a branch
|
|
113 |
if repo is None: |
|
114 |
# The branch is in a shared repository
|
|
115 |
repo = branch.repository |
|
116 |
if repo is not None: |
|
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
117 |
exit_stack.enter_context(repo.lock_read()) |
7358.5.3
by Jelmer Vernooij
Fix tests. |
118 |
branches = list(repo.find_branches(using=True)) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
119 |
saw_tree = False |
120 |
if do_branch or do_tree: |
|
121 |
for branch in branches: |
|
122 |
if do_tree: |
|
123 |
try: |
|
6653.6.1
by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir. |
124 |
tree = branch.controldir.open_workingtree() |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
125 |
saw_tree = True |
126 |
except (errors.NotLocalUrl, errors.NoWorkingTree): |
|
127 |
pass
|
|
128 |
else: |
|
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
129 |
scan_tree(base_tree, tree, needed_refs, exit_stack) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
130 |
if do_branch: |
7356.1.4
by Jelmer Vernooij
use ExitStack in check. |
131 |
scan_branch(branch, needed_refs, exit_stack) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
132 |
if do_branch and not branches: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
133 |
note(gettext("No branch found at specified location.")) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
134 |
if do_tree and base_tree is None and not saw_tree: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
135 |
note(gettext("No working tree found at specified location.")) |
4332.3.11
by Robert Collins
Move tree and back callbacks into the repository check core. |
136 |
if do_repo or do_branch or do_tree: |
137 |
if do_repo: |
|
6138.3.1
by Jonathan Riddell
use gettext() in more files |
138 |
note(gettext("Checking repository at '%s'.") |
5158.6.9
by Martin Pool
Simplify various code to use user_url |
139 |
% (repo.user_url,)) |
4332.3.11
by Robert Collins
Move tree and back callbacks into the repository check core. |
140 |
result = repo.check(None, callback_refs=needed_refs, |
7143.15.2
by Jelmer Vernooij
Run autopep8. |
141 |
check_repo=do_repo) |
3015.4.3
by Daniel Watkins
Implemented CLI options. |
142 |
result.report_results(verbose) |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
143 |
else: |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
144 |
if do_tree: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
145 |
note(gettext("No working tree found at specified location.")) |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
146 |
if do_branch: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
147 |
note(gettext("No branch found at specified location.")) |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
148 |
if do_repo: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
149 |
note(gettext("No repository found at specified location.")) |