A subsequent patch will remove the i3merge and i2merge customisation from the classic infrastructure and config files. The main difference with the classic implementation is that mergetool is no invoked from the Transaction.push_patch() function rather than directly from IndexAndWorktree.merge(). Signed-off-by: Catalin Marinas <catalin.marinas@xxxxxxxxx> --- I'm still not entirely sure where the check for stgit.autoimerge should be done. In the classic infrastructure, it is done in the merge function. With this patch, it is done in Transaction.push(). Should we push this even further to stgit.commands.push? My opinion is not since by having it in Transaction we get the advantage not listing the conflicts if the mergetool succeeds and we don't need to abort the transaction. stgit/lib/git.py | 6 ++++++ stgit/lib/transaction.py | 18 +++++++++++++++--- 2 files changed, 21 insertions(+), 3 deletions(-) diff --git a/stgit/lib/git.py b/stgit/lib/git.py index 07079b8..04c1fa5 100644 --- a/stgit/lib/git.py +++ b/stgit/lib/git.py @@ -842,6 +842,12 @@ class IndexAndWorktree(RunWithEnvCwd): raise MergeConflictException(conflicts) except run.RunException, e: raise MergeException('Index/worktree dirty') + def mergetool(self, files = []): + """Invoke 'git mergetool' on the current IndexAndWorktree to resolve + any outstanding conflicts.""" + err = os.system('git mergetool %s' % ' '.join(files)) + if err: + raise MergeException('"git mergetool" failed, exit code: %d' % err) def changed_files(self, tree, pathlimits = []): """Return the set of files in the worktree that have changed with respect to C{tree}. The listing is optionally restricted to diff --git a/stgit/lib/transaction.py b/stgit/lib/transaction.py index 5a81f9d..c1c9125 100644 --- a/stgit/lib/transaction.py +++ b/stgit/lib/transaction.py @@ -8,6 +8,7 @@ from stgit import exception, utils from stgit.utils import any, all from stgit.out import * from stgit.lib import git, log +from stgit.config import config class TransactionException(exception.StgException): """Exception raised when something goes wrong with a @@ -324,10 +325,21 @@ class StackTransaction(object): self.__current_tree = tree s = ' (modified)' except git.MergeConflictException, e: - tree = ours merge_conflict = True - self.__conflicts = e.conflicts - s = ' (conflict)' + if config.get('stgit.autoimerge') == 'yes': + try: + iw.mergetool() + merge_conflict = False + except git.MergeException: + pass + if merge_conflict: + tree = ours + self.__conflicts = e.conflicts + s = ' (conflict)' + else: + tree = iw.index.write_tree() + self.__current_tree = tree + s = ' (modified)' except git.MergeException, e: self.__halt(str(e)) cd = cd.set_tree(tree) -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html