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). 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/ -------------------------------------------------- [Graduated to 'master'] * bc/stash-export-import (2025-06-11) 4 commits (merged to 'next' on 2025-06-24 at 3dfd301fa1) + builtin/stash: provide a way to import stashes from a ref + builtin/stash: provide a way to export stashes to a ref + builtin/stash: factor out revision parsing into a function + object-name: make get_oid quietly return an error An interchange format for stash entries is defined, and subcommand of "git stash" to import/export has been added. source: <20250612011221.4158484-1-sandals@xxxxxxxxxxxxxxxxxxxx> * jc/cocci-avoid-regexp-constraint (2025-06-18) 1 commit (merged to 'next' on 2025-06-23 at 9ca93f0bac) + cocci: matching (multiple) identifiers Avoid regexp_constraint and instead use comparison_constraint when listing functions to exclude from application of coccinelle rules, as spatch can be built with different regexp engine X-<. source: <xmqqbjqlexzd.fsf@gitster.g> * jc/merge-compact-summary (2025-06-12) 2 commits (merged to 'next' on 2025-06-24 at 29893fdca6) + merge/pull: extend merge.stat configuration variable to cover --compact-summary + merge/pull: add the "--compact-summary" option "git merge/pull" has been taught the "--compact-summary" option to use the compact-summary format, intead of diffstat, when showing the summary of the incoming changes. source: <20250612222537.2426059-1-gitster@xxxxxxxxx> * jk/test-seq-format (2025-06-23) 2 commits (merged to 'next' on 2025-06-24 at 6726b890cb) + test-lib: teach test_seq the -f option + t7422: replace confusing printf with echo A test helper "test_seq" function learned the "-f <fmt>" option, which allowed us to simplify a lot of test scripts. source: <20250623105516.GA654296@xxxxxxxxxxxxxxxxxxxxxxx> -------------------------------------------------- [New Topics] * jk/fix-leak-send-pack (2025-07-01) 2 commits - send-pack: clean-up even when taking an early exit - send-pack: clean up extra_have oid array Leakfix. Will merge to 'next'. source: <20250627-jk-fix-leak-send-pack-v1-1-aadcf0ed8a4b@xxxxxxxxx> * ac/prune-wo-the-repository (2025-06-30) 2 commits - builtin/prune: stop depending on 'the_repository' - repository: move 'repository_format_precious_objects' to repo scope Expecting a reroll. cf. <aGPcKgR0G72JRSlM@xxxxxx> source: <cover.1751296633.git.ayu.chandekar@xxxxxxxxx> * ag/doc-send-email (2025-06-30) 5 commits - docs: mention possible options for Proton Mail users - docs: add a paragraph explaining the `sendmailCmd` option of sendemail - docs: add an OAuth2.0 credential helper for AOL accounts - docs: add outlookidfix config option to sendemail documentation - docs: link OpenSSL's verify(1) manual page to know about -CAfile and -CApath options Documentation updates for "git send-email". Comments? source: <20250630180511.499-1-gargaditya08@xxxxxxxxx> * jj/doc-branch-markup-fix (2025-06-29) 1 commit - doc: improve formatting in branch section Doc markup fix. Will merge to 'next'. source: <20250629190445.10185-1-kuba@xxxxxxxxxxxxxxx> * rs/parse-options-precision (2025-06-29) 6 commits - parse-options: add precision handling for OPTION_COUNTUP - parse-options: add precision handling for OPTION_BITOP - parse-options: add precision handling for OPTION_NEGBIT - parse-options: add precision handling for OPTION_BIT - parse-options: add precision handling for OPTION_SET_INT - parse-options: add precision handling for PARSE_OPT_CMDMODE Define .precision to more canned parse-options type to avoid bugs coming from using a variable with a wrong type to capture the parsed values. Comments? source: <cf5cd57d-733f-4239-80f8-23bdc1523ab2@xxxxxx> * cb/ci-freebsd-update-to-14.3 (2025-06-30) 1 commit - ci: update FreeBSD image to 14.3 CI updates. Will merge to 'next'. source: <pull.2006.git.git.1751345578742.gitgitgadget@xxxxxxxxx> * kh/doc-config-subcommands (2025-07-01) 5 commits - config: mention --url in the synopsis - config: use --value instead of value-pattern - config: document --[no-]value - config: use --value=<pattern> consistently - config: document --[no-]show-names Documentation updates. Will merge to 'next'? source: <cover.1751382830.git.code@xxxxxxxxxxxxxxx> * kn/for-each-ref-skip (2025-07-01) 4 commits - for-each-ref: introduce a '--skip-until' option - refs: selectively set prefix in the seek functions - ref-cache: remove unused function 'find_ref_entry()' - refs: expose `ref_iterator` via 'refs.h' "git for-each-ref" learns "--skip-until" option to help applications that want to page its output. Comments? source: <20250701-306-git-for-each-ref-pagination-v1-0-4f0ae7c0688f@xxxxxxxxx> * tc/last-modified (2025-07-01) 5 commits . (style) fix bad changes suggested by clang-format . (style) clang-format suggested changes . 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. Comments? source: <20250630-toon-new-blame-tree-v3-0-3516025dc3bc@xxxxxxxxx> -------------------------------------------------- [Cooking] * cb/daemon-reap-children (2025-06-26) 4 commits - daemon: explicitly allow EINTR during poll() - daemon: use sigaction() to install child_handler() - compat/mingw: allow sigaction(SIGCHLD) - compat/posix.h: track SA_RESTART fallback Futz with SIGCHLD handling in "git daemon". Comments? source: <pull.2002.v3.git.git.1750927988.gitgitgadget@xxxxxxxxx> * ac/auto-comment-char-fix (2025-06-30) 1 commit - commit: avoid scanning trailing comments when 'core.commentChar' is "auto" "git commit" that concludes a conflicted merge failed to notice and remove existing comment added automatically (like "# Conflicts:") when the core.commentstring is set to 'auto'. Expecting a reroll. cf. <f22e864e-669d-457c-838e-961bbc977c4b@xxxxxxxxx> source: <20250630182527.69167-1-ayu.chandekar@xxxxxxxxx> * cb/daemon-fd-check-fix (2025-06-26) 1 commit (merged to 'next' on 2025-06-30 at 7a88e3eff9) + daemon: remove unnecesary restriction for listener fd Remove unnecessary check from "git daemon" code. Will merge to 'master'. source: <20250626095139.70751-1-carenas@xxxxxxxxx> * cb/daemon-retry-interrupted-accept (2025-06-27) 1 commit - daemon: correctly handle soft accept() errors in service_loop When "git daemon" sees a signal while attempting to accept() a new client, instead of retrying, it skipped it by mistake, which has been corrected. Will merge to 'next'. cf. <xmqqv7od452s.fsf@gitster.g> source: <20250627231404.27100-1-carenas@xxxxxxxxx> * kn/clang-format-updates (2025-06-30) 3 commits - meson: add rule to run 'git clang-format' - clang-format: add 'RemoveBracesLLVM' to the main config - clang-format: set 'ColumnLimit' to 0 Update ".clang-format" and ".editorconfig" to match our style guide a bit better. Will merge to 'next'. source: <20250630-525-make-clang-format-more-robust-v2-0-05cbcdbf7817@xxxxxxxxx> * ly/changed-paths-traversal (2025-06-27) 2 commits - bloom: optimize multiple pathspec items in revision traversal - bloom: replace struct bloom_key * with struct bloom_keyvec Lift the limitation to use changed-path filter in "git log" so that it can be used for a pathspec with multiple literal paths. Will merge to 'next'? source: <20250627062154.1121530-1-502024330056@xxxxxxxxxxxxxxxx> * mc/netrc-service-names (2025-06-25) 3 commits - contrib: better support symbolic port names in git-credential-netrc - contrib: warn for invalid netrc file ports in git-credential-netrc - contrib: use a more portable shebang for git-credential-netrc "netrc" credential helper has been improved to understand textual service names (like smtp) in addition to the numeric port numbers (like 25). Ready? source: <20250625142511.28857-1-maxim@xxxxxxxxxxxxx> * ph/fetch-prune-optim (2025-06-23) 2 commits - refs: remove old refs_warn_dangling_symref - fetch-prune: optimize dangling-ref reporting "git fetch --prune" used to be O(n^2) expensive when there are many refs, which has been corrected. Will merge to 'next'? source: <20250623234327.335490-1-phil.hord@xxxxxxxxx> * bc/use-sha256-by-default-in-3.0 (2025-07-01) 11 commits - Enable SHA-256 by default in breaking changes mode - help: add a build option for default hash - t5300: choose the built-in hash outside of a repo - t4042: choose the built-in hash outside of a repo - t1007: choose the built-in hash outside of a repo - t: default to compile-time default hash if not set - setup: use the default algorithm to initialize repo format - Use legacy hash for legacy formats - builtin: use default hash when outside a repository - hash: add a constant for the legacy hash algorithm - hash: add a constant for the default hash algorithm Prepare to flip the default hash function to SHA-256. Comments? source: <20250701212237.766774-1-sandals@xxxxxxxxxxxxxxxxxxxx> * jc/cocci-dtype (2025-06-18) 1 commit - cocci: do not directly access the .d_type member in struct dirent Catch direct access to .d_type member of struct dirent, as some non-POSIX compliant systems we support lack it, and rewrite to use DTYPE() macro, which is not quite the right thing to do. Will discard. source: <xmqq4iwcgbzb.fsf@gitster.g> * jc/coccicheck-fails-make-when-it-fails (2025-06-23) 1 commit - coccicheck: fail "make" when it fails "make coccicheck" succeeds even when spatch made suggestions, which has been updated to fail in such a case. Will merge to 'next'? source: <xmqqbjqe77vw.fsf@gitster.g> * jt/imap-send-message-fix (2025-06-20) 3 commits (merged to 'next' on 2025-06-24 at 106e5c22eb) + imap-send: improve error messages with configuration hints + imap-send: fix confusing 'store' terminology in error message + Merge branch 'ag/imap-send-resurrection' into jt/imap-send-message-fix (this branch uses ag/imap-send-resurrection.) Update some error messages from "git imap-send". Will merge to 'master'. source: <20250620155614.901816-1-joerg@xxxxxxxxxxx> * lo/repo-info (2025-06-19) 7 commits . repo-info: add field layout.shallow . repo-info: add field layout.bare . repo-info: add the field references.format . repo-info: add the --allow-empty flag . repo-info: add plaintext as an output format . repo-info: add the --format flag . repo-info: declare the repo-info command A new subcommand "git repo-info" gives users a way to grab various repository characteristics. Expecting a reroll, if only to fix "make check-docs". source: <20250619225751.99699-1-lucasseikioshiro@xxxxxxxxx> * cc/fast-import-export-signature-names (2025-06-19) 1 commit - fast-(import|export): improve on commit signature output format Clean up the way how signature on commit objects are exported to and imported from fast-import stream. Needs review. source: <20250619133630.727274-1-christian.couder@xxxxxxxxx> * ac/deglobal-sparse-variables (2025-06-30) 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 Two global variables related to sparse checkout have been moved to the repository settings structure. Breaks end-uesr facing behaviour. cf. <17b7f51c-0c3d-4d63-a501-47ce829f7345@xxxxxxxxx> source: <cover.1751309770.git.ayu.chandekar@xxxxxxxxx> * jk/submodule-remote-lookup-cleanup (2025-06-23) 7 commits (merged to 'next' on 2025-06-24 at 0354a7779f) + submodule: look up remotes by URL first + submodule: move get_default_remote_submodule() + submodule--helper: improve logic for fallback remote name + remote: remove the_repository from some functions + dir: move starts_with_dot(_dot)_slash to dir.h + remote: fix tear down of struct remote + remote: remove branch->merge_name and fix branch_release() Updating submodules from the upstream did not work well when submodule's HEAD is detached, which has been improved. Will merge to 'master'. source: <20250623-jk-submodule-helper-use-url-v4-0-133ef3d89569@xxxxxxxxx> * ow/rebase-verify-insn-fmt-before-initializing-state (2025-06-09) 1 commit - rebase: write script before initializing state "git rebase -i" with bogus rebase.instructionFormat configuration failed to produce the todo file after recording the state files, leading to confused "git status"; this has been corrected. Expecting a reroll. cf. <7e796844-97e2-4b45-a76e-4c1fcb1da3ae@xxxxxxxxx> source: <20250609221055.136074-1-oystwa@xxxxxxxxx> * bs/config-mak-freebsd (2025-06-12) 1 commit - config.mak.uname: update settings for FreeBSD Drop FreeBSD 4 support and assume we are at least at FreeBSD 6 with memmem() supported. Expecting a finalized version from Carlo? source: <xmqqv7p0bpdl.fsf_-_@gitster.g> * jc/tag-idempotent-no-op (2025-06-10) 1 commit - tag: allow idempotent "git tag" without "--force" "git tag T O" when the tag T is already pointing at the object O is a no-op; we used to but no longer error out such a request and require "--force" and instead turn it into a no-op. Comments? source: <xmqqzfefodje.fsf@gitster.g> * ss/compat-bswap-revamp (2025-06-11) 6 commits - bswap.h: provide a built-in based version of bswap32/64 if possible - bswap.h: remove optimized x86 version of bswap32/64 - bswap.h: always overwrite ntohl/ntohll macros - bswap.h: define GIT_LITTLE_ENDIAN on MSVC as little endian - bswap.h: add support for __BYTE_ORDER__ - Merge branch 'ss/revert-builtin-bswap-stuff' into ss/compat-bswap-revamp Clean-up compat/bswap.h mess. Comments? source: <20250611221444.1567638-1-sebastian@xxxxxxxxxxxxx> * ja/doc-git-log-markup (2025-06-29) 9 commits - doc: git-log: convert log config to new doc format - doc: git-log: convert diff options to new doc format - doc: git-log: convert pretty formats to new doc format - doc: git-log: convert pretty options to new doc format - doc: git-log: convert rev list options to new doc format - doc: git-log: convert line range format to new doc format - doc: git-log: convert line range options to new doc format - doc: git-log convert rev-list-description to new doc format - doc: convert git-log to new documentation format Doc mark-up updates. Comments? source: <pull.1933.v2.git.1751203241.gitgitgadget@xxxxxxxxx> * ag/imap-send-resurrection (2025-06-19) 10 commits (merged to 'next' on 2025-06-23 at 7c2003159b) + imap-send: fix minor mistakes in the logs + imap-send: display the destination mailbox when sending a message + imap-send: display port alongwith host when git credential is invoked + imap-send: add ability to list the available folders + imap-send: enable specifying the folder using the command line + imap-send: add PLAIN authentication method to OpenSSL + imap-send: add support for OAuth2.0 authentication + imap-send: gracefully fail if CRAM-MD5 authentication is requested without OpenSSL + imap-send: fix memory leak in case auth_cram_md5 fails + imap-send: fix bug causing cfg->folder being set to NULL (this branch is used by jt/imap-send-message-fix.) "git imap-send" has been broken for a long time, which has been resurrected and then taught to talk OAuth2.0 etc. Will merge to 'master'. source: <PN3PR01MB9597F9CAD0DA83152E651194B87CA@xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx> * sk/reftable-clarify-tests (2025-06-05) 10 commits - t/unit-tests: finalize migration of reftable-related tests - t/unit-tests: convert reftable stack test to use clar - t/unit-tests: convert reftable record test to use clar - t/unit-tests: convert reftable readwrite test to use clar - t/unit-tests: convert reftable table test to use clar - t/unit-tests: convert reftable pq test to use clar - t/unit-tests: convert reftable merged test to use clar - t/unit-tests: convert reftable block test to use clar - t/unit-tests: convert reftable basics test to use clar test framework - t/unit-tests: implement clar specific reftable test helper functions The reftable unit tests are now ported to the "clar" unit testing framework. Expecting a reroll. cf. <xmqqikla86id.fsf@gitster.g> source: <20250605140644.239199-1-kuforiji98@xxxxxxxxx> * ly/load-bitmap-leakfix (2025-06-30) 3 commits - pack-bitmap: add load corrupt bitmap test - pack-bitmap: reword comments in test_bitmap_commits() - pack-bitmap: fix memory leak if load_bitmap() failed Leakfix with a new and a bit invasive test. Comments? source: <pull.1962.v6.git.git.1751347929.gitgitgadget@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> * kn/fetch-push-bulk-ref-update (2025-06-20) 6 commits - receive-pack: handle reference deletions separately - refs/files: skip updates with errors in batched updates - receive-pack: use batched reference updates - send-pack: fix memory leak around duplicate refs - fetch: use batched reference updates - refs: add function to translate errors to strings "git push" and "git fetch" are taught to update refs in batches to gain performance. Will merge to 'next'. source: <20250519-501-update-git-fetch-1-to-use-partial-transactions-v3-0-6cdfd4f769b9@xxxxxxxxx> source: <20250620-6769-address-test-failures-in-the-next-branch-caused-by-batched-reference-updates-v5-0-f35ee6b59a82@xxxxxxxxx> * kj/renamed-submodule (2025-06-07) 2 commits - submodule: skip redundant active entries when pattern covers path - submodule: prevent overwriting .gitmodules entry on path reuse The case where a new submodule takes a path where used to be a completely different subproject is now dealt a bit better than before. Comments? source: <20250608032705.11990-1-jayatheerthkulkarni2005@xxxxxxxxx> * lm/add-p-context (2025-06-28) 4 commits - add-patch: add diff.context command line overrides - add-patch: respect diff.context configuration - test: use "test_config" - test: use "test_grep" "git add/etc -p" now honors diff.context configuration variable, and learns to honor -U<n> option. Ready? source: <pull.1915.v3.git.1751128486.gitgitgadget@xxxxxxxxx> * ps/contrib-sweep (2025-05-12) 11 commits (merged to 'next' on 2025-06-24 at 5d97a089a8) + contrib: remove some scripts in "stats" directory + contrib: remove "git-new-workdir" + contrib: remove "emacs" directory + contrib: remove "git-resurrect.sh" + contrib: remove "persistent-https" remote helper + contrib: remove "mw-to-git" + contrib: remove "hooks" directory + contrib: remove "thunderbird-patch-inline" + contrib: remove remote-helper stubs + contrib: remove "examples" directory + contrib: remove "remotes2config.sh" Remove bunch of stuff from contrib/ hierarchy. Will merge to 'master'. source: <20250512-pks-contrib-spring-cleanup-v3-0-32e151b0bfb0@xxxxxx> * ps/object-store (2025-07-01) 17 commits - odb: rename `read_object_with_reference()` - odb: rename `pretend_object_file()` - odb: rename `has_object()` - odb: rename `repo_read_object_file()` - odb: rename `oid_object_info()` - odb: trivial refactorings to get rid of `the_repository` - odb: get rid of `the_repository` when handling submodule sources - odb: get rid of `the_repository` when handling the primary source - odb: get rid of `the_repository` in `for_each()` functions - odb: get rid of `the_repository` when handling alternates - odb: get rid of `the_repository` in `odb_mkstemp()` - odb: get rid of `the_repository` in `assert_oid_type()` - odb: get rid of `the_repository` in `find_odb()` - odb: introduce parent pointers - object-store: rename files to "odb.{c,h}" - object-store: rename `object_directory` to `odb_source` - object-store: rename `raw_object_store` to `object_database` Code clean-up around object access API. Comments? source: <20250701-pks-object-store-wo-the-repository-v6-0-dbf3894ab4e2@xxxxxx> * cc/promisor-remote-capability (2025-06-25) 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. Ready? source: <20250625125055.1375596-1-christian.couder@xxxxxxxxx> * sj/string-list-typefix (2025-05-18) 8 commits - u-string-list: move "remove duplicates" test to "u-string-list.c" - u-string-list: move "filter string" test to "u-string-list.c" - u-string-list: move "test_split_in_place" to "u-string-list.c" - u-string-list: move "test_split" into "u-string-list.c" - string-list: enable sign compare warnings check - string-list: return index directly when inserting an existing element - string-list: remove unused "insert_at" parameter from add_entry - string-list: fix sign compare warnings for loop iterator Code and test clean-up around string-list API. Comments? source: <aCoDB9P5XV1lHMil@ArchLinux> * tb/midx-avoid-cruft-packs (2025-06-23) 9 commits - repack: exclude cruft pack(s) from the MIDX where possible - pack-objects: introduce '--stdin-packs=follow' - pack-objects: swap 'show_{object,commit}_pack_hint' - pack-objects: fix typo in 'show_object_pack_hint()' - pack-objects: perform name-hash traversal for unpacked objects - pack-objects: declare 'rev_info' for '--stdin-packs' earlier - pack-objects: factor out handling '--stdin-packs' - pack-objects: limit scope in 'add_object_entry_from_pack()' - pack-objects: use standard option incompatibility functions "pack-objects" has been taught to avoid pointing into objects in cruft packs from midx. Ready? source: <cover.1750717921.git.me@xxxxxxxxxxxx> -------------------------------------------------- [Discarded] * kn/fetch-push-bulk-ref-update-fixup (2025-06-20) 7 commits . receive-pack: handle reference deletions separately . refs/files: skip updates with errors in batched updates . Merge branch 'kn/fetch-push-bulk-ref-update' into kn/fetch-push-bulk-ref-update-fixup Follow-up fixes to the base topic. Superseded--folded into the base topic. source: <20250620-6769-address-test-failures-in-the-next-branch-caused-by-batched-reference-updates-v5-0-f35ee6b59a82@xxxxxxxxx>