/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
    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()