What's cooking in git.git (Aug 2025, #08; Mon, 18)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Here are the topics that have been cooking in my tree.  Commits
prefixed with '+' are in 'next' (being in 'next' is a sign that a
topic is stable enough to be used and are candidate to be in a
future release).  Commits prefixed with '-' are only in 'seen', and
aren't considered "accepted" at all and may be annotated with an URL
to a message that raises issues but they are no means exhaustive.  A
topic without enough support may be discarded after a long period of
no activity (of course they can be resubmit when new interests
arise).

Git 2.51 has been tagged.  Let's see if there is any unexpected
fallout for the rest of this week, and then start merging down what
has been cooking in 'next' (and rewind 'next' while doing so).

Copies of the source code to Git live in many repositories, and the
following is a list of the ones I push into or their mirrors.  Some
repositories have only a subset of branches.

With maint, master, next, seen, todo:

	git://git.kernel.org/pub/scm/git/git.git/
	git://repo.or.cz/alt-git.git/
	https://kernel.googlesource.com/pub/scm/git/git/
	https://github.com/git/git/
	https://gitlab.com/git-scm/git/

With all the integration branches and topics broken out:

	https://github.com/gitster/git/

Even though the preformatted documentation in HTML and man format
are not sources, they are published in these repositories for
convenience (replace "htmldocs" with "manpages" for the manual
pages):

	git://git.kernel.org/pub/scm/git/git-htmldocs.git/
	https://github.com/gitster/git-htmldocs.git/

Release tarballs are available at:

	https://www.kernel.org/pub/software/scm/git/

--------------------------------------------------
[New Topics]

* ds/doc-count-objects-fix (2025-08-14) 1 commit
  (merged to 'next' on 2025-08-17 at 1740ef34dd)
 + count-objects: document count-objects pack

 Docfix.

 Will cook in 'next'.
 source: <pull.2031.v3.git.git.1755182034719.gitgitgadget@xxxxxxxxx>


* ad/t1517-short-help-tests-fix (2025-08-16) 1 commit
  (merged to 'next' on 2025-08-17 at b38fb9afd3)
 + t/t1517: mark tests that fail with GIT_TEST_INSTALLED
 (this branch uses ua/t1517-short-help-tests.)

 Test fix.

 Will merge to 'next'?
 source: <20250808010651.591906-1-usmanakinyemi202@xxxxxxxxx>

--------------------------------------------------
[Cooking]

* dk/t7005-editor-updates (2025-08-13) 3 commits
  (merged to 'next' on 2025-08-17 at ad0ab2e2a9)
 + t7005: sanitize test environment for subsequent tests
 + t7005: stop abusing --exec-path
 + t7005: use modern test style

 Test clean-up.

 Will cook in 'next'.
 source: <20250812170256.71751-1-ben.knoble+github@xxxxxxxxx>


* kr/clone-synopsis-fix (2025-08-11) 1 commit
  (merged to 'next' on 2025-08-13 at b0d634ef29)
 + docs: remove stray bracket from git-clone synopsis

 Doc fix.

 Will cook in 'next'.
 source: <pull.2023.v3.git.git.1754949872593.gitgitgadget@xxxxxxxxx>


* ac/deglobal-fmt-merge-log-config (2025-08-10) 2 commits
  (merged to 'next' on 2025-08-13 at c6c74fb8f0)
 + builtin/fmt-merge-msg: stop depending on 'the_repository'
 + environment: remove the global variable 'merge_log_config'

 Code clean-up.

 Will cook in 'next'.
 source: <cover.1754868681.git.ayu.chandekar@xxxxxxxxx>


* jc/longer-disambiguation-fix (2025-08-14) 1 commit
 - abbrev: allow extending beyond 32 chars to disambiguate

 "git rev-parse --short" and friends failed to disambiguate two
 objects with object names that share common prefix longer than 32
 characters.

 Will merge to 'next'?
 source: <xmqqh5ya6iua.fsf_-_@gitster.g>


