~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/sign_my_commits.py

  • Committer: Martin Pool
  • Date: 2006-05-26 04:11:58 UTC
  • mto: This revision was merged to the branch mainline in revision 1761.
  • Revision ID: mbp@sourcefrog.net-20060526041158-921b3be3b2a5a00d
sign-my-commits just signs revisions in the branch's ancestry.

It no longer traverses the whole repository; and avoids calling
repo.all_revision_ids.

Show diffs side-by-side

added added

removed removed

Lines of Context:
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
 
16
17
"""Command which looks for unsigned commits by the current user, and signs them.
17
18
"""
18
19
 
31
32
 
32
33
    This does not sign commits that already have signatures.
33
34
    """
 
35
    # Note that this signs everything on the branch's ancestry
 
36
    # (both mainline and merged), but not other revisions that may be in the
 
37
    # repository
34
38
 
35
39
    takes_options = [Option('dry-run'
36
40
                            , help='Don\'t actually sign anything, just print'
40
44
 
41
45
    def run(self, location=None, committer=None, dry_run=False):
42
46
        if location is None:
43
 
            from bzrlib.workingtree import WorkingTree
44
 
            # Open the containing directory
45
 
            wt = WorkingTree.open_containing('.')[0]
46
 
            b = wt.branch
 
47
            bzrdir = bzrlib.bzrdir.BzrDir.open_containing('.')[0]
47
48
        else:
48
49
            # Passed in locations should be exact
49
 
            from bzrlib.branch import Branch
50
 
            b = Branch.open(location)
51
 
        repo = getattr(b, 'repository', b)
52
 
 
53
 
        config = bzrlib.config.BranchConfig(b)
 
50
            bzrdir = bzrlib.bzrdir.BzrDir.open(location)
 
51
        branch = bzrdir.open_branch()
 
52
        repo = branch.repository
 
53
        config = bzrlib.config.BranchConfig(branch)
54
54
 
55
55
        if committer is None:
56
56
            committer = config.username()
58
58
        gpg_strategy = bzrlib.gpg.GPGStrategy(config)
59
59
 
60
60
        count = 0
61
 
        # return in partial topological order for the sake of reproducibility
62
 
        for rev_id in repo.all_revision_ids():
 
61
        for rev_id in repo.get_ancestry(branch.last_revision())[1:]:
63
62
            if repo.has_signature_for_revision_id(rev_id):
64
63
                continue
65
64