All of lore.kernel.org
 help / color / mirror / Atom feed
* [StGit PATCH] Add automatic git-mergetool invocation to the new infrastructure
@ 2009-02-10 14:14 Catalin Marinas
  2009-02-11  9:20 ` Karl Hasselström
  0 siblings, 1 reply; 4+ messages in thread
From: Catalin Marinas @ 2009-02-10 14:14 UTC (permalink / raw)
  To: git, Karl Hasselström

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@gmail.com>
---

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)

^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2009-02-11 13:12 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-02-10 14:14 [StGit PATCH] Add automatic git-mergetool invocation to the new infrastructure Catalin Marinas
2009-02-11  9:20 ` Karl Hasselström
2009-02-11 10:48   ` Catalin Marinas
2009-02-11 13:11     ` Karl Hasselström

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.