* [PATCH/RFCv2 1/2] git-rebase -i: add command "drop" to remove a commit
@ 2015-06-01 11:52 Galan Rémi
2015-06-01 11:52 ` [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits Galan Rémi
0 siblings, 1 reply; 14+ messages in thread
From: Galan Rémi @ 2015-06-01 11:52 UTC (permalink / raw)
To: Git List
Cc: Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley, Eric Sunshine,
Stephen Kelly, Galan Rémi
Instead of removing a line to remove the commit, you can use the
command "drop" (just like "pick" or "edit"). It has the same effect as
deleting the line (removing the commit) except that you keep a visual
trace of your actions, allowing a better control and reducing the
possibility of removing a commit by mistake.
Signed-off-by: Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr>
---
Documentation/git-rebase.txt | 3 +++
git-rebase--interactive.sh | 3 ++-
t/lib-rebase.sh | 4 ++--
t/t3404-rebase-interactive.sh | 11 +++++++++++
4 files changed, 18 insertions(+), 3 deletions(-)
diff --git a/Documentation/git-rebase.txt b/Documentation/git-rebase.txt
index 1d01baa..9cf3760 100644
--- a/Documentation/git-rebase.txt
+++ b/Documentation/git-rebase.txt
@@ -514,6 +514,9 @@ rebasing.
If you just want to edit the commit message for a commit, replace the
command "pick" with the command "reword".
+To drop a commit, replace the command "pick" with "drop", or just
+delete its line.
+
If you want to fold two or more commits into one, replace the command
"pick" for the second and subsequent commits with "squash" or "fixup".
If the commits had different authors, the folded commit will be
diff --git a/git-rebase--interactive.sh b/git-rebase--interactive.sh
index bab0dcc..2882276 100644
--- a/git-rebase--interactive.sh
+++ b/git-rebase--interactive.sh
@@ -152,6 +152,7 @@ Commands:
s, squash = use commit, but meld into previous commit
f, fixup = like "squash", but discard this commit's log message
x, exec = run command (the rest of the line) using shell
+ d, drop = remove commit
These lines can be re-ordered; they are executed from top to bottom.
@@ -505,7 +506,7 @@ do_next () {
rm -f "$msg" "$author_script" "$amend" || exit
read -r command sha1 rest < "$todo"
case "$command" in
- "$comment_char"*|''|noop)
+ "$comment_char"*|''|noop|drop|d)
mark_action_done
;;
pick|p)
diff --git a/t/lib-rebase.sh b/t/lib-rebase.sh
index 6bd2522..fdbc900 100644
--- a/t/lib-rebase.sh
+++ b/t/lib-rebase.sh
@@ -14,7 +14,7 @@
# specified line.
#
# "<cmd> <lineno>" -- add a line with the specified command
-# ("squash", "fixup", "edit", or "reword") and the SHA1 taken
+# ("squash", "fixup", "edit", "reword" or "drop") and the SHA1 taken
# from the specified line.
#
# "exec_cmd_with_args" -- add an "exec cmd with args" line.
@@ -46,7 +46,7 @@ set_fake_editor () {
action=pick
for line in $FAKE_LINES; do
case $line in
- squash|fixup|edit|reword)
+ squash|fixup|edit|reword|drop)
action="$line";;
exec*)
echo "$line" | sed 's/_/ /g' >> "$1";;
diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
index ac429a0..1bad068 100755
--- a/t/t3404-rebase-interactive.sh
+++ b/t/t3404-rebase-interactive.sh
@@ -1102,4 +1102,15 @@ test_expect_success 'rebase -i commits that overwrite untracked files (no ff)' '
test $(git cat-file commit HEAD | sed -ne \$p) = I
'
+test_expect_success 'drop' '
+ git checkout master &&
+ test_when_finished "git checkout master" &&
+ git checkout -b dropBranchTest master &&
+ set_fake_editor &&
+ FAKE_LINES="1 drop 2 3 drop 4 5" git rebase -i --root &&
+ test E = $(git cat-file commit HEAD | sed -ne \$p) &&
+ test C = $(git cat-file commit HEAD^ | sed -ne \$p) &&
+ test A = $(git cat-file commit HEAD^^ | sed -ne \$p)
+'
+
test_done
--
2.4.1.363.g9535a9c
^ permalink raw reply related [flat|nested] 14+ messages in thread
* [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-01 11:52 [PATCH/RFCv2 1/2] git-rebase -i: add command "drop" to remove a commit Galan Rémi
@ 2015-06-01 11:52 ` Galan Rémi
2015-06-01 23:16 ` Eric Sunshine
2015-06-02 6:40 ` Matthieu Moy
0 siblings, 2 replies; 14+ messages in thread
From: Galan Rémi @ 2015-06-01 11:52 UTC (permalink / raw)
To: Git List
Cc: Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley, Eric Sunshine,
Stephen Kelly, Galan Rémi
Check if commits were removed (i.e. a line was deleted) and print
warnings or abort git rebase according to the value of the
configuration variable rebase.checkLevel.
Add the configuration variable rebase.checkLevel.
- When unset or set to "ignore", no checking is done.
- When set to "warn", the commits are checked, warnings are
displayed but git rebase still proceeds.
- When set to "error", the commits are checked, warnings are
displayed and the rebase is aborted.
rebase.checkLevel defaults to "ignore".
Signed-off-by: Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr>
---
Documentation/config.txt | 9 ++++
Documentation/git-rebase.txt | 6 +++
git-rebase--interactive.sh | 105 ++++++++++++++++++++++++++++++++++++++++++
t/t3404-rebase-interactive.sh | 10 +++-
4 files changed, 129 insertions(+), 1 deletion(-)
diff --git a/Documentation/config.txt b/Documentation/config.txt
index 5f76e8c..e2e5554 100644
--- a/Documentation/config.txt
+++ b/Documentation/config.txt
@@ -2160,6 +2160,15 @@ rebase.autoStash::
successful rebase might result in non-trivial conflicts.
Defaults to false.
+rebase.checkLevel::
+ If set to "warn", git rebase -i will print a warning if some
+ commits are removed (i.e. a line was deleted) or if some
+ commits appear more than one time (e.g. the same commit is
+ picked twice), however the rebase will still proceed. If set
+ to "error", it will print the previous warnings and abort the
+ rebase. If set to "ignore", no checking is done. Defaults to
+ "ignore".
+
receive.advertiseAtomic::
By default, git-receive-pack will advertise the atomic push
capability to its clients. If you don't want to this capability
diff --git a/Documentation/git-rebase.txt b/Documentation/git-rebase.txt
index 9cf3760..d348ca2 100644
--- a/Documentation/git-rebase.txt
+++ b/Documentation/git-rebase.txt
@@ -213,6 +213,12 @@ rebase.autoSquash::
rebase.autoStash::
If set to true enable '--autostash' option by default.
+rebase.checkLevel::
+ If set to "warn" print warnings about removed commits and
+ duplicated commits in interactive mode. If set to "error"
+ print the warnings and abort the rebase. If set to "ignore" no
+ checking is done. "ignore" by default.
+
OPTIONS
-------
--onto <newbase>::
diff --git a/git-rebase--interactive.sh b/git-rebase--interactive.sh
index 2882276..58da6ee 100644
--- a/git-rebase--interactive.sh
+++ b/git-rebase--interactive.sh
@@ -837,6 +837,109 @@ add_exec_commands () {
mv "$1.new" "$1"
}
+# Print the list of the SHA-1 of the commits
+# from a todo list in a file.
+# $1: todo-file, $2: outfile
+todo_list_to_sha_list () {
+ todo_list=$(git stripspace --strip-comments <"$1")
+ temp_file=$(mktemp)
+ echo "$todo_list" >$temp_file
+ while read -r command sha1 rest
+ do
+ case $command in
+ x|"exec")
+ ;;
+ *)
+ printf "%s\n" "$sha1"
+ ;;
+ esac
+ done <$temp_file >"$2"
+ rm $temp_file
+}
+
+# Transforms SHA-1 list in argument
+# to a list of commits (in place)
+# Doesn't check if the SHA-1 are commits.
+# $1: file with long SHA-1 list
+long_sha_to_commit_list () {
+ short_missing=""
+ git_command="git show --oneline"
+ get_line_command="head -n 1"
+ temp_file=$(mktemp)
+ while read -r sha
+ do
+ if test -n "$sha"
+ then
+ commit=$($git_command $sha | $get_line_command)
+ if test -n "$commit"
+ then
+ printf "%s\n" "$commit"
+ fi
+ fi
+ done <"$1" >$temp_file
+ mv $temp_file "$1"
+}
+
+# Use warn for each line of a file
+# $1: file to warn
+warn_file () {
+ while read -r line
+ do
+ warn " - $line"
+ done <"$1"
+}
+
+# Check if the user dropped some commits by mistake
+# Behaviour determined by .gitconfig.
+check_commits () {
+ checkLevel=$(git config --get rebase.checkLevel)
+ checkLevel=${checkLevel:-ignore}
+ # To lowercase
+ checkLevel=$(echo "$checkLevel" | tr 'A-Z' 'a-z')
+
+ case "$checkLevel" in
+ warn|error)
+ # Get the SHA-1 of the commits
+ todo_list_to_sha_list "$todo".backup "$todo".oldsha1
+ todo_list_to_sha_list "$todo" "$todo".newsha1
+
+ # Sort the SHA-1 and compare them
+ echo "$(sort -u "$todo".oldsha1)" >"$todo".oldsha1
+ echo "$(sort -u "$todo".newsha1)" >"$todo".newsha1
+ echo "$(comm -2 -3 "$todo".oldsha1 "$todo".newsha1)" >"$todo".miss
+
+ # Make the list user-friendly
+ long_sha_to_commit_list "$todo".miss
+
+ # Check missing commits
+ if test -s "$todo".miss
+ then
+ warn "Warning : some commits may have been dropped" \
+ "accidentally."
+ warn "Dropped commits (in no relevent order):"
+ warn_file "$todo".miss
+ warn ""
+ warn "To avoid this message, use \"drop\" to" \
+ "explicitly remove a commit."
+ warn "Use git --config rebase.checkLevel to change" \
+ "the level of warnings (ignore,warn,error)."
+ warn ""
+
+ if test "$checkLevel" = error
+ then
+ die_abort "Rebase aborted due to dropped commits."
+ fi
+ fi
+ ;;
+ ignore)
+ ;;
+ *)
+ warn "Unrecognized setting $checkLevel for option" \
+ "rebase.checkLevel in git rebase -i."
+ ;;
+ esac
+}
+
# The whole contents of this file is run by dot-sourcing it from
# inside a shell function. It used to be that "return"s we see
# below were not inside any function, and expected to return
@@ -1079,6 +1182,8 @@ has_action "$todo" ||
expand_todo_ids
+check_commits
+
test -d "$rewritten" || test -n "$force_rebase" || skip_unnecessary_picks
GIT_REFLOG_ACTION="$GIT_REFLOG_ACTION: checkout $onto_name"
diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
index 1bad068..d3a9ed5 100755
--- a/t/t3404-rebase-interactive.sh
+++ b/t/t3404-rebase-interactive.sh
@@ -1103,7 +1103,6 @@ test_expect_success 'rebase -i commits that overwrite untracked files (no ff)' '
'
test_expect_success 'drop' '
- git checkout master &&
test_when_finished "git checkout master" &&
git checkout -b dropBranchTest master &&
set_fake_editor &&
@@ -1113,4 +1112,13 @@ test_expect_success 'drop' '
test A = $(git cat-file commit HEAD^^ | sed -ne \$p)
'
+test_expect_success 'rebase -i respects rebase.checkLevel' '
+ test_config rebase.checkLevel error &&
+ test_when_finished "git checkout master" &&
+ git checkout -b tmp2 master &&
+ set_fake_editor &&
+ test_must_fail env FAKE_LINES="1 2 3 4" git rebase -i --root &&
+ test E = $(git cat-file commit HEAD | sed -ne \$p)
+'
+
test_done
--
2.4.1.363.g9535a9c
^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-01 11:52 ` [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits Galan Rémi
@ 2015-06-01 23:16 ` Eric Sunshine
2015-06-01 23:17 ` Eric Sunshine
2015-06-02 7:42 ` Remi Galan Alfonso
2015-06-02 6:40 ` Matthieu Moy
1 sibling, 2 replies; 14+ messages in thread
From: Eric Sunshine @ 2015-06-01 23:16 UTC (permalink / raw)
To: Galan Rémi
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley, Stephen Kelly
On Mon, Jun 1, 2015 at 7:52 AM, Galan Rémi
<remi.galan-alfonso@ensimag.grenoble-inp.fr> wrote:
> Check if commits were removed (i.e. a line was deleted) and print
> warnings or abort git rebase according to the value of the
> configuration variable rebase.checkLevel.
>
> Add the configuration variable rebase.checkLevel.
> - When unset or set to "ignore", no checking is done.
> - When set to "warn", the commits are checked, warnings are
> displayed but git rebase still proceeds.
> - When set to "error", the commits are checked, warnings are
> displayed and the rebase is aborted.
>
> rebase.checkLevel defaults to "ignore".
>
> Signed-off-by: Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr>
> ---
> diff --git a/Documentation/config.txt b/Documentation/config.txt
> index 5f76e8c..e2e5554 100644
> --- a/Documentation/config.txt
> +++ b/Documentation/config.txt
> @@ -2160,6 +2160,15 @@ rebase.autoStash::
> successful rebase might result in non-trivial conflicts.
> Defaults to false.
>
> +rebase.checkLevel::
> + If set to "warn", git rebase -i will print a warning if some
> + commits are removed (i.e. a line was deleted) or if some
> + commits appear more than one time (e.g. the same commit is
> + picked twice), however the rebase will still proceed. If set
The cover letter says that v2 no longer checks for a duplicate,
however, this documentation still mentions it.
> + to "error", it will print the previous warnings and abort the
> + rebase. If set to "ignore", no checking is done. Defaults to
> + "ignore".
> +
> receive.advertiseAtomic::
> By default, git-receive-pack will advertise the atomic push
> capability to its clients. If you don't want to this capability
> diff --git a/Documentation/git-rebase.txt b/Documentation/git-rebase.txt
> index 9cf3760..d348ca2 100644
> --- a/Documentation/git-rebase.txt
> +++ b/Documentation/git-rebase.txt
> @@ -213,6 +213,12 @@ rebase.autoSquash::
> rebase.autoStash::
> If set to true enable '--autostash' option by default.
>
> +rebase.checkLevel::
> + If set to "warn" print warnings about removed commits and
> + duplicated commits in interactive mode. If set to "error"
Same here.
> + print the warnings and abort the rebase. If set to "ignore" no
> + checking is done. "ignore" by default.
> +
> diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
> index 1bad068..d3a9ed5 100755
> --- a/t/t3404-rebase-interactive.sh
> +++ b/t/t3404-rebase-interactive.sh
> @@ -1103,7 +1103,6 @@ test_expect_success 'rebase -i commits that overwrite untracked files (no ff)' '
> '
>
> test_expect_success 'drop' '
> - git checkout master &&
> test_when_finished "git checkout master" &&
> git checkout -b dropBranchTest master &&
This "cleanup" change might deserve its own test (or at least a
mention in the commit message).
> set_fake_editor &&
> @@ -1113,4 +1112,13 @@ test_expect_success 'drop' '
> test A = $(git cat-file commit HEAD^^ | sed -ne \$p)
> '
>
> +test_expect_success 'rebase -i respects rebase.checkLevel' '
> + test_config rebase.checkLevel error &&
> + test_when_finished "git checkout master" &&
> + git checkout -b tmp2 master &&
> + set_fake_editor &&
> + test_must_fail env FAKE_LINES="1 2 3 4" git rebase -i --root &&
> + test E = $(git cat-file commit HEAD | sed -ne \$p)
> +'
Shouldn't you also explicitly test "warn" and "ignore" modes?
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-01 23:16 ` Eric Sunshine
@ 2015-06-01 23:17 ` Eric Sunshine
2015-06-02 7:42 ` Remi Galan Alfonso
1 sibling, 0 replies; 14+ messages in thread
From: Eric Sunshine @ 2015-06-01 23:17 UTC (permalink / raw)
To: Galan Rémi
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley, Stephen Kelly
On Mon, Jun 1, 2015 at 7:16 PM, Eric Sunshine <sunshine@sunshineco.com> wrote:
> On Mon, Jun 1, 2015 at 7:52 AM, Galan Rémi
> <remi.galan-alfonso@ensimag.grenoble-inp.fr> wrote:
>> test_expect_success 'drop' '
>> - git checkout master &&
>> test_when_finished "git checkout master" &&
>> git checkout -b dropBranchTest master &&
>
> This "cleanup" change might deserve its own test (or at least a
> mention in the commit message).
"...might deserve its own _patch_..."
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-01 23:16 ` Eric Sunshine
2015-06-01 23:17 ` Eric Sunshine
@ 2015-06-02 7:42 ` Remi Galan Alfonso
2015-06-02 13:41 ` Eric Sunshine
1 sibling, 1 reply; 14+ messages in thread
From: Remi Galan Alfonso @ 2015-06-02 7:42 UTC (permalink / raw)
To: Eric Sunshine
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley
Eric Sunshine <sunshine@sunshineco.com> writes:
> > +rebase.checkLevel::
> > + If set to "warn", git rebase -i will print a warning if some
> > + commits are removed (i.e. a line was deleted) or if some
> > + commits appear more than one time (e.g. the same commit is
> > + picked twice), however the rebase will still proceed. If set
>
> The cover letter says that v2 no longer checks for a duplicate,
> however, this documentation still mentions it.
>
> > +rebase.checkLevel::
> > + If set to "warn" print warnings about removed commits and
> > + duplicated commits in interactive mode. If set to "error"
>
> Same here.
I forgot to modify the documentation, really sorry about
that.
Corrected here.
Eric Sunshine <sunshine@sunshineco.com> writes:
> > test_expect_success 'drop' '
> > - git checkout master &&
> > test_when_finished "git checkout master" &&
> > git checkout -b dropBranchTest master &&
>
> This "cleanup" change might deserve its own patch (or at least a
> mention in the commit message).
I will rather move the this cleanup to the first part of this patch,
where the test was added (it should cause no problem, since the patch
is still in discussion), it makes more sense. I actually thought that
was what I did but seems like I was wrong.
I forgot to double check my patch this time, and it is showing, my
bad.
Eric Sunshine <sunshine@sunshineco.com> writes:
> > +test_expect_success 'rebase -i respects rebase.checkLevel' '
> > + test_config rebase.checkLevel error &&
> > + test_when_finished "git checkout master" &&
> > + git checkout -b tmp2 master &&
> > + set_fake_editor &&
> > + test_must_fail env FAKE_LINES="1 2 3 4" git rebase -i --root &&
> > + test E = $(git cat-file commit HEAD | sed -ne \$p)
> > +'
>
> Shouldn't you also explicitly test "warn" and "ignore" modes?
I don't think testing "ignore" is really necessary since it
corresponds to the default behaviour, it is thus silently tested by
the other tests.
Either way, I will add a test for "warn".
Rémi
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-02 7:42 ` Remi Galan Alfonso
@ 2015-06-02 13:41 ` Eric Sunshine
2015-06-02 13:51 ` Remi Galan Alfonso
0 siblings, 1 reply; 14+ messages in thread
From: Eric Sunshine @ 2015-06-02 13:41 UTC (permalink / raw)
To: Remi Galan Alfonso
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley
On Tue, Jun 2, 2015 at 3:42 AM, Remi Galan Alfonso
<remi.galan-alfonso@ensimag.grenoble-inp.fr> wrote:
> Eric Sunshine <sunshine@sunshineco.com> writes:
>> > +test_expect_success 'rebase -i respects rebase.checkLevel' '
>> > + test_config rebase.checkLevel error &&
>> > + test_when_finished "git checkout master" &&
>> > + git checkout -b tmp2 master &&
>> > + set_fake_editor &&
>> > + test_must_fail env FAKE_LINES="1 2 3 4" git rebase -i --root &&
>> > + test E = $(git cat-file commit HEAD | sed -ne \$p)
>> > +'
>>
>> Shouldn't you also explicitly test "warn" and "ignore" modes?
>
> I don't think testing "ignore" is really necessary since it
> corresponds to the default behaviour, it is thus silently tested by
> the other tests.
Although the underlying behavior of "ignore" may be the same as the
default, you also want to check that higher-level machinery for
recognizing the "ignore" option is working correctly, which is why
checking "ignore" explicitly is a reasonable thing to do.
> Either way, I will add a test for "warn".
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-02 13:41 ` Eric Sunshine
@ 2015-06-02 13:51 ` Remi Galan Alfonso
0 siblings, 0 replies; 14+ messages in thread
From: Remi Galan Alfonso @ 2015-06-02 13:51 UTC (permalink / raw)
To: Eric Sunshine
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley
Eric Sunshine <sunshine@sunshineco.com> writes:
> Although the underlying behavior of "ignore" may be the same as the
> default, you also want to check that higher-level machinery for
> recognizing the "ignore" option is working correctly, which is why
> checking "ignore" explicitly is a reasonable thing to do.
Noted, I'm adding a test for "ignore".
Thank you,
Rémi
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-01 11:52 ` [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits Galan Rémi
2015-06-01 23:16 ` Eric Sunshine
@ 2015-06-02 6:40 ` Matthieu Moy
2015-06-02 9:23 ` Remi Galan Alfonso
2015-06-02 17:17 ` Junio C Hamano
1 sibling, 2 replies; 14+ messages in thread
From: Matthieu Moy @ 2015-06-02 6:40 UTC (permalink / raw)
To: Galan Rémi
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Junio C Hamano, Johannes Schindelin,
Stefan Beller, Philip Oakley, Eric Sunshine, Stephen Kelly
Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr> writes:
> Check if commits were removed (i.e. a line was deleted) and print
> warnings or abort git rebase according to the value of the
> configuration variable rebase.checkLevel.
checkLevel does not seem to be a good name, because it doesn't say
_what_ is checked. I don't have really good proposal in mind, but maybe
rebase.todoListCheckLevel
rebase.missinLinesCheckLevel
?
--
Matthieu Moy
http://www-verimag.imag.fr/~moy/
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-02 6:40 ` Matthieu Moy
@ 2015-06-02 9:23 ` Remi Galan Alfonso
2015-06-02 17:17 ` Junio C Hamano
1 sibling, 0 replies; 14+ messages in thread
From: Remi Galan Alfonso @ 2015-06-02 9:23 UTC (permalink / raw)
To: Matthieu Moy
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Junio C Hamano, Johannes Schindelin,
Stefan Beller, Philip Oakley, Eric Sunshine
Matthieu Moy <Matthieu.Moy@grenoble-inp.fr> writes:
> Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr> writes:
>
> > Check if commits were removed (i.e. a line was deleted) and print
> > warnings or abort git rebase according to the value of the
> > configuration variable rebase.checkLevel.
>
> checkLevel does not seem to be a good name, because it doesn't say
> _what_ is checked. I don't have really good proposal in mind, but maybe
>
> rebase.todoListCheckLevel
> rebase.missinLinesCheckLevel
>
> ?
I agree that we could use a better name.
I'm thinking about
> rebase.missingLinesCheckLevel
or
rebase.missingCommitsCheckLevel
but I am worried that these names are too long.
Maybe
rebase.dropCheckLevel
I don't really have better propositions right now.
Rémi
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-02 6:40 ` Matthieu Moy
2015-06-02 9:23 ` Remi Galan Alfonso
@ 2015-06-02 17:17 ` Junio C Hamano
1 sibling, 0 replies; 14+ messages in thread
From: Junio C Hamano @ 2015-06-02 17:17 UTC (permalink / raw)
To: Matthieu Moy
Cc: Galan Rémi, Git List, Remi Lespinet, Guillaume Pages,
Louis-Alexandre Stuber, Antoine Delaite, Johannes Schindelin,
Stefan Beller, Philip Oakley, Eric Sunshine, Stephen Kelly
Matthieu Moy <Matthieu.Moy@grenoble-inp.fr> writes:
> Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr> writes:
>
>> Check if commits were removed (i.e. a line was deleted) and print
>> warnings or abort git rebase according to the value of the
>> configuration variable rebase.checkLevel.
>
> checkLevel does not seem to be a good name, because it doesn't say
> _what_ is checked. I don't have really good proposal in mind, but maybe
>
> rebase.todoListCheckLevel
> rebase.missinLinesCheckLevel
Yeah, with s/sin/sing/, but the above makes more sense. It may be
that we probably do not even need "Level" there in the name.
^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH/RFCv4 1/2] git-rebase -i: add command "drop" to remove a commit
@ 2015-06-03 11:44 Galan Rémi
2015-06-03 11:44 ` [PATCH/RFCv4 2/2] git rebase -i: warn about removed commits Galan Rémi
0 siblings, 1 reply; 14+ messages in thread
From: Galan Rémi @ 2015-06-03 11:44 UTC (permalink / raw)
To: Git List
Cc: Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano, Eric Sunshine,
Galan Rémi
Instead of removing a line to remove the commit, you can use the
command "drop" (just like "pick" or "edit"). It has the same effect as
deleting the line (removing the commit) except that you keep a visual
trace of your actions, allowing a better control and reducing the
possibility of removing a commit by mistake.
Signed-off-by: Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr>
---
Documentation/git-rebase.txt | 3 +++
git-rebase--interactive.sh | 18 ++++++++++++++++++
t/lib-rebase.sh | 4 ++--
t/t3404-rebase-interactive.sh | 10 ++++++++++
4 files changed, 33 insertions(+), 2 deletions(-)
diff --git a/Documentation/git-rebase.txt b/Documentation/git-rebase.txt
index 1d01baa..9cf3760 100644
--- a/Documentation/git-rebase.txt
+++ b/Documentation/git-rebase.txt
@@ -514,6 +514,9 @@ rebasing.
If you just want to edit the commit message for a commit, replace the
command "pick" with the command "reword".
+To drop a commit, replace the command "pick" with "drop", or just
+delete its line.
+
If you want to fold two or more commits into one, replace the command
"pick" for the second and subsequent commits with "squash" or "fixup".
If the commits had different authors, the folded commit will be
diff --git a/git-rebase--interactive.sh b/git-rebase--interactive.sh
index dc3133f..869cc60 100644
--- a/git-rebase--interactive.sh
+++ b/git-rebase--interactive.sh
@@ -152,6 +152,7 @@ Commands:
s, squash = use commit, but meld into previous commit
f, fixup = like "squash", but discard this commit's log message
x, exec = run command (the rest of the line) using shell
+ d, drop = remove commit
These lines can be re-ordered; they are executed from top to bottom.
@@ -508,6 +509,23 @@ do_next () {
"$comment_char"*|''|noop)
mark_action_done
;;
+ drop|d)
+ if test -z $sha1
+ then
+ warn "Missing SHA-1 in 'drop' command."
+ die "Please fix this using 'git rebase --edit-todo'."
+ fi
+
+ sha1_verif="$(git rev-parse --verify --quiet $sha1^{commit})"
+ if test -z $sha1_verif
+ then
+ warn "'$sha1' is not a SHA-1 or does not represent" \
+ "a commit in 'drop' command."
+ die "Please fix this using 'git rebase --edit-todo'."
+ fi
+
+ mark_action_done
+ ;;
pick|p)
comment_for_reflog pick
diff --git a/t/lib-rebase.sh b/t/lib-rebase.sh
index 6bd2522..fdbc900 100644
--- a/t/lib-rebase.sh
+++ b/t/lib-rebase.sh
@@ -14,7 +14,7 @@
# specified line.
#
# "<cmd> <lineno>" -- add a line with the specified command
-# ("squash", "fixup", "edit", or "reword") and the SHA1 taken
+# ("squash", "fixup", "edit", "reword" or "drop") and the SHA1 taken
# from the specified line.
#
# "exec_cmd_with_args" -- add an "exec cmd with args" line.
@@ -46,7 +46,7 @@ set_fake_editor () {
action=pick
for line in $FAKE_LINES; do
case $line in
- squash|fixup|edit|reword)
+ squash|fixup|edit|reword|drop)
action="$line";;
exec*)
echo "$line" | sed 's/_/ /g' >> "$1";;
diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
index ac429a0..8960083 100755
--- a/t/t3404-rebase-interactive.sh
+++ b/t/t3404-rebase-interactive.sh
@@ -1102,4 +1102,14 @@ test_expect_success 'rebase -i commits that overwrite untracked files (no ff)' '
test $(git cat-file commit HEAD | sed -ne \$p) = I
'
+test_expect_success 'drop' '
+ test_when_finished "git checkout master" &&
+ git checkout -b dropBranchTest master &&
+ set_fake_editor &&
+ FAKE_LINES="1 drop 2 3 drop 4 5" git rebase -i --root &&
+ test E = $(git cat-file commit HEAD | sed -ne \$p) &&
+ test C = $(git cat-file commit HEAD^ | sed -ne \$p) &&
+ test A = $(git cat-file commit HEAD^^ | sed -ne \$p)
+'
+
test_done
--
2.4.2.389.geaf7ccf
^ permalink raw reply related [flat|nested] 14+ messages in thread
* [PATCH/RFCv4 2/2] git rebase -i: warn about removed commits
2015-06-03 11:44 [PATCH/RFCv4 1/2] git-rebase -i: add command "drop" to remove a commit Galan Rémi
@ 2015-06-03 11:44 ` Galan Rémi
2015-06-03 19:14 ` [PATCH/RFCv2 " Eric Sunshine
0 siblings, 1 reply; 14+ messages in thread
From: Galan Rémi @ 2015-06-03 11:44 UTC (permalink / raw)
To: Git List
Cc: Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano, Eric Sunshine,
Galan Rémi
Check if commits were removed (i.e. a line was deleted) and print
warnings or abort git rebase depending on the value of the
configuration variable rebase.missingCommits.
This patch gives the user the possibility to avoid silent loss of
information (losing a commit through deleting the line in this case)
if he wants to.
Add the configuration variable rebase.missingCommitsCheck.
- When unset or set to "ignore", no checking is done.
- When set to "warn", the commits are checked, warnings are
displayed but git rebase still proceeds.
- When set to "error", the commits are checked, warnings are
displayed and the rebase is aborted.
rebase.missingCommitsCheck defaults to "ignore".
Signed-off-by: Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr>
---
Documentation/config.txt | 10 ++++++
Documentation/git-rebase.txt | 6 ++++
git-rebase--interactive.sh | 82 +++++++++++++++++++++++++++++++++++++++++++
t/t3404-rebase-interactive.sh | 63 +++++++++++++++++++++++++++++++++
4 files changed, 161 insertions(+)
diff --git a/Documentation/config.txt b/Documentation/config.txt
index 4d21ce1..b29cd8d 100644
--- a/Documentation/config.txt
+++ b/Documentation/config.txt
@@ -2160,6 +2160,16 @@ rebase.autoStash::
successful rebase might result in non-trivial conflicts.
Defaults to false.
+rebase.missingCommitsCheck::
+ If set to "warn", git rebase -i will print a warning if some
+ commits are removed (e.g. a line was deleted), however the
+ rebase will still proceed. If set to "error", it will print
+ the previous warning and abort the rebase. If set to
+ "ignore", no checking is done.
+ To drop a commit without warning or error, use the `drop`
+ command in the todo-list.
+ Defaults to "ignore".
+
receive.advertiseAtomic::
By default, git-receive-pack will advertise the atomic push
capability to its clients. If you don't want to this capability
diff --git a/Documentation/git-rebase.txt b/Documentation/git-rebase.txt
index 9cf3760..6d413a1 100644
--- a/Documentation/git-rebase.txt
+++ b/Documentation/git-rebase.txt
@@ -213,6 +213,12 @@ rebase.autoSquash::
rebase.autoStash::
If set to true enable '--autostash' option by default.
+rebase.missingCommitsCheck::
+ If set to "warn" print warnings about removed commits in
+ interactive mode. If set to "error" print the warnings and
+ abort the rebase. If set to "ignore" no checking is
+ done. "ignore" by default.
+
OPTIONS
-------
--onto <newbase>::
diff --git a/git-rebase--interactive.sh b/git-rebase--interactive.sh
index 869cc60..26804dd 100644
--- a/git-rebase--interactive.sh
+++ b/git-rebase--interactive.sh
@@ -851,6 +851,86 @@ add_exec_commands () {
mv "$1.new" "$1"
}
+# Print the list of the SHA-1 of the commits
+# from a todo list in a file.
+# $1: todo-file, $2: outfile
+todo_list_to_sha_list () {
+ git stripspace --strip-comments <"$1" | while read -r command sha1 rest
+ do
+ case $command in
+ x|"exec")
+ ;;
+ *)
+ printf "%s\n" "$sha1"
+ ;;
+ esac
+ done >"$2"
+}
+
+# Use warn for each line of a file
+# $1: file
+warn_file () {
+ while read -r line
+ do
+ warn " - $line"
+ done <"$1"
+}
+
+# Check if the user dropped some commits by mistake
+# Behaviour determined by rebase.missingCommitsCheck.
+check_commits () {
+ checkLevel=$(git config --get rebase.missingCommitsCheck)
+ checkLevel=${checkLevel:-ignore}
+ # Don't be case sensitive
+ checkLevel=$(echo "$checkLevel" | tr 'A-Z' 'a-z')
+
+ case "$checkLevel" in
+ warn|error)
+ # Get the SHA-1 of the commits
+ todo_list_to_sha_list "$todo".backup "$todo".oldsha1
+ todo_list_to_sha_list "$todo" "$todo".newsha1
+
+ # Sort the SHA-1 and compare them
+ sort -u "$todo".oldsha1 >"$todo".oldsha1+
+ mv "$todo".oldsha1+ "$todo".oldsha1
+ sort -u "$todo".newsha1 >"$todo".newsha1+
+ mv "$todo".newsha1+ "$todo".newsha1
+ comm -2 -3 "$todo".oldsha1 "$todo".newsha1 >"$todo".miss
+
+ # Make the list user-friendly
+ opt="--no-walk=sorted --format=oneline --abbrev-commit --stdin"
+ git rev-list $opt <"$todo".miss >"$todo".miss+
+ mv "$todo".miss+ "$todo".miss
+
+ # Check missing commits
+ if test -s "$todo".miss
+ then
+ warn "Warning: some commits may have been dropped" \
+ "accidentally."
+ warn "Dropped commits (newer to older):"
+ warn_file "$todo".miss
+ warn ""
+ warn "To avoid this message, use \"drop\" to" \
+ "explicitly remove a commit."
+ warn "Use git --config rebase.missingCommitsCheck to change" \
+ "the level of warnings (ignore, warn, error)."
+ warn ""
+
+ if test "$checkLevel" = error
+ then
+ die_abort "Rebase aborted due to dropped commits."
+ fi
+ fi
+ ;;
+ ignore)
+ ;;
+ *)
+ warn "Unrecognized setting $checkLevel for option" \
+ "rebase.missingCommitsCheck."
+ ;;
+ esac
+}
+
# The whole contents of this file is run by dot-sourcing it from
# inside a shell function. It used to be that "return"s we see
# below were not inside any function, and expected to return
@@ -1096,6 +1176,8 @@ has_action "$todo" ||
expand_todo_ids
+check_commits
+
test -d "$rewritten" || test -n "$force_rebase" || skip_unnecessary_picks
GIT_REFLOG_ACTION="$GIT_REFLOG_ACTION: checkout $onto_name"
diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
index 8960083..f369d2c 100755
--- a/t/t3404-rebase-interactive.sh
+++ b/t/t3404-rebase-interactive.sh
@@ -1112,4 +1112,67 @@ test_expect_success 'drop' '
test A = $(git cat-file commit HEAD^^ | sed -ne \$p)
'
+cat >expect <<EOF
+Successfully rebased and updated refs/heads/tmp2.
+EOF
+
+test_expect_success 'rebase -i respects rebase.missingCommitsCheck=ignore' '
+ test_config rebase.missingCommitsCheck ignore &&
+ test_when_finished "git checkout master &&
+ git branch -D tmp2" &&
+ git checkout -b tmp2 master &&
+ set_fake_editor &&
+ FAKE_LINES="1 2 3 4" \
+ git rebase -i --root 2>warning &&
+ test D = $(git cat-file commit HEAD | sed -ne \$p) &&
+ test_cmp warning expect
+'
+
+cat >expect <<EOF
+Warning: some commits may have been dropped accidentally.
+Dropped commits (newer to older):
+ - $(git rev-list --pretty=oneline --abbrev-commit -1 master)
+
+To avoid this message, use "drop" to explicitly remove a commit.
+Use git --config rebase.missingCommitsCheck to change the level of warnings (ignore, warn, error).
+
+Successfully rebased and updated refs/heads/tmp2.
+EOF
+
+test_expect_success 'rebase -i respects rebase.missingCommitsCheck=warn' '
+ test_config rebase.missingCommitsCheck warn &&
+ test_when_finished "git checkout master &&
+ git branch -D tmp2" &&
+ git checkout -b tmp2 master &&
+ set_fake_editor &&
+ FAKE_LINES="1 2 3 4" \
+ git rebase -i --root 2>warning &&
+ test D = $(git cat-file commit HEAD | sed -ne \$p) &&
+ test_cmp warning expect
+'
+
+cat >expect <<EOF
+Warning: some commits may have been dropped accidentally.
+Dropped commits (newer to older):
+ - $(git rev-list --pretty=oneline --abbrev-commit -1 master)
+ - $(git rev-list --pretty=oneline --abbrev-commit -1 master~2)
+
+To avoid this message, use "drop" to explicitly remove a commit.
+Use git --config rebase.missingCommitsCheck to change the level of warnings (ignore, warn, error).
+
+Rebase aborted due to dropped commits.
+EOF
+
+test_expect_success 'rebase -i respects rebase.missingCommitsCheck=error' '
+ test_config rebase.missingCommitsCheck error &&
+ test_when_finished "git checkout master &&
+ git branch -D tmp2" &&
+ git checkout -b tmp2 master &&
+ set_fake_editor &&
+ test_must_fail env FAKE_LINES="1 2 4" \
+ git rebase -i --root 2>warning &&
+ test E = $(git cat-file commit HEAD | sed -ne \$p) &&
+ test_cmp warning expect
+'
+
test_done
--
2.4.2.389.geaf7ccf
^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-03 11:44 ` [PATCH/RFCv4 2/2] git rebase -i: warn about removed commits Galan Rémi
@ 2015-06-03 19:14 ` Eric Sunshine
2015-06-03 20:09 ` Remi Galan Alfonso
0 siblings, 1 reply; 14+ messages in thread
From: Eric Sunshine @ 2015-06-03 19:14 UTC (permalink / raw)
To: Galan Rémi
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano
On Wednesday, June 3, 2015, Galan Rémi
<remi.galan-alfonso@ensimag.grenoble-inp.fr> wrote:
> Check if commits were removed (i.e. a line was deleted) and print
> warnings or abort git rebase depending on the value of the
> configuration variable rebase.missingCommits.
A few comments below in addition to those already made by Matthieu...
> diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
> index 8960083..f369d2c 100755
> --- a/t/t3404-rebase-interactive.sh
> +++ b/t/t3404-rebase-interactive.sh
> @@ -1112,4 +1112,67 @@ test_expect_success 'drop' '
> test A = $(git cat-file commit HEAD^^ | sed -ne \$p)
> '
>
> +cat >expect <<EOF
> +Successfully rebased and updated refs/heads/tmp2.
> +EOF
> +
> +test_expect_success 'rebase -i respects rebase.missingCommitsCheck=ignore' '
> + test_config rebase.missingCommitsCheck ignore &&
> + test_when_finished "git checkout master &&
> + git branch -D tmp2" &&
Strange indentation.
> + git checkout -b tmp2 master &&
> + set_fake_editor &&
> + FAKE_LINES="1 2 3 4" \
> + git rebase -i --root 2>warning &&
The file containing the actual output is usually spelled "actual".
> + test D = $(git cat-file commit HEAD | sed -ne \$p) &&
> + test_cmp warning expect
The arguments to test_cmp are usually reversed so that 'expect' comes
before 'actual', which results in a more natural-feeling diff when
test_cmp detects that the files differ.
These comments apply to remaining new tests, as well.
> +'
> +
> +cat >expect <<EOF
> +Warning: some commits may have been dropped accidentally.
> +Dropped commits (newer to older):
> + - $(git rev-list --pretty=oneline --abbrev-commit -1 master)
> +
> +To avoid this message, use "drop" to explicitly remove a commit.
> +Use git --config rebase.missingCommitsCheck to change the level of warnings (ignore, warn, error).
> +
> +Successfully rebased and updated refs/heads/tmp2.
> +EOF
> +
> +test_expect_success 'rebase -i respects rebase.missingCommitsCheck=warn' '
> + test_config rebase.missingCommitsCheck warn &&
> + test_when_finished "git checkout master &&
> + git branch -D tmp2" &&
> + git checkout -b tmp2 master &&
> + set_fake_editor &&
> + FAKE_LINES="1 2 3 4" \
> + git rebase -i --root 2>warning &&
> + test D = $(git cat-file commit HEAD | sed -ne \$p) &&
> + test_cmp warning expect
> +'
> +
> +cat >expect <<EOF
> +Warning: some commits may have been dropped accidentally.
> +Dropped commits (newer to older):
> + - $(git rev-list --pretty=oneline --abbrev-commit -1 master)
> + - $(git rev-list --pretty=oneline --abbrev-commit -1 master~2)
> +
> +To avoid this message, use "drop" to explicitly remove a commit.
> +Use git --config rebase.missingCommitsCheck to change the level of warnings (ignore, warn, error).
> +
> +Rebase aborted due to dropped commits.
> +EOF
> +
> +test_expect_success 'rebase -i respects rebase.missingCommitsCheck=error' '
> + test_config rebase.missingCommitsCheck error &&
> + test_when_finished "git checkout master &&
> + git branch -D tmp2" &&
> + git checkout -b tmp2 master &&
> + set_fake_editor &&
> + test_must_fail env FAKE_LINES="1 2 4" \
> + git rebase -i --root 2>warning &&
> + test E = $(git cat-file commit HEAD | sed -ne \$p) &&
> + test_cmp warning expect
> +'
> +
> test_done
> --
> 2.4.2.389.geaf7ccf
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-03 19:14 ` [PATCH/RFCv2 " Eric Sunshine
@ 2015-06-03 20:09 ` Remi Galan Alfonso
2015-06-06 23:45 ` Remi Galan Alfonso
0 siblings, 1 reply; 14+ messages in thread
From: Remi Galan Alfonso @ 2015-06-03 20:09 UTC (permalink / raw)
To: Eric Sunshine
Cc: Git List, Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano
Eric Sunshine <sunshine@sunshineco.com> writes:
> > +test_expect_success 'rebase -i respects rebase.missingCommitsCheck=ignore' '
> > + test_config rebase.missingCommitsCheck ignore &&
> > + test_when_finished "git checkout master &&
> > + git branch -D tmp2" &&
>
> Strange indentation.
Considering that 'git branch -D tmp2' is a part of test_when_finished,
I wasn't sure of how it was supposed to be indented, so I did it this
way to show that it was still within test_when_finished and not a
separate command.
> test_when_finished "git checkout master &&
> git branch -D tmp2" &&
Doesn't seem as clear, especially if you quickly read the lines.
For now, I have removed the tab.
Also the other points have been corrected.
Thank you,
Rémi
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-03 20:09 ` Remi Galan Alfonso
@ 2015-06-06 23:45 ` Remi Galan Alfonso
0 siblings, 0 replies; 14+ messages in thread
From: Remi Galan Alfonso @ 2015-06-06 23:45 UTC (permalink / raw)
To: Git List
Cc: Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano
I'm going to try to change the die_abort in this patch by a die, so
that the user can use rebase --edit-todo afterward. This way, adding
the checking on the SHA-1 for the 'drop' command (discussed in 1/2)
(and also maybe the other commands requiring a correct SHA-1
corresponding to a commit) to the 2/2 part would make a bit more
sense. Though I still see some other issues with this, I agree that it
makes more sense in 2/2 rather than in 1/2 (some more checking in a
future patch would be a good idea).
(So far I've tried rather quickly, but it doesn't seem as easy as I
originally though, working on it though)
Rémi
^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH/RFCv2 0/2] rebase -i : drop command and removed commits
@ 2015-06-01 9:57 Galan Rémi
2015-06-01 9:57 ` [PATCH/RFCv2 2/2] git rebase -i: warn about " Galan Rémi
0 siblings, 1 reply; 14+ messages in thread
From: Galan Rémi @ 2015-06-01 9:57 UTC (permalink / raw)
To: Git List
Cc: Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley, Eric Sunshine,
Stephen Kelly
- [PATCH 1/2] git-rebase -i: add command "drop" to remove a commit
The 'drop' command is added as a way to explicitely remove commits in
git rebase -i.
This patch does not prevent users from commenting the line, removing
the line or using the 'noop' command if they want to.
While the 'noop' command has the same effect, it doesn't seem to be
the right use for it since 'noop' merely ignores everything that
follows, in particular writing 'noop <SHA-1> <text>' can be confusing.
Commenting a line also has the same effect but the 2/2 part of the
patch is not made for working correctly with comments (though it still
works with 'noop').
This command is inspired by the command 'drop' in histedit of
Mercurial (though in the idea, it is not made to make migrants from
Mercurial feel better but rather because it seems like a good idea).
For the 'drop' command, maybe instead of just doing the same thing as
noop, checking if the SHA-1 that supposedly follow does exist could be
a good idea.
- [PATCH 2/2] git rebase -i: warn about removed commits
Since the default behaviour is 'ignore', meaning that no checking is
done and no warning is displayed, users that are used to remove the
lines to remove a commit can still do so without changing their
configuration.
However this patch gives the user the possibility to avoid silent loss
of information if he wants.
Regarding the comments of v1 : The dupplicated commits are not checked
anymore ((about the review by Eric Sunshine) thus the error case stays
within the warning test, now that we only have one test for warnings).
The list of removed commits is now shown in the format '<short SHA-1>
<commit-message>' instead of '<full SHA-1>', this was done following
an idea given by Matthieu Moy outside of the mailing list.
Because of this some code have been added and modified and thus need
reviewing.
A test has been added to check the correct behaviour of the error
configuration.
^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits
2015-06-01 9:57 [PATCH/RFCv2 0/2] rebase -i : drop command and " Galan Rémi
@ 2015-06-01 9:57 ` Galan Rémi
0 siblings, 0 replies; 14+ messages in thread
From: Galan Rémi @ 2015-06-01 9:57 UTC (permalink / raw)
To: Git List
Cc: Remi Lespinet, Guillaume Pages, Louis-Alexandre Stuber,
Antoine Delaite, Matthieu Moy, Junio C Hamano,
Johannes Schindelin, Stefan Beller, Philip Oakley, Eric Sunshine,
Stephen Kelly, Galan Rémi
Check if commits were removed (i.e. a line was deleted) and print
warnings or abort git rebase according to the value of the
configuration variable rebase.checkLevel.
Add the configuration variable rebase.checkLevel.
- When unset or set to "ignore", no checking is done.
- When set to "warn", the commits are checked, warnings are
displayed but git rebase still proceeds.
- When set to "error", the commits are checked, warnings are
displayed and the rebase is aborted.
rebase.checkLevel defaults to "ignore".
Signed-off-by: Galan Rémi <remi.galan-alfonso@ensimag.grenoble-inp.fr>
---
Documentation/config.txt | 9 ++++
Documentation/git-rebase.txt | 6 +++
git-rebase--interactive.sh | 105 ++++++++++++++++++++++++++++++++++++++++++
t/t3404-rebase-interactive.sh | 10 +++-
4 files changed, 129 insertions(+), 1 deletion(-)
diff --git a/Documentation/config.txt b/Documentation/config.txt
index 5f76e8c..e2e5554 100644
--- a/Documentation/config.txt
+++ b/Documentation/config.txt
@@ -2160,6 +2160,15 @@ rebase.autoStash::
successful rebase might result in non-trivial conflicts.
Defaults to false.
+rebase.checkLevel::
+ If set to "warn", git rebase -i will print a warning if some
+ commits are removed (i.e. a line was deleted) or if some
+ commits appear more than one time (e.g. the same commit is
+ picked twice), however the rebase will still proceed. If set
+ to "error", it will print the previous warnings and abort the
+ rebase. If set to "ignore", no checking is done. Defaults to
+ "ignore".
+
receive.advertiseAtomic::
By default, git-receive-pack will advertise the atomic push
capability to its clients. If you don't want to this capability
diff --git a/Documentation/git-rebase.txt b/Documentation/git-rebase.txt
index 9cf3760..d348ca2 100644
--- a/Documentation/git-rebase.txt
+++ b/Documentation/git-rebase.txt
@@ -213,6 +213,12 @@ rebase.autoSquash::
rebase.autoStash::
If set to true enable '--autostash' option by default.
+rebase.checkLevel::
+ If set to "warn" print warnings about removed commits and
+ duplicated commits in interactive mode. If set to "error"
+ print the warnings and abort the rebase. If set to "ignore" no
+ checking is done. "ignore" by default.
+
OPTIONS
-------
--onto <newbase>::
diff --git a/git-rebase--interactive.sh b/git-rebase--interactive.sh
index 2882276..58da6ee 100644
--- a/git-rebase--interactive.sh
+++ b/git-rebase--interactive.sh
@@ -837,6 +837,109 @@ add_exec_commands () {
mv "$1.new" "$1"
}
+# Print the list of the SHA-1 of the commits
+# from a todo list in a file.
+# $1: todo-file, $2: outfile
+todo_list_to_sha_list () {
+ todo_list=$(git stripspace --strip-comments <"$1")
+ temp_file=$(mktemp)
+ echo "$todo_list" >$temp_file
+ while read -r command sha1 rest
+ do
+ case $command in
+ x|"exec")
+ ;;
+ *)
+ printf "%s\n" "$sha1"
+ ;;
+ esac
+ done <$temp_file >"$2"
+ rm $temp_file
+}
+
+# Transforms SHA-1 list in argument
+# to a list of commits (in place)
+# Doesn't check if the SHA-1 are commits.
+# $1: file with long SHA-1 list
+long_sha_to_commit_list () {
+ short_missing=""
+ git_command="git show --oneline"
+ get_line_command="head -n 1"
+ temp_file=$(mktemp)
+ while read -r sha
+ do
+ if test -n "$sha"
+ then
+ commit=$($git_command $sha | $get_line_command)
+ if test -n "$commit"
+ then
+ printf "%s\n" "$commit"
+ fi
+ fi
+ done <"$1" >$temp_file
+ mv $temp_file "$1"
+}
+
+# Use warn for each line of a file
+# $1: file to warn
+warn_file () {
+ while read -r line
+ do
+ warn " - $line"
+ done <"$1"
+}
+
+# Check if the user dropped some commits by mistake
+# Behaviour determined by .gitconfig.
+check_commits () {
+ checkLevel=$(git config --get rebase.checkLevel)
+ checkLevel=${checkLevel:-ignore}
+ # To lowercase
+ checkLevel=$(echo "$checkLevel" | tr 'A-Z' 'a-z')
+
+ case "$checkLevel" in
+ warn|error)
+ # Get the SHA-1 of the commits
+ todo_list_to_sha_list "$todo".backup "$todo".oldsha1
+ todo_list_to_sha_list "$todo" "$todo".newsha1
+
+ # Sort the SHA-1 and compare them
+ echo "$(sort -u "$todo".oldsha1)" >"$todo".oldsha1
+ echo "$(sort -u "$todo".newsha1)" >"$todo".newsha1
+ echo "$(comm -2 -3 "$todo".oldsha1 "$todo".newsha1)" >"$todo".miss
+
+ # Make the list user-friendly
+ long_sha_to_commit_list "$todo".miss
+
+ # Check missing commits
+ if test -s "$todo".miss
+ then
+ warn "Warning : some commits may have been dropped" \
+ "accidentally."
+ warn "Dropped commits (in no relevent order):"
+ warn_file "$todo".miss
+ warn ""
+ warn "To avoid this message, use \"drop\" to" \
+ "explicitly remove a commit."
+ warn "Use git --config rebase.checkLevel to change" \
+ "the level of warnings (ignore,warn,error)."
+ warn ""
+
+ if test "$checkLevel" = error
+ then
+ die_abort "Rebase aborted due to dropped commits."
+ fi
+ fi
+ ;;
+ ignore)
+ ;;
+ *)
+ warn "Unrecognized setting $checkLevel for option" \
+ "rebase.checkLevel in git rebase -i."
+ ;;
+ esac
+}
+
# The whole contents of this file is run by dot-sourcing it from
# inside a shell function. It used to be that "return"s we see
# below were not inside any function, and expected to return
@@ -1079,6 +1182,8 @@ has_action "$todo" ||
expand_todo_ids
+check_commits
+
test -d "$rewritten" || test -n "$force_rebase" || skip_unnecessary_picks
GIT_REFLOG_ACTION="$GIT_REFLOG_ACTION: checkout $onto_name"
diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
index 1bad068..d3a9ed5 100755
--- a/t/t3404-rebase-interactive.sh
+++ b/t/t3404-rebase-interactive.sh
@@ -1103,7 +1103,6 @@ test_expect_success 'rebase -i commits that overwrite untracked files (no ff)' '
'
test_expect_success 'drop' '
- git checkout master &&
test_when_finished "git checkout master" &&
git checkout -b dropBranchTest master &&
set_fake_editor &&
@@ -1113,4 +1112,13 @@ test_expect_success 'drop' '
test A = $(git cat-file commit HEAD^^ | sed -ne \$p)
'
+test_expect_success 'rebase -i respects rebase.checkLevel' '
+ test_config rebase.checkLevel error &&
+ test_when_finished "git checkout master" &&
+ git checkout -b tmp2 master &&
+ set_fake_editor &&
+ test_must_fail env FAKE_LINES="1 2 3 4" git rebase -i --root &&
+ test E = $(git cat-file commit HEAD | sed -ne \$p)
+'
+
test_done
--
2.4.1.363.g9535a9c
^ permalink raw reply related [flat|nested] 14+ messages in thread
end of thread, other threads:[~2015-06-06 23:45 UTC | newest]
Thread overview: 14+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-06-01 11:52 [PATCH/RFCv2 1/2] git-rebase -i: add command "drop" to remove a commit Galan Rémi
2015-06-01 11:52 ` [PATCH/RFCv2 2/2] git rebase -i: warn about removed commits Galan Rémi
2015-06-01 23:16 ` Eric Sunshine
2015-06-01 23:17 ` Eric Sunshine
2015-06-02 7:42 ` Remi Galan Alfonso
2015-06-02 13:41 ` Eric Sunshine
2015-06-02 13:51 ` Remi Galan Alfonso
2015-06-02 6:40 ` Matthieu Moy
2015-06-02 9:23 ` Remi Galan Alfonso
2015-06-02 17:17 ` Junio C Hamano
-- strict thread matches above, loose matches on Subject: below --
2015-06-03 11:44 [PATCH/RFCv4 1/2] git-rebase -i: add command "drop" to remove a commit Galan Rémi
2015-06-03 11:44 ` [PATCH/RFCv4 2/2] git rebase -i: warn about removed commits Galan Rémi
2015-06-03 19:14 ` [PATCH/RFCv2 " Eric Sunshine
2015-06-03 20:09 ` Remi Galan Alfonso
2015-06-06 23:45 ` Remi Galan Alfonso
2015-06-01 9:57 [PATCH/RFCv2 0/2] rebase -i : drop command and " Galan Rémi
2015-06-01 9:57 ` [PATCH/RFCv2 2/2] git rebase -i: warn about " Galan Rémi
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.