Merge branch 'mg/tracked-local-branches'
authorJunio C Hamano <gitster@pobox.com>
Mon, 6 Apr 2009 07:42:31 +0000 (00:42 -0700)
committerJunio C Hamano <gitster@pobox.com>
Mon, 6 Apr 2009 07:42:31 +0000 (00:42 -0700)
* mg/tracked-local-branches:
Make local branches behave like remote branches when --tracked
Test for local branches being followed with --track

1  2 
remote.c
diff --combined remote.c
index 2b037f11b29d86e38d6608a58c65e79e0ffd3800,30d7fdec834cc0dcc35d335754add91f96b51ab3..d12140e0fef5331188295da1f3190873ddc5bed8
+++ b/remote.c
@@@ -1170,8 -1170,9 +1170,9 @@@ struct branch *branch_get(const char *n
                        for (i = 0; i < ret->merge_nr; i++) {
                                ret->merge[i] = xcalloc(1, sizeof(**ret->merge));
                                ret->merge[i]->src = xstrdup(ret->merge_name[i]);
-                               remote_find_tracking(ret->remote,
-                                                    ret->merge[i]);
+                               if (remote_find_tracking(ret->remote, ret->merge[i])
+                                   && !strcmp(ret->remote_name, "."))
+                                       ret->merge[i]->dst = xstrdup(ret->merge_name[i]);
                        }
                }
        }
@@@ -1401,10 -1402,9 +1402,10 @@@ int stat_tracking_info(struct branch *b
        if (theirs == ours)
                return 0;
  
 -      /* Run "rev-list --left-right ours...theirs" internally... */
 +      /* Run "rev-list --no-merges --left-right ours...theirs" internally... */
        rev_argc = 0;
        rev_argv[rev_argc++] = NULL;
 +      rev_argv[rev_argc++] = "--no-merges";
        rev_argv[rev_argc++] = "--left-right";
        rev_argv[rev_argc++] = symmetric;
        rev_argv[rev_argc++] = "--";
@@@ -1451,6 -1451,8 +1452,8 @@@ int format_tracking_info(struct branch 
        base = branch->merge[0]->dst;
        if (!prefixcmp(base, "refs/remotes/")) {
                base += strlen("refs/remotes/");
+       } else if (!prefixcmp(base, "refs/heads/")) {
+               base += strlen("refs/heads/");
        }
        if (!num_theirs)
                strbuf_addf(sb, "Your branch is ahead of '%s' "