X-Git-Url: https://git.distorted.org.uk/~mdw/stgit/blobdiff_plain/bad9dcfc19eb88f866ebf97692fbde5d7827f76e..8ebae56bad042edf75f7d290469fea166a20d045:/stgit/commands/branch.py diff --git a/stgit/commands/branch.py b/stgit/commands/branch.py index ef44349..d348409 100644 --- a/stgit/commands/branch.py +++ b/stgit/commands/branch.py @@ -23,7 +23,7 @@ from optparse import OptionParser, make_option from stgit.commands.common import * from stgit.utils import * -from stgit import stack, git +from stgit import stack, git, basedir help = 'manage development branches' @@ -124,10 +124,9 @@ def func(parser, options, args): tree_id = None if len(args) == 2: - tree_id = args[1] - - git.create_branch(args[0], tree_id) - stack.Series(args[0]).init() + tree_id = git_id(args[1]) + + stack.Series(args[0]).init(create_at = tree_id) print 'Branch "%s" created.' % args[0] return @@ -173,13 +172,19 @@ def func(parser, options, args): if len(args) != 0: parser.error('incorrect number of arguments') - branches = os.listdir(os.path.join(git.get_base_dir(), 'refs', 'heads')) + branches = [] + basepath = os.path.join(basedir.get(), 'refs', 'heads') + for path, files, dirs in walk_tree(basepath): + branches += [os.path.join(path, f) for f in files] branches.sort() - max_len = max([len(i) for i in branches]) - print 'Available branches:' - for i in branches: - __print_branch(i, max_len) + if branches: + print 'Available branches:' + max_len = max([len(i) for i in branches]) + for i in branches: + __print_branch(i, max_len) + else: + print 'No branches' return elif options.protect: