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 |
||
6379.6.7
by Jelmer Vernooij
Move importing from future until after doc string, otherwise the doc string will disappear. |
37 |
from __future__ import absolute_import |
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 |
ui, |
|
42 |
)
|
|
6624
by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes') |
43 |
from .branch import Branch |
44 |
from .controldir import ControlDir |
|
45 |
from .revision import NULL_REVISION |
|
6656.1.1
by Martin
Apply 2to3 dict fixer and clean up resulting mess using view helpers |
46 |
from .sixish import ( |
47 |
viewitems, |
|
48 |
)
|
|
6624
by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes') |
49 |
from .trace import note |
50 |
from .workingtree import WorkingTree |
|
51 |
from .i18n import gettext |
|
5850.1.3
by Jelmer Vernooij
Add VersionedFileCheck. |
52 |
|
1347
by Martin Pool
- refactor check code into method object |
53 |
class Check(object): |
1732.2.4
by Martin Pool
Split check into Branch.check and Repository.check |
54 |
"""Check a repository""" |
1449
by Robert Collins
teach check about ghosts |
55 |
|
5850.1.3
by Jelmer Vernooij
Add VersionedFileCheck. |
56 |
def __init__(self, repository, check_repo=True): |
57 |
self.repository = repository |
|
58 |
||
59 |
def report_results(self, verbose): |
|
60 |
raise NotImplementedError(self.report_results) |
|
61 |
||
62 |
||
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
63 |
def scan_branch(branch, needed_refs, to_unlock): |
64 |
"""Scan a branch for refs. |
|
65 |
||
66 |
:param branch: The branch to schedule for checking.
|
|
67 |
:param needed_refs: Refs we are accumulating.
|
|
68 |
:param to_unlock: The unlock list accumulating.
|
|
69 |
"""
|
|
6138.3.1
by Jonathan Riddell
use gettext() in more files |
70 |
note(gettext("Checking branch at '%s'.") % (branch.base,)) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
71 |
branch.lock_read() |
72 |
to_unlock.append(branch) |
|
73 |
branch_refs = branch._get_check_refs() |
|
74 |
for ref in branch_refs: |
|
75 |
reflist = needed_refs.setdefault(ref, []) |
|
76 |
reflist.append(branch) |
|
77 |
||
78 |
||
79 |
def scan_tree(base_tree, tree, needed_refs, to_unlock): |
|
80 |
"""Scan a tree for refs. |
|
81 |
||
82 |
:param base_tree: The original tree check opened, used to detect duplicate
|
|
83 |
tree checks.
|
|
84 |
:param tree: The tree to schedule for checking.
|
|
85 |
:param needed_refs: Refs we are accumulating.
|
|
86 |
:param to_unlock: The unlock list accumulating.
|
|
87 |
"""
|
|
88 |
if base_tree is not None and tree.basedir == base_tree.basedir: |
|
89 |
return
|
|
6138.3.1
by Jonathan Riddell
use gettext() in more files |
90 |
note(gettext("Checking working tree at '%s'.") % (tree.basedir,)) |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
91 |
tree.lock_read() |
92 |
to_unlock.append(tree) |
|
93 |
tree_refs = tree._get_check_refs() |
|
94 |
for ref in tree_refs: |
|
95 |
reflist = needed_refs.setdefault(ref, []) |
|
96 |
reflist.append(tree) |
|
97 |
||
98 |
||
3015.4.5
by Daniel Watkins
Each option selects only the specific thing to be checked. |
99 |
def check_dwim(path, verbose, do_branch=False, do_repo=False, do_tree=False): |
4332.3.35
by Robert Collins
Fix failing tests. |
100 |
"""Check multiple objects. |
101 |
||
102 |
If errors occur they are accumulated and reported as far as possible, and
|
|
103 |
an exception raised at the end of the process.
|
|
104 |
"""
|
|
3015.4.16
by Daniel Watkins
Added implementation of error reporting when objects are missing. |
105 |
try: |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
106 |
base_tree, branch, repo, relpath = \ |
6207.3.1
by jelmer at samba
use classmethods. |
107 |
ControlDir.open_containing_tree_branch_or_repository(path) |
3015.4.16
by Daniel Watkins
Added implementation of error reporting when objects are missing. |
108 |
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. |
109 |
base_tree = branch = repo = None |
3015.3.23
by Daniel Watkins
Abstracted discovery of elements away. |
110 |
|
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
111 |
to_unlock = [] |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
112 |
needed_refs= {} |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
113 |
try: |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
114 |
if base_tree is not None: |
115 |
# If the tree is a lightweight checkout we won't see it in
|
|
116 |
# repo.find_branches - add now.
|
|
117 |
if do_tree: |
|
118 |
scan_tree(None, base_tree, needed_refs, to_unlock) |
|
119 |
branch = base_tree.branch |
|
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
120 |
if branch is not None: |
121 |
# We have a branch
|
|
122 |
if repo is None: |
|
123 |
# The branch is in a shared repository
|
|
124 |
repo = branch.repository |
|
125 |
if repo is not None: |
|
126 |
repo.lock_read() |
|
127 |
to_unlock.append(repo) |
|
128 |
branches = 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. |
129 |
saw_tree = False |
130 |
if do_branch or do_tree: |
|
131 |
for branch in branches: |
|
132 |
if do_tree: |
|
133 |
try: |
|
6653.6.1
by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir. |
134 |
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. |
135 |
saw_tree = True |
136 |
except (errors.NotLocalUrl, errors.NoWorkingTree): |
|
137 |
pass
|
|
138 |
else: |
|
139 |
scan_tree(base_tree, tree, needed_refs, to_unlock) |
|
140 |
if do_branch: |
|
141 |
scan_branch(branch, needed_refs, to_unlock) |
|
142 |
if do_branch and not branches: |
|
6138.3.1
by Jonathan Riddell
use gettext() in more files |
143 |
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. |
144 |
if do_tree and base_tree is None and not saw_tree: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
145 |
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. |
146 |
if do_repo or do_branch or do_tree: |
147 |
if do_repo: |
|
6138.3.1
by Jonathan Riddell
use gettext() in more files |
148 |
note(gettext("Checking repository at '%s'.") |
5158.6.9
by Martin Pool
Simplify various code to use user_url |
149 |
% (repo.user_url,)) |
4332.3.11
by Robert Collins
Move tree and back callbacks into the repository check core. |
150 |
result = repo.check(None, callback_refs=needed_refs, |
151 |
check_repo=do_repo) |
|
3015.4.3
by Daniel Watkins
Implemented CLI options. |
152 |
result.report_results(verbose) |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
153 |
else: |
4332.3.10
by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them. |
154 |
if do_tree: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
155 |
note(gettext("No working tree found at specified location.")) |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
156 |
if do_branch: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
157 |
note(gettext("No branch found at specified location.")) |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
158 |
if do_repo: |
6138.3.1
by Jonathan Riddell
use gettext() in more files |
159 |
note(gettext("No repository found at specified location.")) |
4332.3.9
by Robert Collins
Less lock thrashing in check.py. |
160 |
finally: |
161 |
for thing in to_unlock: |
|
162 |
thing.unlock() |