* dl/push-missing-object-error (2025-08-08) 3 commits
  (merged to 'next' on 2025-08-11 at ad69d77794)
 + remote.c: convert if-else ladder to switch
 + remote.c: remove BUG in show_push_unqualified_ref_name_error()
 + t5516: remove surrounding empty lines in test bodies

 "git push" had a code path that led to BUG() but it should have
 been a die(), as it is a response to a usual but invalid end-user
 action to attempt pushing an object that does not exist.

 Will cook in 'next'.
 cf. <xmqqo6spiyqp.fsf@gitster.g>
 source: <cover.1754637849.git.liu.denton@xxxxxxxxx>


* ja/doc-lint-sections-and-synopsis (2025-08-11) 6 commits
  (merged to 'next' on 2025-08-17 at 413ff100cd)
 + doc lint: check that synopsis manpages have synopsis inlines
 + doc:git-for-each-ref: fix styling and typos
 + doc: check for absence of the form --[no-]parameter
 + doc: check for absence of multiple terms in each entry of desc list
 + doc: check well-formedness of delimited sections
 + doc: test linkgit macros for well-formedness

 Doc lint updates to encourage the newer and easier-to-use
 `synopsis` format, with fixes to a handful of existing uses.

 Will cook in 'next'.
 source: <pull.1945.v3.git.1754945600.gitgitgadget@xxxxxxxxx>


* js/rebase-i-allow-drop-on-a-merge (2025-08-06) 1 commit
  (merged to 'next' on 2025-08-07 at bc44e9dc1b)
 + rebase -i: permit 'drop' of a merge commit

 During interactive rebase, using 'drop' on a merge commit lead to
 an error, which was incorrect.

 Will cook in 'next'.
 source: <37f6e34c-91aa-4e55-88e1-019d2e042df3@xxxxxxxx>


* ms/refs-list (2025-08-05) 6 commits
  (merged to 'next' on 2025-08-13 at 3f0791145b)
 + t: add test for git refs list subcommand
 + t6300: refactor tests to be shareable
 + builtin/refs: add list subcommand
 + builtin/for-each-ref: factor out core logic into a helper
 + builtin/for-each-ref: align usage string with the man page
 + doc: factor out common option

 The "list" subcommand of "git refs" acts as a front-end for
 "git for-each-ref".

 Will cook in 'next'.
 source: <20250805092758.5321-1-meetsoni3017@xxxxxxxxx>


* kh/doc-git-log-markup-fix (2025-08-08) 1 commit
  (merged to 'next' on 2025-08-12 at 1336146ed4)
 + doc: git-log: fix description list

 Doc update.

 Will cook in 'next'.
 source: <aaa1734189ec8bab7cfa0965132e3d8e5909b1af.1754660514.git.code@xxxxxxxxxxxxxxx>


* ly/changed-path-traversal-with-magic-pathspec (2025-08-10) 1 commit
  (merged to 'next' on 2025-08-12 at 0f929dcec7)
 + bloom: enable bloom filter with wildcard pathspec in revision traversal

 Revision traversal limited with pathspec, like "git log dir/*",
 used to ignore changed-paths Bloom filter when the pathspec
 contained wildcards; now they take advantage of the filter when
 they can.

 Will cook in 'next'.
 source: <20250811060137.75135-1-yldhome2d2@xxxxxxxxx>


* ps/commit-graph-wo-globals (2025-08-14) 6 commits
  (merged to 'next' on 2025-08-17 at e2889596be)
 + commit-graph: stop passing in redundant repository
 + commit-graph: stop using `the_repository`
 + commit-graph: stop using `the_hash_algo`
 + commit-graph: refactor `parse_commit_graph()` to take a repository
 + commit-graph: store the hash algorithm instead of its length
 + commit-graph: stop using `the_hash_algo` via macros

 Remove dependency on the_repository and other globals from the
 commit-graph code, and other changes unrelated to de-globaling.

 Will cook in 'next'.
 source: <20250815-b4-pks-commit-graph-wo-the-repository-v4-0-b6b651178cce@xxxxxx>


