~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/bundle/apply_bundle.py

  • Committer: Alexander Belchenko
  • Date: 2006-07-30 16:43:12 UTC
  • mto: (1711.2.111 jam-integration)
  • mto: This revision was merged to the branch mainline in revision 1906.
  • Revision ID: bialix@ukr.net-20060730164312-b025fd3ff0cee59e
rename  gpl.txt => COPYING.txt

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006, 2007, 2009, 2010 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
1
"""\
17
2
This contains functionality for installing bundles into repositories
18
3
"""
25
10
 
26
11
 
27
12
def install_bundle(repository, bundle_reader):
28
 
    custom_install = getattr(bundle_reader, 'install', None)
29
 
    if custom_install is not None:
30
 
        return custom_install(repository)
31
13
    pb = bzrlib.ui.ui_factory.nested_progress_bar()
32
14
    repository.lock_write()
33
15
    try:
44
26
        pb.finished()
45
27
 
46
28
 
47
 
def merge_bundle(reader, tree, check_clean, merge_type,
48
 
                    reprocess, show_base, change_reporter=None):
 
29
def merge_bundle(reader, tree, check_clean, merge_type, 
 
30
                    reprocess, show_base):
49
31
    """Merge a revision bundle into the current tree."""
50
32
    pb = bzrlib.ui.ui_factory.nested_progress_bar()
51
33
    try:
52
34
        pp = ProgressPhase("Merge phase", 6, pb)
53
35
        pp.next_phase()
54
36
        install_bundle(tree.branch.repository, reader)
55
 
        merger = Merger(tree.branch, this_tree=tree,
56
 
                        change_reporter=change_reporter)
 
37
        merger = Merger(tree.branch, this_tree=tree, pb=pb)
57
38
        merger.pp = pp
58
39
        merger.pp.next_phase()
59
 
        if check_clean and tree.has_changes():
60
 
            raise errors.UncommittedChanges(self)
 
40
        merger.check_basis(check_clean, require_commits=False)
61
41
        merger.other_rev_id = reader.target
62
42
        merger.other_tree = merger.revision_tree(reader.target)
63
43
        merger.other_basis = reader.target