From: "Phillip Wood via GitGitGadget" <gitgitgadget@gmail.com>
To: git@vger.kernel.org
Cc: Justin Tobler <jltobler@gmail.com>,
Junio C Hamano <gitster@pobox.com>,
Phillip Wood <phillip.wood123@gmail.com>,
Phillip Wood <phillip.wood@dunelm.org.uk>
Subject: [PATCH v2 0/2] add -p: a couple of hunk splitting fixes
Date: Mon, 15 Sep 2025 15:29:02 +0000 [thread overview]
Message-ID: <pull.1863.v2.git.1757950144.gitgitgadget@gmail.com> (raw)
In-Reply-To: <pull.1863.git.1740149837.gitgitgadget@gmail.com>
Thanks to Justin and Junio for their comments in V1. Sorry for the long
delay in re-rolling - I thought I'd sent these ages ago and then discovered
that they weren't upstream and realized I had not, in fact, sent them
after-all.
Changes since V1:
* Patch 1: The new hunks created by splitting a hunk are now only marked as
"undecided" when WITH_BREAKING_CHANGES is enabled.
* Patch 2: Reworded commit message and added a space before a redirection
in the test
V1 Cover Letter:
This series fixes a couple of infelicities when splitting hunks that have
already been selected or edited which I noticed a while ago when preparing
the test for 'pw/add-patch-with-suppress-blank-empty'.
Phillip Wood (2):
add -p: mark split hunks as undecided
add-patch: update hunk splitability after editing
Documentation/BreakingChanges.adoc | 5 +++++
add-patch.c | 19 +++++++++++++++-
t/t3701-add-interactive.sh | 36 ++++++++++++++++++++++++++++++
3 files changed, 59 insertions(+), 1 deletion(-)
base-commit: 4975ec3473b4bc61bc8a3df1ef29d0b7e7959e87
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1863%2Fphillipwood%2Fadd-p-split-hunks-are-undecided-v2
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1863/phillipwood/add-p-split-hunks-are-undecided-v2
Pull-Request: https://github.com/gitgitgadget/git/pull/1863
Range-diff vs v1:
1: 43a0592a46 ! 1: 3e2ec7b37f add -p: mark split hunks as undecided
@@ Metadata
## Commit message ##
add -p: mark split hunks as undecided
- When a hunk is split each of the new hunks inherits whether it is
- selected or not from the original hunk. This means that if a selected
- hunk is split all of the new hunks are selected and the user is not asked
- whether or not they want to select the new hunks. This is unfortunate as
- the user is presumably splitting the original hunk because they only
- want to select some sub-set of it. Fix this by marking all the new hunks
- as "undecided" so that we prompt the user to decide whether to select
- them or not.
+ When a hunk is split, each of the new hunks inherits whether it is
+ selected or not from the original hunk. If a selected hunk is split
+ all of the new hunks are marked as "selected" and the user is only
+ prompted with the first of the split hunks. The user is not asked
+ whether or not they wish to select the rest of the new hunks. This
+ means that if they wish to deselect any of the new hunks apart from
+ the first one they have to navigate back to the hunk they want to
+ deselect before they can deselect it. This is unfortunate as the user
+ is presumably splitting the original hunk because they only want to
+ select some sub-set of it.
+
+ Instead mark all the new hunks as "undecided" so that the user is
+ prompted whether they wish to select each one in turn. In the case
+ where the user only wants to change the selection of the first of
+ the split hunks they will now have to do more work re-selecting the
+ remaining split hunks. However, changing the selection of any of the
+ other newly created hunks is now much simpler as the user no-longer has
+ to navigate back to them in order to change their selected state. Due
+ to concerns that users may be relying on the current behaviour [1]
+ this change is guarded by WITH_BREAKING_CHANGES.
+
+ [1] https://lore.kernel.org/git/xmqqjz9b6xr1.fsf@gitster.g
Signed-off-by: Phillip Wood <phillip.wood@dunelm.org.uk>
+ ## Documentation/BreakingChanges.adoc ##
+@@ Documentation/BreakingChanges.adoc: A prerequisite for this change is that the ecosystem is ready to support the
+ "reftable" format. Most importantly, alternative implementations of Git like
+ JGit, libgit2 and Gitoxide need to support it.
+
++* The behavior of "git add -p" has been changed so that splitting a
++ hunk that has already been marked as selected or unselected will now
++ prompt the user to select each of the new hunks created by the
++ split instead of them inheriting their state from the original hunk.
++
+ === Removals
+
+ * Support for grafting commits has long been superseded by git-replace(1).
+
## add-patch.c ##
@@ add-patch.c: static int split_hunk(struct add_p_state *s, struct file_diff *file_diff,
* sizeof(*hunk));
hunk = file_diff->hunk + hunk_index;
hunk->splittable_into = 1;
++#ifdef WITH_BREAKING_CHANGES
+ hunk->use = UNDECIDED_HUNK;
++#endif
memset(hunk + 1, 0, (splittable_into - 1) * sizeof(*hunk));
header = &hunk->header;
@@ add-patch.c: next_hunk_line:
hunk++;
hunk->splittable_into = 1;
-- hunk->use = hunk[-1].use;
++#ifdef WITH_BREAKING_CHANGES
+ hunk->use = UNDECIDED_HUNK;
++#else
+ hunk->use = hunk[-1].use;
++#endif
header = &hunk->header;
header->old_count = header->new_count = context_line_count;
## t/t3701-add-interactive.sh ##
-@@ t/t3701-add-interactive.sh: test_expect_success 'hunk splitting works with diff.suppressBlankEmpty' '
- test_cmp expect actual
- '
+@@ t/t3701-add-interactive.sh: do
+ '
+ done
-+test_expect_success 'splitting previous hunk marks split hunks as undecided' '
++test_expect_success WITH_BREAKING_CHANGES 'splitting previous hunk marks split hunks as undecided' '
+ test_write_lines a " " b c d e f g h i j k >file &&
+ git add file &&
+ test_write_lines x " " b y d e f g h i j x >file &&
2: 35ef0ee2b9 ! 2: 3a831b1a2d add-patch: update hunk splitability after editing
@@ Metadata
## Commit message ##
add-patch: update hunk splitability after editing
- When the users edits a hunk if they change deletion lines to context
- lines or vice versa then the number of hunks that the edited hunk can be
- split into may differ from the unedited hunk and so we need to update
- hunk->splittable_into. In practice users are unlikely to hit this bug as
- it is doubtful that a user who has edited a hunk will split it
- afterwards.
+ If, when the user edits a hunk, they change deletion lines into
+ context lines or vice versa, then the number of hunks that the edited
+ hunk can be split into may differ from the unedited hunk. This means
+ that so we should recalculate `hunk->splittable_into` after the hunk
+ has been edited. In practice users are unlikely to hit this bug as it
+ is doubtful that a user who has edited a hunk will split it afterwards.
Signed-off-by: Phillip Wood <phillip.wood@dunelm.org.uk>
@@ add-patch.c: static ssize_t recount_edited_hunk(struct add_p_state *s, struct hu
## t/t3701-add-interactive.sh ##
-@@ t/t3701-add-interactive.sh: test_expect_success 'splitting previous hunk marks split hunks as undecided' '
+@@ t/t3701-add-interactive.sh: test_expect_success WITH_BREAKING_CHANGES 'splitting previous hunk marks split h
test_cmp expect actual
'
@@ t/t3701-add-interactive.sh: test_expect_success 'splitting previous hunk marks s
+ mv "$1.tmp" "$1"
+ EOF
+
-+ test_write_lines a b c d e f g h i j k l m n>file &&
++ test_write_lines a b c d e f g h i j k l m n >file &&
+ git add file &&
+ test_write_lines A b c d E f g h i j k l M n >file &&
+ (
+ test_set_editor "$(pwd)/fake-editor.sh" &&
-+ test_write_lines e K s j y n y q | git add -p file
++ if test_have_prereq WITH_BREAKING_CHANGES
++ then
++ test_write_lines e K s j y n y q
++ else
++ test_write_lines e K s n K n y q
++ fi | git add -p file
+ ) &&
+ git cat-file blob :file >actual &&
+ test_write_lines a b d e f g h i j k l M n >expect &&
--
gitgitgadget
next prev parent reply other threads:[~2025-09-15 15:29 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-21 14:57 [PATCH 0/2] add -p: a couple of hunk splitting fixes Phillip Wood via GitGitGadget
2025-02-21 14:57 ` [PATCH 1/2] add -p: mark split hunks as undecided Phillip Wood via GitGitGadget
2025-02-21 19:52 ` Justin Tobler
2025-02-21 21:31 ` Junio C Hamano
2025-02-26 14:40 ` phillip.wood123
2025-02-26 16:49 ` Junio C Hamano
2025-02-27 16:22 ` phillip.wood123
2025-02-27 18:36 ` Junio C Hamano
2025-02-28 16:19 ` Phillip Wood
2025-02-28 17:06 ` Junio C Hamano
2025-03-04 10:25 ` Phillip Wood
2025-02-21 14:57 ` [PATCH 2/2] add-patch: update hunk splitability after editing Phillip Wood via GitGitGadget
2025-02-21 20:29 ` Justin Tobler
2025-02-21 21:42 ` Junio C Hamano
2025-09-15 15:29 ` Phillip Wood via GitGitGadget [this message]
2025-09-15 15:29 ` [PATCH v2 1/2] add -p: mark split hunks as undecided Phillip Wood via GitGitGadget
2025-09-15 17:44 ` Junio C Hamano
2025-09-16 9:36 ` Phillip Wood
2025-09-16 16:03 ` Junio C Hamano
2025-09-15 15:29 ` [PATCH v2 2/2] add-patch: update hunk splitability after editing Phillip Wood via GitGitGadget
2025-09-25 15:10 ` [PATCH v3 0/2] add -p: a couple of hunk splitting fixes Phillip Wood via GitGitGadget
2025-09-25 15:10 ` [PATCH v3 1/2] add -p: mark split hunks as undecided Phillip Wood via GitGitGadget
2025-09-25 18:21 ` Junio C Hamano
2025-09-26 10:12 ` Phillip Wood
2025-09-26 17:37 ` Junio C Hamano
2025-10-08 13:51 ` Phillip Wood
2025-09-25 15:10 ` [PATCH v3 2/2] add-patch: update hunk splitability after editing Phillip Wood via GitGitGadget
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=pull.1863.v2.git.1757950144.gitgitgadget@gmail.com \
--to=gitgitgadget@gmail.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=jltobler@gmail.com \
--cc=phillip.wood123@gmail.com \
--cc=phillip.wood@dunelm.org.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).