Skip to content
/ git Public
forked from git/git

Commit

Permalink
revision.c: introduce --cherry-mark
Browse files Browse the repository at this point in the history
for marking those commits which "--cherry-pick" would drop.
The marker for those commits is '=' because '-' denotes a boundary
commit already, even though 'git cherry' uses it.

Nonequivalent commits are denoted '+' unless '--left-right' is used.

Signed-off-by: Michael J Gruber <git@drmicha.warpmail.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Michael J Gruber authored and gitster committed Mar 9, 2011
1 parent 1df2d65 commit adbbb31
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 4 deletions.
21 changes: 18 additions & 3 deletions revision.c
Original file line number Diff line number Diff line change
Expand Up @@ -535,6 +535,7 @@ static void cherry_pick_list(struct commit_list *list, struct rev_info *revs)
int left_count = 0, right_count = 0;
int left_first;
struct patch_ids ids;
unsigned cherry_flag;

/* First count the commits on the left and on the right */
for (p = list; p; p = p->next) {
Expand Down Expand Up @@ -576,6 +577,9 @@ static void cherry_pick_list(struct commit_list *list, struct rev_info *revs)
commit->util = add_commit_patch_id(commit, &ids);
}

/* either cherry_mark or cherry_pick are true */
cherry_flag = revs->cherry_mark ? PATCHSAME : SHOWN;

/* Check the other side */
for (p = list; p; p = p->next) {
struct commit *commit = p->item;
Expand All @@ -598,7 +602,7 @@ static void cherry_pick_list(struct commit_list *list, struct rev_info *revs)
if (!id)
continue;
id->seen = 1;
commit->object.flags |= SHOWN;
commit->object.flags |= cherry_flag;
}

/* Now check the original side for seen ones */
Expand All @@ -610,7 +614,7 @@ static void cherry_pick_list(struct commit_list *list, struct rev_info *revs)
if (!ent)
continue;
if (ent->seen)
commit->object.flags |= SHOWN;
commit->object.flags |= cherry_flag;
commit->util = NULL;
}

Expand Down Expand Up @@ -802,7 +806,7 @@ static int limit_list(struct rev_info *revs)
show(revs, newlist);
show_early_output = NULL;
}
if (revs->cherry_pick)
if (revs->cherry_pick || revs->cherry_mark)
cherry_pick_list(newlist, revs);

if (revs->left_only || revs->right_only)
Expand Down Expand Up @@ -1293,7 +1297,14 @@ static int handle_revision_opt(struct rev_info *revs, int argc, const char **arg
revs->right_only = 1;
} else if (!strcmp(arg, "--count")) {
revs->count = 1;
} else if (!strcmp(arg, "--cherry-mark")) {
if (revs->cherry_pick)
die("--cherry-mark is incompatible with --cherry-pick");
revs->cherry_mark = 1;
revs->limited = 1; /* needs limit_list() */
} else if (!strcmp(arg, "--cherry-pick")) {
if (revs->cherry_mark)
die("--cherry-pick is incompatible with --cherry-mark");
revs->cherry_pick = 1;
revs->limited = 1;
} else if (!strcmp(arg, "--objects")) {
Expand Down Expand Up @@ -2270,12 +2281,16 @@ char *get_revision_mark(const struct rev_info *revs, const struct commit *commit
return "-";
else if (commit->object.flags & UNINTERESTING)
return "^";
else if (commit->object.flags & PATCHSAME)
return "=";
else if (!revs || revs->left_right) {
if (commit->object.flags & SYMMETRIC_LEFT)
return "<";
else
return ">";
} else if (revs->graph)
return "*";
else if (revs->cherry_mark)
return "+";
return "";
}
4 changes: 3 additions & 1 deletion revision.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@
#define CHILD_SHOWN (1u<<6)
#define ADDED (1u<<7) /* Parents already parsed and added? */
#define SYMMETRIC_LEFT (1u<<8)
#define ALL_REV_FLAGS ((1u<<9)-1)
#define PATCHSAME (1u<<9)
#define ALL_REV_FLAGS ((1u<<10)-1)

#define DECORATE_SHORT_REFS 1
#define DECORATE_FULL_REFS 2
Expand Down Expand Up @@ -68,6 +69,7 @@ struct rev_info {
reverse:1,
reverse_output_stage:1,
cherry_pick:1,
cherry_mark:1,
bisect:1,
ancestry_path:1,
first_parent_only:1;
Expand Down

0 comments on commit adbbb31

Please sign in to comment.