aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2020-09-18 17:58:00 -0700
committerJunio C Hamano <gitster@pobox.com>2020-09-18 17:58:00 -0700
commite46544454a8f4a157bf6988b14fb6841b31ced88 (patch)
tree14001293dad6d6dd0e84aa773f21f8fb315f3af3
parent2496da42118087e6766964c7a7b94f45daf372f4 (diff)
parent793d37c17ffab46507e14c4547ad2edc9ba9e3fe (diff)
downloadgit-e46544454a8f4a157bf6988b14fb6841b31ced88.tar.xz
Merge branch 'so/log-tree-diff-cleanup'
Code cleanup. * so/log-tree-diff-cleanup: log_tree_diff: get rid of extra check for NULL log_tree_diff: get rid of code duplication for first_parent_only
-rw-r--r--log-tree.c21
1 files changed, 5 insertions, 16 deletions
diff --git a/log-tree.c b/log-tree.c
index 55a68d0c61..8ac285a25a 100644
--- a/log-tree.c
+++ b/log-tree.c
@@ -917,26 +917,15 @@ static int log_tree_diff(struct rev_info *opt, struct commit *commit, struct log
}
/* More than one parent? */
- if (parents && parents->next) {
+ if (parents->next) {
if (opt->ignore_merges)
return 0;
else if (opt->combine_merges)
return do_diff_combined(opt, commit);
- else if (opt->first_parent_only) {
- /*
- * Generate merge log entry only for the first
- * parent, showing summary diff of the others
- * we merged _in_.
- */
- parse_commit_or_die(parents->item);
- diff_tree_oid(get_commit_tree_oid(parents->item),
- oid, "", &opt->diffopt);
- log_tree_diff_flush(opt);
- return !opt->loginfo;
+ else if (!opt->first_parent_only) {
+ /* If we show multiple diffs, show the parent info */
+ log->parent = parents->item;
}
-
- /* If we show individual diffs, show the parent info */
- log->parent = parents->item;
}
showed_log = 0;
@@ -952,7 +941,7 @@ static int log_tree_diff(struct rev_info *opt, struct commit *commit, struct log
/* Set up the log info for the next parent, if any.. */
parents = parents->next;
- if (!parents)
+ if (!parents || opt->first_parent_only)
break;
log->parent = parents->item;
opt->loginfo = log;