- if new_head == git_id('base'):
- print 'Branch already up-to-date'
- else:
- applied = crt_series.get_applied()
-
- if len(applied) > 0:
- print 'Popping all patches...',
- sys.stdout.flush()
- crt_series.pop_patch(applied[0])
- print 'done'
-
- git.switch(new_head)
-
- 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'
-
- print_crt_patch()
+ if crt_series.get_protected():
+ raise CmdException, 'This branch is protected. Pulls are not permitted'
+
+ check_local_changes()
+ check_conflicts()
+ check_head_top_equal(crt_series)
+
+ if policy not in ['pull', 'fetch-rebase', 'rebase']:
+ raise GitConfigException, 'Unsupported pull-policy "%s"' % policy
+
+ applied = prepare_rebase(crt_series)
+
+ # pull the remote changes
+ if policy == 'pull':
+ out.info('Pulling from "%s"' % repository)
+ git.pull(repository)
+ elif policy == 'fetch-rebase':
+ out.info('Fetching from "%s"' % repository)
+ git.fetch(repository)
+ try:
+ target = git.fetch_head()
+ except git.GitException:
+ out.error('Could not find the remote head to rebase onto - fix branch.%s.merge in .git/config' % crt_series.get_name())
+ out.error('Pushing any patches back...')
+ post_rebase(crt_series, applied, False, False)
+ raise
+
+ rebase(crt_series, target)
+ elif policy == 'rebase':
+ rebase(crt_series, crt_series.get_parent_branch())
+
+ post_rebase(crt_series, applied, options.nopush, options.merged)
+
+ # maybe tidy up
+ if config.get('stgit.keepoptimized') == 'yes':
+ git.repack()
+
+ print_crt_patch(crt_series)