# HG changeset patch # User Phil Cohen # Date 2017-12-07 21:20:47 # Node ID aa660c1203a9e10b679fa6deee2e0e943e97cc95 # Parent 482614b3802a9f30ee12c69e273835825c499901 rebase: do not bail on uncomitted changes if rebasing in-memory Differential Revision: https://phab.mercurial-scm.org/D1233 diff --git a/hgext/rebase.py b/hgext/rebase.py --- a/hgext/rebase.py +++ b/hgext/rebase.py @@ -784,7 +784,8 @@ def rebase(ui, repo, **opts): return retcode else: destmap = _definedestmap(ui, repo, destf, srcf, basef, revf, - destspace=destspace) + destspace=destspace, + inmemory=opts['inmemory']) retcode = rbsrt._preparenewrebase(destmap) if retcode is not None: return retcode @@ -804,7 +805,7 @@ def rebase(ui, repo, **opts): rbsrt._finishrebase() def _definedestmap(ui, repo, destf=None, srcf=None, basef=None, revf=None, - destspace=None): + destspace=None, inmemory=False): """use revisions argument to define destmap {srcrev: destrev}""" if revf is None: revf = [] @@ -818,8 +819,9 @@ def _definedestmap(ui, repo, destf=None, if revf and srcf: raise error.Abort(_('cannot specify both a revision and a source')) - cmdutil.checkunfinished(repo) - cmdutil.bailifchanged(repo) + if not inmemory: + cmdutil.checkunfinished(repo) + cmdutil.bailifchanged(repo) if ui.configbool('commands', 'rebase.requiredest') and not destf: raise error.Abort(_('you must specify a destination'),