merge, pull: add '--(no-)log' command line option
These are the command line option equivalents of the 'merge.log' config variable. The patch also updates documentation and bash completion accordingly, and adds a test. Signed-off-by: SZEDER Gábor <szeder@ira.uka.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
6cd9cfefc5
commit
efb779f887
@ -9,6 +9,15 @@
|
|||||||
Synonyms to --stat and --no-stat; these are deprecated and will be
|
Synonyms to --stat and --no-stat; these are deprecated and will be
|
||||||
removed in the future.
|
removed in the future.
|
||||||
|
|
||||||
|
--log::
|
||||||
|
In addition to branch names, populate the log message with
|
||||||
|
one-line descriptions from the actual commits that are being
|
||||||
|
merged.
|
||||||
|
|
||||||
|
--no-log::
|
||||||
|
Do not list one-line descriptions from the actual commits being
|
||||||
|
merged.
|
||||||
|
|
||||||
--no-commit::
|
--no-commit::
|
||||||
Perform the merge but pretend the merge failed and do
|
Perform the merge but pretend the merge failed and do
|
||||||
not autocommit, to give the user a chance to inspect and
|
not autocommit, to give the user a chance to inspect and
|
||||||
|
@ -779,7 +779,7 @@ _git_merge ()
|
|||||||
;;
|
;;
|
||||||
--*)
|
--*)
|
||||||
__gitcomp "
|
__gitcomp "
|
||||||
--no-commit --no-stat --squash --strategy
|
--no-commit --no-stat --log --no-log --squash --strategy
|
||||||
"
|
"
|
||||||
return
|
return
|
||||||
esac
|
esac
|
||||||
|
@ -12,6 +12,8 @@ stat show a diffstat at the end of the merge
|
|||||||
n,no-stat don't show a diffstat at the end of the merge
|
n,no-stat don't show a diffstat at the end of the merge
|
||||||
summary (synonym to --stat)
|
summary (synonym to --stat)
|
||||||
no-summary (synonym to --no-stat)
|
no-summary (synonym to --no-stat)
|
||||||
|
log add list of one-line log to merge commit message
|
||||||
|
no-log don't add list of one-line log to merge commit message
|
||||||
squash create a single commit instead of doing a merge
|
squash create a single commit instead of doing a merge
|
||||||
commit perform a commit if the merge sucesses (default)
|
commit perform a commit if the merge sucesses (default)
|
||||||
ff allow fast forward (default)
|
ff allow fast forward (default)
|
||||||
@ -39,7 +41,7 @@ use_strategies=
|
|||||||
|
|
||||||
allow_fast_forward=t
|
allow_fast_forward=t
|
||||||
allow_trivial_merge=t
|
allow_trivial_merge=t
|
||||||
squash= no_commit=
|
squash= no_commit= log_arg=
|
||||||
|
|
||||||
dropsave() {
|
dropsave() {
|
||||||
rm -f -- "$GIT_DIR/MERGE_HEAD" "$GIT_DIR/MERGE_MSG" \
|
rm -f -- "$GIT_DIR/MERGE_HEAD" "$GIT_DIR/MERGE_MSG" \
|
||||||
@ -154,6 +156,8 @@ parse_config () {
|
|||||||
show_diffstat=false ;;
|
show_diffstat=false ;;
|
||||||
--stat|--summary)
|
--stat|--summary)
|
||||||
show_diffstat=t ;;
|
show_diffstat=t ;;
|
||||||
|
--log|--no-log)
|
||||||
|
log_arg=$1 ;;
|
||||||
--squash)
|
--squash)
|
||||||
test "$allow_fast_forward" = t ||
|
test "$allow_fast_forward" = t ||
|
||||||
die "You cannot combine --squash with --no-ff."
|
die "You cannot combine --squash with --no-ff."
|
||||||
@ -261,7 +265,7 @@ else
|
|||||||
merge_name=$(for remote
|
merge_name=$(for remote
|
||||||
do
|
do
|
||||||
merge_name "$remote"
|
merge_name "$remote"
|
||||||
done | git fmt-merge-msg
|
done | git fmt-merge-msg $log_arg
|
||||||
)
|
)
|
||||||
merge_msg="${merge_msg:+$merge_msg$LF$LF}$merge_name"
|
merge_msg="${merge_msg:+$merge_msg$LF$LF}$merge_name"
|
||||||
fi
|
fi
|
||||||
|
@ -16,7 +16,7 @@ cd_to_toplevel
|
|||||||
test -z "$(git ls-files -u)" ||
|
test -z "$(git ls-files -u)" ||
|
||||||
die "You are in the middle of a conflicted merge."
|
die "You are in the middle of a conflicted merge."
|
||||||
|
|
||||||
strategy_args= no_stat= no_commit= squash= no_ff=
|
strategy_args= no_stat= no_commit= squash= no_ff= log_arg=
|
||||||
curr_branch=$(git symbolic-ref -q HEAD)
|
curr_branch=$(git symbolic-ref -q HEAD)
|
||||||
curr_branch_short=$(echo "$curr_branch" | sed "s|refs/heads/||")
|
curr_branch_short=$(echo "$curr_branch" | sed "s|refs/heads/||")
|
||||||
rebase=$(git config --bool branch.$curr_branch_short.rebase)
|
rebase=$(git config --bool branch.$curr_branch_short.rebase)
|
||||||
@ -27,6 +27,8 @@ do
|
|||||||
no_stat=-n ;;
|
no_stat=-n ;;
|
||||||
--stat|--summary)
|
--stat|--summary)
|
||||||
no_stat=$1 ;;
|
no_stat=$1 ;;
|
||||||
|
--log|--no-log)
|
||||||
|
log_arg=$1 ;;
|
||||||
--no-c|--no-co|--no-com|--no-comm|--no-commi|--no-commit)
|
--no-c|--no-co|--no-com|--no-comm|--no-commi|--no-commit)
|
||||||
no_commit=--no-commit ;;
|
no_commit=--no-commit ;;
|
||||||
--c|--co|--com|--comm|--commi|--commit)
|
--c|--co|--com|--comm|--commi|--commit)
|
||||||
@ -170,9 +172,9 @@ then
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
merge_name=$(git fmt-merge-msg <"$GIT_DIR/FETCH_HEAD") || exit
|
merge_name=$(git fmt-merge-msg $log_arg <"$GIT_DIR/FETCH_HEAD") || exit
|
||||||
test true = "$rebase" &&
|
test true = "$rebase" &&
|
||||||
exec git-rebase $strategy_args --onto $merge_head \
|
exec git-rebase $strategy_args --onto $merge_head \
|
||||||
${oldremoteref:-$merge_head}
|
${oldremoteref:-$merge_head}
|
||||||
exec git-merge $no_stat $no_commit $squash $no_ff $strategy_args \
|
exec git-merge $no_stat $no_commit $squash $no_ff $log_arg $strategy_args \
|
||||||
"$merge_name" HEAD $merge_head
|
"$merge_name" HEAD $merge_head
|
||||||
|
@ -104,7 +104,11 @@ create_merge_msgs() {
|
|||||||
git log --no-merges ^HEAD c2 >>squash.1-5 &&
|
git log --no-merges ^HEAD c2 >>squash.1-5 &&
|
||||||
echo "Squashed commit of the following:" >squash.1-5-9 &&
|
echo "Squashed commit of the following:" >squash.1-5-9 &&
|
||||||
echo >>squash.1-5-9 &&
|
echo >>squash.1-5-9 &&
|
||||||
git log --no-merges ^HEAD c2 c3 >>squash.1-5-9
|
git log --no-merges ^HEAD c2 c3 >>squash.1-5-9 &&
|
||||||
|
echo > msg.nolog &&
|
||||||
|
echo "* commit 'c3':" >msg.log &&
|
||||||
|
echo " commit 3" >>msg.log &&
|
||||||
|
echo >>msg.log
|
||||||
}
|
}
|
||||||
|
|
||||||
verify_diff() {
|
verify_diff() {
|
||||||
@ -456,6 +460,16 @@ test_expect_success 'merge c0 with c1 (ff overrides no-ff)' '
|
|||||||
verify_head $c1
|
verify_head $c1
|
||||||
'
|
'
|
||||||
|
|
||||||
|
test_expect_success 'merge log message' '
|
||||||
|
git reset --hard c0 &&
|
||||||
|
git merge --no-log c2 &&
|
||||||
|
git show -s --pretty=format:%b HEAD >msg.act &&
|
||||||
|
verify_diff msg.nolog msg.act "[OOPS] bad merge log message" &&
|
||||||
|
git merge --log c3 &&
|
||||||
|
git show -s --pretty=format:%b HEAD >msg.act &&
|
||||||
|
verify_diff msg.log msg.act "[OOPS] bad merge log message"
|
||||||
|
'
|
||||||
|
|
||||||
test_debug 'gitk --all'
|
test_debug 'gitk --all'
|
||||||
|
|
||||||
test_done
|
test_done
|
||||||
|
Loading…
Reference in New Issue
Block a user