* tc/t0450-harden (2025-08-12) 3 commits
 - fixup! t0450: add allowlist for builtins with missing .adoc
 - t0450: add allowlist for builtins with missing .adoc
 - t0450: fix test for out-of-tree builds

 Test updates.

 Expecting a reroll after 2.51 final.
 source: <20250804073002.1586332-1-toon@xxxxxxxxx>


* gh/git-jump-pathname-with-sp (2025-08-11) 1 commit
  (merged to 'next' on 2025-08-13 at a99311e231)
 + git-jump: make `diff` work with filenames containing spaces

 "git jump" (in contrib/) fails to parse the diff header correctly
 when a file has a space in its name, which has been corrected.

 Will cook in 'next'.
 source: <pull.1950.v2.git.1754913323810.gitgitgadget@xxxxxxxxx>


* jc/diff-no-index-in-subdir (2025-08-09) 1 commit
  (merged to 'next' on 2025-08-13 at 956899dc16)
 + diff: --no-index should ignore the worktree

 "git diff --no-index" run inside a subdirectory under control of a
 Git repository operated at the top of the working tree and stripped
 the prefix from the output, and oddballs like "-" (stdin) did not
 work correctly because of it.  Correct the set-up by undoing what
 the set-up sequence did to cwd and prefix.

 Will cook in 'next'.
 source: <xmqq1ppk58ob.fsf@gitster.g>


* je/doc-rebase (2025-08-15) 5 commits
 - doc: git-rebase: update discussion of internals
 - doc: git-rebase: move --onto explanation down
 - doc: git rebase: clarify arguments syntax
 - doc: git rebase: dedup merge conflict discussion
 - doc: git-rebase: start with an example

 Documentation for "git rebase" has been updated.

 Will merge to 'next'?
 source: <pull.1949.v8.git.1755276750.gitgitgadget@xxxxxxxxx>


* rj/t6137-cygwin-fix (2025-08-08) 1 commit
  (merged to 'next' on 2025-08-12 at f5acbbb35a)
 + t6137-*.sh: fix test failure on cygwin

 Test fix for breakage introduced in Git 2.50.

 Will cook in 'next'.
 source: <5514f2fd-3307-42c8-97ac-bc2147a7ba41@xxxxxxxxxxxxxxxxxxxx>


* ps/reftable-libgit2-cleanup (2025-08-12) 8 commits
 - refs/reftable: always reload stacks when creating lock
 - reftable: don't second-guess errors from flock interface
 - reftable/stack: handle outdated stacks when compacting
 - reftable/stack: allow passing flags to `reftable_stack_add()`
 - reftable/stack: fix compiler warning due to missing braces
 - reftable/stack: reorder code to avoid forward declarations
 - reftable/writer: drop Git-specific `QSORT()` macro
 - reftable/writer: fix type used for number of records

 Code clean-ups.

 Will merge to 'next'?
 source: <20250812-pks-reftable-fixes-for-libgit2-v3-0-cf3b2267867e@xxxxxx>


* tc/diff-tree-max-depth (2025-08-07) 3 commits
  (merged to 'next' on 2025-08-15 at dddb2275d4)
 + diff: teach tree-diff a max-depth parameter
 + within_depth: fix return for empty path
 + combine-diff: zero memory used for callback filepairs

 "git diff-tree" learned "--max-depth" option.

 Will cook in 'next'.
 source: <20250807-toon-max-depth-v2-0-50b7e5c81665@xxxxxxxxx>


* dk/help-all (2025-08-03) 3 commits
  (merged to 'next' on 2025-08-13 at 6dce87c0b5)
 + builtin: also setup gently for --help-all
 + parse-options: refactor flags for usage_with_options_internal
 + Merge branch 'ua/t1517-short-help-tests' into dk/help-all
 (this branch uses ua/t1517-short-help-tests.)

 "git cmd --help-all" outside repository.

 Will cook in 'next'.
 source: <20250803012613.54086-1-ben.knoble+github@xxxxxxxxx>


* lc/rebase-trailer (2025-08-03) 2 commits
 - rebase: support --trailer
 - trailer: append trailers in-process and drop the fork to `interpret-trailers`

 Expecting a reroll.
 cf. <198826af571.62b85cb31711042.2415806544948206668@linux.beauty>
 source: <20250803150059.402017-1-me@linux.beauty>


