summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: d24ef76)
raw | patch | inline | side by side (parent: d24ef76)
| author | Jonas Fonseca <fonseca@diku.dk> | |
| Sat, 29 Sep 2007 01:36:24 +0000 (03:36 +0200) | ||
| committer | Jonas Fonseca <fonseca@diku.dk> | |
| Sat, 29 Sep 2007 01:36:24 +0000 (03:36 +0200) | 
Unmerged entries now suggests to press M to resolve merge conflicts.
Unmerged entries are no longer shown for the "staged changes"; the same
goes for 'M'odified entries following an 'U'nmerged entry.
Unmerged entries are no longer shown for the "staged changes"; the same
goes for 'M'odified entries following an 'U'nmerged entry.
| manual.txt | patch | blob | history | |
| tig.c | patch | blob | history | |
| tigrc.5.txt | patch | blob | history | 
diff --git a/manual.txt b/manual.txt
index a199ad15ce73d8dddbb48dc78d2c5dad41456cff..b976ece2a095faf39e60eb2536529b2a5d3474ce 100644 (file)
--- a/manual.txt
+++ b/manual.txt
        running git-add <filename>). In the stage view, when pressing this on \
        a diff chunk line stages only that chunk for next commit, when not on \
        a diff chunk line all changes in the displayed diff is staged.
+M      Resolve unmerged file by launching git-mergetool(1). Note, to work \
+       correctly this might require some initial configuration of your \
+       preferred merge tool. See the manpage of git-mergetool(1).
 -----------------------------------------------------------------------------
 [[refspec]]
index b9fd89c7f20c44a9c1830235eded41cd8f5f8180..1cffb040f7aff7826e0ba6140e2fecab2ce84445 100644 (file)
--- a/tig.c
+++ b/tig.c
        REQ_(TOGGLE_LINENO,     "Toggle line numbers"), \
        REQ_(TOGGLE_REV_GRAPH,  "Toggle revision graph visualization"), \
        REQ_(STATUS_UPDATE,     "Update file status"), \
+       REQ_(STATUS_MERGE,      "Merge file using external tool"), \
        REQ_(EDIT,              "Open in editor"), \
        REQ_(CHERRY_PICK,       "Cherry-pick commit to current branch")
        { 'g',          REQ_TOGGLE_REV_GRAPH },
        { ':',          REQ_PROMPT },
        { 'u',          REQ_STATUS_UPDATE },
+       { 'M',          REQ_STATUS_MERGE },
        { 'e',          REQ_EDIT },
        { 'C',          REQ_CHERRY_PICK },
        redraw_display();
 }
+static void
+open_mergetool(const char *file)
+{
+       char cmd[SIZEOF_STR];
+       char file_sq[SIZEOF_STR];
+
+       if (sq_quote(file_sq, 0, file) < sizeof(file_sq) &&
+           string_format(cmd, "git mergetool %s", file_sq)) {
+               open_external_viewer(cmd);
+       }
+}
+
 static void
 open_editor(bool from_root, const char *file)
 {
 status_run(struct view *view, const char cmd[], bool diff, enum line_type type)
 {
        struct status *file = NULL;
+       struct status *unmerged = NULL;
        char buf[SIZEOF_STR * 4];
        size_t bufsize = 0;
        FILE *pipe;
@@ -3038,6 +3053,23 @@ status_run(struct view *view, const char cmd[], bool diff, enum line_type type)
                                if (!sep)
                                        break;
                                sepsize = sep - buf + 1;
+
+                               /* Collapse all 'M'odified entries that
+                                * follow a associated 'U'nmerged entry.
+                                */
+                               if (file->status == 'U') {
+                                       unmerged = file;
+
+                               } else if (unmerged) {
+                                       int collapse = !strcmp(buf, unmerged->name);
+
+                                       unmerged = NULL;
+                                       if (collapse) {
+                                               free(file);
+                                               view->lines--;
+                                               continue;
+                                       }
+                               }
                        }
                        /* git-ls-files just delivers a NUL separated
        return TRUE;
 }
-#define STATUS_DIFF_INDEX_CMD "git diff-index -z --cached HEAD"
+/* Don't show unmerged entries in the staged section. */
+#define STATUS_DIFF_INDEX_CMD "git diff-index -z --diff-filter=ACDMRTXB --cached HEAD"
 #define STATUS_DIFF_FILES_CMD "git diff-files -z"
 #define STATUS_LIST_OTHER_CMD \
        "git ls-files -z --others --exclude-per-directory=.gitignore"
                status_update(view);
                break;
+       case REQ_STATUS_MERGE:
+               open_mergetool(status->name);
+               open_view(view, REQ_VIEW_STATUS, OPEN_RELOAD);
+               break;
+
        case REQ_EDIT:
                if (!status)
                        return request;
        struct status *status = line->data;
        char file[SIZEOF_STR] = "all files";
        char *text;
+       char *key;
        if (status && !string_format(file, "'%s'", status->name))
                return;
                die("w00t");
        }
-       string_format(view->ref, text, get_key(REQ_STATUS_UPDATE), file);
+       if (status && status->status == 'U') {
+               text = "Press %s to resolve conflict in %s";
+               key = get_key(REQ_STATUS_MERGE);
+
+       } else {
+               key = get_key(REQ_STATUS_UPDATE);
+       }
+
+       string_format(view->ref, text, key, file);
 }
 static bool
diff --git a/tigrc.5.txt b/tigrc.5.txt
index fa4f47369627161ac6cf50c5ab6fd304edeed964..8e37efc8a38d3acc1ab66d982f0ce282fd83ea76 100644 (file)
--- a/tigrc.5.txt
+++ b/tigrc.5.txt
 toggle-lineno          Toggle line numbers
 toggle-rev-graph       Toggle revision graph visualization
 status-update          Update file status
+status-merge           Resolve unmerged file
 edit                   Open in editor
 cherry-pick            Cherry-pick commit to current branch
 ------------------------------------------------------------------------------
![[tokkee]](http://tokkee.org/images/avatar.png)
