X-Git-Url: https://git.distorted.org.uk/~mdw/stgit/blobdiff_plain/0b4b9499a53813957d23adaa0e97e1cc3a3a6900..HEAD:/stgit/commands/pull.py diff --git a/stgit/commands/pull.py b/stgit/commands/pull.py index 69b8d88..b63ef7a 100644 --- a/stgit/commands/pull.py +++ b/stgit/commands/pull.py @@ -24,35 +24,35 @@ from stgit import stack, git help = 'pull the changes from the remote repository' -usage = """%prog [options] [] [] +usage = """%prog [options] [] -Pull the latest changes from the given repository (defaulting to -'origin'). This command works by popping all the patches from the -stack, pulling the changes in the parent repository, setting the base -of the stack to the latest parent HEAD and pusing the patches back -(unless '--nopush' is specified). The 'push' operation can fail if -there are conflicts. They need to be resolved and the patch pushed -again. +Pull the latest changes from the given remote repository (defaulting +to branch..remote, or 'origin' if not set). This command works +by popping all the patches from the stack, pulling the changes in the +parent repository, setting the base of the stack to the latest parent +HEAD and pushing the patches back (unless '--nopush' is specified). +The 'push' operation can fail if there are conflicts. They need to be +resolved and the patch pushed again. -Check the 'git pull' documentation for the and -format.""" +Check the 'git fetch' documentation for the format.""" options = [make_option('-n', '--nopush', help = 'do not push the patches back after pulling', + action = 'store_true'), + make_option('-m', '--merged', + help = 'check for patches merged upstream', action = 'store_true')] def func(parser, options, args): """Pull the changes from a remote repository """ - if len(args) > 2: + if len(args) > 1: parser.error('incorrect number of arguments') - repository = 'origin' - refspec = None if len(args) >= 1: repository = args[0] - if len(args) == 2: - refspec = args[1] + else: + repository = crt_series.get_parent_remote() if crt_series.get_protected(): raise CmdException, 'This branch is protected. Pulls are not permitted' @@ -64,26 +64,25 @@ def func(parser, options, args): # pop all patches applied = crt_series.get_applied() if len(applied) > 0: - print 'Popping all patches...', + print 'Popping all applied patches...', sys.stdout.flush() crt_series.pop_patch(applied[0]) print 'done' # pull the remote changes print 'Pulling from "%s"...' % repository - git.pull(repository, refspec) + git.fetch(repository) + if (config.get('stgit.pull-does-rebase') == 'yes'): + print 'rebasing to "%s"...' % git.fetch_head() + git.reset(tree_id = git.fetch_head()) print 'done' # push the patches back - if options.nopush: - applied = [] - for p in applied: - print 'Pushing patch "%s"...' % p, - sys.stdout.flush() - crt_series.push_patch(p) - if crt_series.empty_patch(p): - print 'done (empty patch)' - else: - print 'done' + if not options.nopush: + push_patches(applied, options.merged) + + # maybe tidy up + if config.get('stgit.keepoptimized') == 'yes': + git.repack() print_crt_patch()