~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/bundle/apply_bundle.py

  • Committer: Wouter van Heyst
  • Date: 2006-06-07 16:05:27 UTC
  • mto: This revision was merged to the branch mainline in revision 1752.
  • Revision ID: larstiq@larstiq.dyndns.org-20060607160527-2b3649154d0e2e84
more code cleanup

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 Canonical Ltd
2
 
#
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.
7
 
#
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.
12
 
#
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
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
1
"""\
17
2
This contains functionality for installing bundles into repositories
18
3
"""
21
6
from bzrlib.progress import ProgressPhase
22
7
from bzrlib.merge import Merger
23
8
from bzrlib.repository import install_revision
24
 
from bzrlib.trace import note
25
9
 
26
10
 
27
11
def install_bundle(repository, bundle_reader):
28
12
    pb = bzrlib.ui.ui_factory.nested_progress_bar()
29
13
    repository.lock_write()
30
14
    try:
31
 
        real_revisions = bundle_reader.real_revisions
 
15
        real_revisions = bundle_reader.info.real_revisions
32
16
        for i, revision in enumerate(reversed(real_revisions)):
33
17
            pb.update("Install revisions",i, len(real_revisions))
34
18
            if repository.has_revision(revision.revision_id):
42
26
 
43
27
 
44
28
def merge_bundle(reader, tree, check_clean, merge_type, 
45
 
                    reprocess, show_base, change_reporter=None):
 
29
                    reprocess, show_base):
46
30
    """Merge a revision bundle into the current tree."""
47
31
    pb = bzrlib.ui.ui_factory.nested_progress_bar()
48
32
    try:
49
33
        pp = ProgressPhase("Merge phase", 6, pb)
50
34
        pp.next_phase()
51
35
        install_bundle(tree.branch.repository, reader)
52
 
        merger = Merger(tree.branch, this_tree=tree, pb=pb,
53
 
                        change_reporter=change_reporter)
 
36
        merger = Merger(tree.branch, this_tree=tree, pb=pb)
54
37
        merger.pp = pp
55
38
        merger.pp.next_phase()
56
39
        merger.check_basis(check_clean, require_commits=False)
57
 
        merger.other_rev_id = reader.target
58
 
        merger.other_tree = merger.revision_tree(reader.target)
59
 
        merger.other_basis = reader.target
 
40
        merger.other_rev_id = reader.info.target
 
41
        merger.other_tree = merger.revision_tree(reader.info.target)
 
42
        merger.other_basis = reader.info.target
60
43
        merger.pp.next_phase()
61
44
        merger.find_base()
62
45
        if merger.base_rev_id == merger.other_rev_id: