23
import bzrlib.bzrdir as bzrdir
24
22
import bzrlib.errors as errors
26
from bzrlib.branch import Branch
28
24
from errors import (AlreadyBranchError, BranchExistsWithoutWorkingTree,
29
NonExistingParent, NonExistingRevision,
30
NonExistingSource, NotBranchError, TargetAlreadyExists)
25
NonExistingParent, NonExistingRevision, NonExistingSource,
26
RevisionValueError, TargetAlreadyExists)
29
from bzrlib.builtins import get_format_type
30
import bzrlib.bzrdir as bzrdir
32
format = get_format_type('default')
34
if not os.path.exists(location):
38
existing_bzrdir = bzrdir.BzrDir.open(location)
39
except errors.NotBranchError:
40
bzrdir.BzrDir.create_branch_convenience(location, format=format)
42
if existing_bzrdir.has_branch():
43
if existing_bzrdir.has_workingtree():
44
raise AlreadyBranchError(location)
46
raise BranchExistsWithoutWorkingTree(location)
48
existing_bzrdir.create_branch()
49
existing_bzrdir.create_workingtree()
32
51
def branch(from_location, to_location, revision=None):
33
""" Create a branch from a local/remote location.
35
:param from_location: the original location of the branch
37
:param to_location: the directory where the branch should be created
39
:param revision: if specified, the given revision will be branched
41
:return: number of revisions branched
52
from bzrlib.branch import Branch
43
53
from bzrlib.transport import get_transport
57
elif len(revision) > 1:
58
raise RevisionValueError('bzr branch --revision takes exactly 1 revision value')
46
61
br_from = Branch.open(from_location)
49
64
raise NonExistingSource(from_location)
52
except errors.NotBranchError:
53
raise NotBranchError(from_location)
55
68
br_from.lock_read()
59
if revision is not None:
60
revision_id = br_from.get_rev_id(revision)
72
if len(revision) == 1 and revision[0] is not None:
73
revision_id = revision[0].in_history(br_from)[1]
75
revision_id = br_from.last_revision()
64
77
to_location = to_location + '/' + os.path.basename(from_location.rstrip("/\\"))
87
100
return branch.revno()
89
def checkout(branch_location, to_location, revision=None, lightweight=False):
90
""" Create a new checkout of an existing branch.
92
:param branch_location: the location of the branch you'd like to checkout
94
:param to_location: the directory where the checkout should be created
96
:param revision: the given revision will be checkout'ed (be aware!)
98
:param lightweight: perform a lightweight checkout (be aware!)
101
source = Branch.open(branch_location)
102
except errors.NotBranchError:
103
raise NotBranchError(branch_location)
105
if revision is not None:
106
revision_id = source.get_rev_id(revision)
110
# if the source and to_location are the same,
111
# and there is no working tree,
112
# then reconstitute a branch
113
if (bzrlib.osutils.abspath(to_location) ==
114
bzrlib.osutils.abspath(branch_location)):
116
source.bzrdir.open_workingtree()
117
except errors.NoWorkingTree:
118
source.bzrdir.create_workingtree()
121
to_location = to_location + '/' + os.path.basename(branch_location.rstrip("/\\"))
124
os.mkdir(to_location)
126
if e.errno == errno.EEXIST:
127
raise TargetAlreadyExists(to_location)
128
if e.errno == errno.ENOENT:
129
raise NonExistingParent(to_location)
133
old_format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
134
bzrlib.bzrdir.BzrDirFormat.set_default_format(bzrdir.BzrDirMetaFormat1())
138
checkout = bzrdir.BzrDirMetaFormat1().initialize(to_location)
139
bzrlib.branch.BranchReferenceFormat().initialize(checkout, source)
141
checkout_branch = bzrlib.bzrdir.BzrDir.create_branch_convenience(
142
to_location, force_new_tree=False)
143
checkout = checkout_branch.bzrdir
144
checkout_branch.bind(source)
145
if revision_id is not None:
146
rh = checkout_branch.revision_history()
147
checkout_branch.set_revision_history(rh[:rh.index(revision_id) + 1])
149
checkout.create_workingtree(revision_id)
151
bzrlib.bzrdir.BzrDirFormat.set_default_format(old_format)
154
""" Initialize a directory.
156
:param location: full path to the directory you want to be versioned
158
from bzrlib.builtins import get_format_type
160
format = get_format_type('default')
162
if not os.path.exists(location):
166
existing_bzrdir = bzrdir.BzrDir.open(location)
167
except errors.NotBranchError:
168
bzrdir.BzrDir.create_branch_convenience(location, format=format)
170
if existing_bzrdir.has_branch():
171
if existing_bzrdir.has_workingtree():
172
raise AlreadyBranchError(location)
174
raise BranchExistsWithoutWorkingTree(location)
176
existing_bzrdir.create_branch()
177
existing_bzrdir.create_workingtree()
103
""" FIXME - will be implemented later """