* ly/diff-name-only-with-diff-from-content (2025-08-07) 1 commit
  (merged to 'next' on 2025-08-13 at 662b1ed5c5)
 + diff: ensure consistent diff behavior with ignore options

 Various options to "git diff" that makes comparison ignore certain
 aspects of the differences (like "space changes are ignored",
 "differences in lines that match these regular expressions are
 ignored") did not work well with "--name-only" and friends.

 Will cook in 'next'.
 source: <20250808033019.78817-1-yldhome2d2@xxxxxxxxx>


* rs/describe-with-prio-queue (2025-08-03) 2 commits
  (merged to 'next' on 2025-08-07 at 5ebcaaf8b8)
 + describe: use prio_queue_replace()
 + describe: use prio_queue

 "git describe" has been optimized by using better data structure.

 Will cook in 'next'.
 source: <36d5b59a-a99a-4a6f-b637-dfb0b760660f@xxxxxx>


* ps/object-store-midx-dedup-info (2025-08-11) 11 commits
 - midx: compute paths via their source
 - midx: stop duplicating info redundant with its owning source
 - midx: write multi-pack indices via their source
 - midx: load multi-pack indices via their source
 - midx: drop redundant `struct repository` parameter
 - odb: simplify calling `link_alt_odb_entry()`
 - odb: return newly created in-memory sources
 - odb: consistently use "dir" to refer to alternate's directory
 - odb: allow `odb_find_source()` to fail
 - odb: store locality in object database sources
 - Merge branch 'ps/object-store-midx' into ps/object-store-midx-dedup-info

 Further code clean-up for multi-pack-index code paths.

 Will merge to 'next'?
 source: <20250811-b4-pks-midx-deduplicate-source-info-v3-0-e442bdf2b4ad@xxxxxx>


* jc/strbuf-split (2025-07-31) 13 commits
  (merged to 'next' on 2025-08-11 at ddf662f7e9)
 + trace2: do not use strbuf_split*()
 + trace2: trim_trailing_newline followed by trim is a no-op
 + sub-process: do not use strbuf_split*()
 + environment: do not use strbuf_split*()
 + config: do not use strbuf_split()
 + notes: do not use strbuf_split*()
 + merge-tree: do not use strbuf_split*()
 + clean: do not use strbuf_split*() [part 2]
 + clean: do not pass the whole structure when it is not necessary
 + clean: do not use strbuf_split*() [part 1]
 + clean: do not pass strbuf by value
 + wt-status: avoid strbuf_split*()
 + Merge branch 'jc/string-list-split' into jc/strbuf-split
 (this branch uses jc/string-list-split.)

 Arrays of strbuf is often a wrong data structure to use, and
 strbuf_split*() family of functions that create them often have
 better alternatives.

 Update several code paths and replace strbuf_split*().

 Will cook in 'next'.
 source: <20250731225433.4028872-1-gitster@xxxxxxxxx>


* jc/string-list-split (2025-08-01) 7 commits
  (merged to 'next' on 2025-08-11 at 160ff9d174)
 + string-list: split-then-remove-empty can be done while splitting
 + string-list: optionally omit empty string pieces in string_list_split*()
 + diff: simplify parsing of diff.colormovedws
 + string-list: optionally trim string pieces split by string_list_split*()
 + string-list: unify string_list_split* functions
 + string-list: align string_list_split() with its _in_place() counterpart
 + string-list: report programming error with BUG
 (this branch is used by jc/strbuf-split.)

 string_list_split*() family of functions have been extended to
 simplify common use cases.

 Will cook in 'next'.
 source: <20250801220423.1230969-1-gitster@xxxxxxxxx>


* am/xdiff-hash-tweak (2025-07-28) 2 commits
 - xdiff: optimize xdl_hash_record_verbatim
 - xdiff: refactor xdl_hash_record()

 Inspired by Ezekiel's recent effort to showcase Rust interface, the
 hash function implementation used to hash lines have been updated
 to the one used for ELF symbol lookup by Glibc.

 Still being discussed (AUG13)
 cf. <b118903c-a50a-4ae4-b41e-1c47c37218c4@xxxxxxxxx>
 source: <20250728190520.10962-1-amonakov@xxxxxxxxx>


* ps/remote-rename-fix (2025-07-31) 7 commits
  (merged to 'next' on 2025-08-07 at 227d2faf29)
 + builtin/remote: only iterate through refs that are to be renamed
 + builtin/remote: rework how remote refs get renamed
 + builtin/remote: determine whether refs need renaming early on
 + builtin/remote: fix sign comparison warnings
 + refs: simplify logic when migrating reflog entries
 + refs: pass refname when invoking reflog entry callback
 + Merge branch 'ps/reflog-migrate-fixes' into ps/remote-rename-fix
 (this branch uses ps/reflog-migrate-fixes.)

 "git remote rename origin upstream" failed to move origin/HEAD to
 upstream/HEAD when origin/HEAD is unborn and performed other
 renames extremely inefficiently, which has been corrected.

 Will cook in 'next'.
 source: <20250731-pks-remote-rename-improvements-v2-0-dda6f083674d@xxxxxx>


* ag/send-email-imap-sent (2025-08-11) 2 commits
 - send-email: enable copying emails to an IMAP folder without actually sending them
 - send-email: add ability to send a copy of sent emails to an IMAP folder

 "git send-email" learned to drive "git imap-send" to store already
 sent e-mails in an IMAP folder.

 Will merge to 'next'?
 source: <PN3PR01MB9597E8E33868386C997D2563B82BA@xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx>


* en/ort-rename-fixes (2025-08-06) 7 commits
  (merged to 'next' on 2025-08-12 at 02536ed675)
 + merge-ort: fix directory rename on top of source of other rename/delete
 + merge-ort: fix incorrect file handling
 + merge-ort: clarify the interning of strings in opt->priv->path
 + t6423: fix missed staging of file in testcases 12i,12j,12k
 + t6423: document two bugs with rename-to-self testcases
 + merge-ort: drop unnecessary temporary in check_for_directory_rename()
 + merge-ort: update comments to modern testfile location

 Various bugs about rename handling in "ort" merge strategy have
 been fixed.

 Will cook in 'next'.
 source: <pull.1943.v3.git.1754522122.gitgitgadget@xxxxxxxxx>


* ps/reflog-migrate-fixes (2025-08-05) 9 commits
  (merged to 'next' on 2025-08-07 at 8068e2ad68)
 + refs: fix invalid old object IDs when migrating reflogs
 + refs: stop unsetting REF_HAVE_OLD for log-only updates
 + refs/files: detect race when generating reflog entry for HEAD
 + refs: fix identity for migrated reflogs
 + ident: fix type of string length parameter
 + builtin/reflog: implement subcommand to write new entries
 + refs: export `ref_transaction_update_reflog()`
 + builtin/reflog: improve grouping of subcommands
 + Documentation/git-reflog: convert to use synopsis type
 (this branch is used by ps/remote-rename-fix.)

 "git refs migrate" to migrate the reflog entries from a refs
 backend to another had a handful of bugs squashed.

 Will cook in 'next'.
 source: <20250806-pks-reflog-append-v6-0-a50839653766@xxxxxx>


* ds/sparse-checkout-clean (2025-07-16) 9 commits
 - sparse-checkout: make 'clean' clear more files
 - t: expand tests around sparse merges and clean
 - sparse-index: point users to new 'clean' action
 - sparse-checkout: add --verbose option to 'clean'
 - dir: add generic "walk all files" helper
 - sparse-checkout: match some 'clean' behavior
 - sparse-checkout: add basics of 'clean' command
 - sparse-checkout: remove use of the_repository
 - Merge branch 'ac/deglobal-sparse-variables' into ds/sparse-checkout-clean
 (this branch uses ac/deglobal-sparse-variables.)

 "git sparse-checkout" subcommand learned a new "clean" action to
 prune otherwise unused working-tree files that are outside the
 areas of interest.

 Needs to wait for the base topic to solidify.
 source: <pull.1941.v2.git.1752716054.gitgitgadget@xxxxxxxxx>


* pw/3.0-commentchar-auto-deprecation (2025-07-31) 4 commits
 - commit: print advice when core.commentString=auto
 - config: warn on core.commentString=auto
 - breaking-changes: deprecate support for core.commentString=auto
 - Merge branch 'ps/config-wo-the-repository' into pw/3.0-commentchar-auto-deprecation

 Proposes to deprecate "core.commentChar=auto" that attempts to
 dynamically pick a suitable comment character, as it is too much
 trouble to support for little benefit.

 Will merge to 'next'?
 source: <cover.1753975294.git.phillip.wood@xxxxxxxxxxxxx>


* ua/t1517-short-help-tests (2025-08-07) 3 commits
  (merged to 'next' on 2025-08-12 at 55d20e1985)
 + t5304: move `prune -h` test from t1517
 + t5200: move `update-server-info -h` test from t1517
 + t/t1517: automate `git subcmd -h` tests outside a repository
 (this branch is used by ad/t1517-short-help-tests-fix and dk/help-all.)

 Test shuffling.

 Will cook in 'next'.
 source: <20250808010651.591906-1-usmanakinyemi202@xxxxxxxxx>


* tc/last-modified (2025-08-05) 4 commits
 - fixup! last-modified: new subcommand to show when files were last modified
 - last-modified: use Bloom filters when available
 - t/perf: add last-modified perf script
 - last-modified: new subcommand to show when files were last modified

 A new command "git last-modified" is proposed to show the closest
 ancestor commit that touched each path.
 source: <20250730175510.987383-1-toon@xxxxxxxxx>


* lo/repo-info (2025-08-16) 5 commits
 - repo: add the --format flag
 - repo: add the field layout.shallow
 - repo: add the field layout.bare
 - repo: add the field references.format
 - repo: declare the repo command

 A new subcommand "git repo" gives users a way to grab various
 repository characteristics.

 Will merge to 'next'?
 source: <20250816224603.3307-1-lucasseikioshiro@xxxxxxxxx>


* ac/deglobal-sparse-variables (2025-07-18) 3 commits
 - environment: remove the global variable 'sparse_expect_files_outside_of_patterns'
 - environment: move access to "core.sparsecheckoutcone" into repo_settings
 - environment: move access to "core.sparsecheckout" into repo_settings
 (this branch is used by ds/sparse-checkout-clean.)

 Two global variables related to sparse checkout have been moved to
 the repository settings structure.

 Expecting a reroll.
 cf. <CAE7as+bnG6KgA8X_n36pqP15bmyM6re+xEb1MOXKvZSUdJ8Arg@xxxxxxxxxxxxxx>
 source: <cover.1752882401.git.ayu.chandekar@xxxxxxxxx>


* tb/prepare-midx-pack-cleanup (2025-05-28) 5 commits
 - midx: return a `packed_git` pointer from `prepare_midx_pack()`
 - midx-write.c: extract inner loop from fill_packs_from_midx()
 - midx-write.c: guard against incremental MIDXs in want_included_pack()
 - midx: access pack names through `nth_midxed_pack_name()`
 - Merge branch 'ps/midx-negative-packfile-cache' into tb/prepare-midx-pack-cleanup

 Improvement on Multi-pack-index API.

 Expecting a reroll.
 cf. <20250530065034.GC1321283@xxxxxxxxxxxxxxxxxxxxxxx>
 source: <cover.1748473122.git.me@xxxxxxxxxxxx>


* cc/promisor-remote-capability (2025-07-31) 5 commits
 - promisor-remote: use string constants for 'name' and 'url' too
 - promisor-remote: allow a client to check fields
 - promisor-remote: refactor how we parse advertised fields
 - promisor-remote: allow a server to advertise more fields
 - promisor-remote: refactor to get rid of 'struct strvec'

 The "promisor-remote" capability mechanism has been updated to
 allow the "partialCloneFilter" settings and the "token" value to be
 communicated from the server side.

 Expecting a reroll.
 source: <20250731072401.3817074-1-christian.couder@xxxxxxxxx>




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux