~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/switch.py

  • Committer: Ian Clatworthy
  • Date: 2007-11-16 01:19:16 UTC
  • mto: (3015.1.1 ianc-integration)
  • mto: This revision was merged to the branch mainline in revision 3016.
  • Revision ID: ian.clatworthy@internode.on.net-20071116011916-cqzuyhp8vwsmyhyo
migrate switch command into the core - was in BzrTools

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2007 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
 
 
17
from bzrlib import errors, merge
 
18
from bzrlib.branch import Branch, BranchFormat, BranchReferenceFormat
 
19
from bzrlib.bzrdir import BzrDir
 
20
from bzrlib.trace import note
 
21
 
 
22
 
 
23
def switch(control_dir, to_branch):
 
24
    try:
 
25
        source_repository = control_dir.open_branch().repository
 
26
    except errors.NotBranchError:
 
27
        source_repository = to_branch.repository
 
28
    set_branch_location(control_dir, to_branch)
 
29
    tree = control_dir.open_workingtree()
 
30
    _update(tree, source_repository, to_branch)
 
31
 
 
32
 
 
33
def _update(tree, source_repository, to_branch):
 
34
    tree.lock_tree_write()
 
35
    try:
 
36
        if tree.last_revision() == tree.branch.last_revision():
 
37
            note("Tree is up to date.")
 
38
            return
 
39
        base_tree = source_repository.revision_tree(tree.last_revision())
 
40
        merge.Merge3Merger(tree, tree, base_tree, to_branch.basis_tree())
 
41
        tree.set_last_revision(to_branch.last_revision())
 
42
        note('Updated to revision %d' % tree.branch.revno())
 
43
    finally:
 
44
        tree.unlock()
 
45
 
 
46
 
 
47
def _check_switch_branch_format(control):
 
48
    branch_format = BranchFormat.find_format(control)
 
49
    format_string = branch_format.get_format_string()
 
50
    if not format_string.startswith("Bazaar-NG Branch Reference Format "):
 
51
        raise errors.BzrCommandError(
 
52
            'The switch command can only be used on a lightweight checkout.\n'
 
53
            'Expected branch reference, found %s at %s' % (
 
54
            format_string.strip(), control.root_transport.base))
 
55
    if not format_string == BranchReferenceFormat().get_format_string():
 
56
        raise errors.BzrCommandError(
 
57
            'Unsupported: %r' % (format_string.strip(),))        
 
58
 
 
59
 
 
60
def set_branch_location(control, to_branch):
 
61
    """Set location value of a branch reference.
 
62
 
 
63
    :param control: BzrDir containing the branch reference
 
64
    :param location: value to write to the branch reference location.
 
65
    """
 
66
    _check_switch_branch_format(control)
 
67
    branch_format = BranchFormat.find_format(control)
 
68
    transport = control.get_branch_transport(None)
 
69
    location = transport.put_bytes('location', to_branch.base)