/brz/remove-bazaar

To get this branch, use:
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
    )
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
1347 by Martin Pool
- refactor check code into method object
46
class Check(object):
1732.2.4 by Martin Pool
Split check into Branch.check and Repository.check
47
    """Check a repository"""
1449 by Robert Collins
teach check about ghosts
48
5850.1.3 by Jelmer Vernooij
Add VersionedFileCheck.
49
    def __init__(self, repository, check_repo=True):
50
        self.repository = repository
51
52
    def report_results(self, verbose):
53
        raise NotImplementedError(self.report_results)
54
55
4332.3.10 by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them.
56
def scan_branch(branch, needed_refs, to_unlock):
57
    """Scan a branch for refs.
58
59
    :param branch:  The branch to schedule for checking.
60
    :param needed_refs: Refs we are accumulating.
61
    :param to_unlock: The unlock list accumulating.
62
    """
6138.3.1 by Jonathan Riddell
use gettext() in more files
63
    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.
64
    branch.lock_read()
65
    to_unlock.append(branch)
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
72
def scan_tree(base_tree, tree, needed_refs, to_unlock):
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.
79
    :param to_unlock: The unlock list accumulating.
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,))
4332.3.10 by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them.
84
    tree.lock_read()
85
    to_unlock.append(tree)
86
    tree_refs = tree._get_check_refs()
87
    for ref in tree_refs:
88
        reflist = needed_refs.setdefault(ref, [])
89
        reflist.append(tree)
90
91
3015.4.5 by Daniel Watkins
Each option selects only the specific thing to be checked.
92
def check_dwim(path, verbose, do_branch=False, do_repo=False, do_tree=False):
4332.3.35 by Robert Collins
Fix failing tests.
93
    """Check multiple objects.
94
95
    If errors occur they are accumulated and reported as far as possible, and
96
    an exception raised at the end of the process.
97
    """
3015.4.16 by Daniel Watkins
Added implementation of error reporting when objects are missing.
98
    try:
4332.3.10 by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them.
99
        base_tree, branch, repo, relpath = \
6207.3.1 by jelmer at samba
use classmethods.
100
                        ControlDir.open_containing_tree_branch_or_repository(path)
3015.4.16 by Daniel Watkins
Added implementation of error reporting when objects are missing.
101
    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.
102
        base_tree = branch = repo = None
3015.3.23 by Daniel Watkins
Abstracted discovery of elements away.
103
4332.3.9 by Robert Collins
Less lock thrashing in check.py.
104
    to_unlock = []
4332.3.10 by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them.
105
    needed_refs= {}
4332.3.9 by Robert Collins
Less lock thrashing in check.py.
106
    try:
4332.3.10 by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them.
107
        if base_tree is not None:
108
            # If the tree is a lightweight checkout we won't see it in
109
            # repo.find_branches - add now.
110
            if do_tree:
111
                scan_tree(None, base_tree, needed_refs, to_unlock)
112
            branch = base_tree.branch
4332.3.9 by Robert Collins
Less lock thrashing in check.py.
113
        if branch is not None:
114
            # We have a branch
115
            if repo is None:
116
                # The branch is in a shared repository
117
                repo = branch.repository
118
        if repo is not None:
119
            repo.lock_read()
120
            to_unlock.append(repo)
121
            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.
122
            saw_tree = False
123
            if do_branch or do_tree:
124
                for branch in branches:
125
                    if do_tree:
126
                        try:
6653.6.1 by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir.
127
                            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.
128
                            saw_tree = True
129
                        except (errors.NotLocalUrl, errors.NoWorkingTree):
130
                            pass
131
                        else:
132
                            scan_tree(base_tree, tree, needed_refs, to_unlock)
133
                    if do_branch:
134
                        scan_branch(branch, needed_refs, to_unlock)
135
            if do_branch and not branches:
6138.3.1 by Jonathan Riddell
use gettext() in more files
136
                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.
137
            if do_tree and base_tree is None and not saw_tree:
6138.3.1 by Jonathan Riddell
use gettext() in more files
138
                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.
139
            if do_repo or do_branch or do_tree:
140
                if do_repo:
6138.3.1 by Jonathan Riddell
use gettext() in more files
141
                    note(gettext("Checking repository at '%s'.")
5158.6.9 by Martin Pool
Simplify various code to use user_url
142
                         % (repo.user_url,))
4332.3.11 by Robert Collins
Move tree and back callbacks into the repository check core.
143
                result = repo.check(None, callback_refs=needed_refs,
144
                    check_repo=do_repo)
3015.4.3 by Daniel Watkins
Implemented CLI options.
145
                result.report_results(verbose)
4332.3.9 by Robert Collins
Less lock thrashing in check.py.
146
        else:
4332.3.10 by Robert Collins
Invert control of check so that trees and branches are checked by calling back into them.
147
            if do_tree:
6138.3.1 by Jonathan Riddell
use gettext() in more files
148
                note(gettext("No working tree found at specified location."))
4332.3.9 by Robert Collins
Less lock thrashing in check.py.
149
            if do_branch:
6138.3.1 by Jonathan Riddell
use gettext() in more files
150
                note(gettext("No branch found at specified location."))
4332.3.9 by Robert Collins
Less lock thrashing in check.py.
151
            if do_repo:
6138.3.1 by Jonathan Riddell
use gettext() in more files
152
                note(gettext("No repository found at specified location."))
4332.3.9 by Robert Collins
Less lock thrashing in check.py.
153
    finally:
154
        for thing in to_unlock:
155
            thing.unlock()