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.42 will be released early next week. 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-vcs/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'] * ps/revision-stdin-with-options (2023-08-16) 1 commit (merged to 'next' on 2023-08-16 at 6eef21f632) + rev-list-options: fix typo in `--stdin` documentation Typofix to documentation added during this cycle. source: <b1b3f1d10b64e63c62db0105957a4ad5e0295d34.1692194193.git.martin.agren@xxxxxxxxx> * sa/doc-ls-remote (2023-08-16) 1 commit (merged to 'next' on 2023-08-16 at 059ebeb48b) + show-ref doc: fix carets in monospace Mark-up fix to documentation added during this cycle. source: <f52247af9027192d0a29b8ee049db20250314d74.1692194193.git.martin.agren@xxxxxxxxx> * tl/notes-separator (2023-08-16) 2 commits (merged to 'next' on 2023-08-16 at 397c62dd35) + notes doc: tidy up `--no-stripspace` paragraph + notes doc: split up run-on sentences Typo/grammofix to documentation added during this cycle. source: <cover.1692194193.git.martin.agren@xxxxxxxxx> -------------------------------------------------- [New Topics] * jc/diff-exit-code-with-w-fixes (2023-08-18) 5 commits - diff: the -w option breaks --exit-code for --raw and other output modes - t4040: remove test that succeeded for a wrong reason - diff: teach "--stat -w --exit-code" to notice differences - diff: mode-only change should be noticed by "--patch -w --exit-code" - diff: move the fallback "--exit-code" code down "git diff -w --exit-code" with various options did not work correctly, which is being addressed. Needs review. source: <20230818235932.3253552-1-gitster@xxxxxxxxx> * jc/update-index-show-index-version (2023-08-18) 3 commits - test-tool: retire "index-version" - update-index: add --show-index-version - update-index doc: v4 is OK with JGit and libgit2 "git update-index" learns "--show-index-version" to inspect the index format version used by the on-disk index file. Needs review. source: <20230818233729.2766281-1-gitster@xxxxxxxxx> -------------------------------------------------- [Stalled] * ob/send-email-interactive-failure (2023-08-09) 1 commit . send-email: prompt-dependent exit codes "git send-email" exits with non-zero status when end-user interaction causes any prepared message not to be sent. Expecting a reroll. Without an opt-in fix, this will be a backward-incompatible change that needs mention in the release notes. source: <20230809171531.2564739-1-oswald.buddenhagen@xxxxxx> * ob/sequencer-empty-hint-fix (2023-08-09) 1 commit . sequencer: rectify empty hint in call of require_clean_work_tree() Update the use of API for consistency between two calls to require_clean_work_tree() from the sequencer code. Expecting a reroll. cf. <xmqqedkahoio.fsf@gitster.g> source: <20230809171531.2564829-1-oswald.buddenhagen@xxxxxx> * cc/git-replay (2023-06-03) 15 commits - replay: stop assuming replayed branches do not diverge - replay: add --contained to rebase contained branches - replay: add --advance or 'cherry-pick' mode - replay: disallow revision specific options and pathspecs - replay: use standard revision ranges - replay: make it a minimal server side command - replay: remove HEAD related sanity check - replay: remove progress and info output - replay: add an important FIXME comment about gpg signing - replay: don't simplify history - replay: introduce pick_regular_commit() - replay: die() instead of failing assert() - replay: start using parse_options API - replay: introduce new builtin - t6429: remove switching aspects of fast-rebase No reviews? source: <20230602102533.876905-1-christian.couder@xxxxxxxxx> * tk/cherry-pick-sequence-requires-clean-worktree (2023-06-01) 1 commit - cherry-pick: refuse cherry-pick sequence if index is dirty "git cherry-pick A" that replays a single commit stopped before clobbering local modification, but "git cherry-pick A..B" did not, which has been corrected. Expecting a reroll. cf. <999f12b2-38d6-f446-e763-4985116ad37d@xxxxxxxxx> source: <pull.1535.v2.git.1685264889088.gitgitgadget@xxxxxxxxx> -------------------------------------------------- [Cooking] * ob/revert-of-revert-is-reapply (2023-08-11) 3 commits - SQUASH??? reword by Linus Arver and Phillip Wood - doc: revert: add discussion - sequencer: beautify subject of reverts of reverts Tweak the default log message created by "git revert" when reverting a commit that records a revert. Expecting a hopefully final reroll, without the [3/2]. source: <20230428083528.1699221-1-oswald.buddenhagen@xxxxxx> * ob/format-patch-description-file (2023-08-11) 1 commit - format-patch: add --description-file option "git format-patch" learns a way to feed cover letter description, that (1) can be used on detached HEAD where there is no branch description available, and (2) also can override the branch description if there is one. Expecting a reroll. cf. <ZNa2VQQzZmaMzM4C@ugly> source: <20230809171530.2564724-1-oswald.buddenhagen@xxxxxx> * ds/scalar-updates (2023-08-14) 2 commits - setup: add discover_git_directory_reason() - scalar: add --[no-]src option Scalar updates. Expecting a reroll. cf. <abae52d5-47d5-4439-9d2b-68bb6e1c96fa@xxxxxxxxxx> source: <pull.1569.git.1692025937.gitgitgadget@xxxxxxxxx> * ja/worktree-orphan (2023-08-13) 1 commit (merged to 'next' on 2023-08-18 at b2a6f7fb71) + builtin/worktree.c: fix typo in "forgot fetch" msg Typofix in an error message. Will cook in 'next'. source: <20230811233940.30264-1-jacobabel@xxxxxxxxxx> * jc/mv-d-to-d-error-message-fix (2023-08-11) 1 commit - mv: fix error for moving directory to another Typofix in an error message. Will merge to 'next'. source: <xmqqjzu1njt0.fsf@gitster.g> * ob/t9001-indent-fix (2023-08-13) 1 commit (merged to 'next' on 2023-08-18 at 00c1cf4fe7) + t9001: fix indentation in test_no_confirm() Test style fix. Will cook in 'next'. source: <20230813104649.2919412-1-oswald.buddenhagen@xxxxxx> * sl/sparse-check-attr (2023-08-11) 3 commits - check-attr: integrate with sparse-index - attr.c: read attributes in a sparse directory - t1092: add tests for 'git check-attr' Teach "git check-attr" work better with sparse-index. Will merge to 'next'. cf. <3b2a5b4b-ab8f-746b-6b69-8e8262b6390b@xxxxxxxxxx> Looking good. source: <20230811142211.4547-1-cheskaqiqi@xxxxxxxxx> * ob/sequencer-rearrange-cleanup (2023-08-09) 1 commit (merged to 'next' on 2023-08-09 at df4360945c) + sequencer: simplify allocation of result array in todo_list_rearrange_squash() Code clean-up. Will cook in 'next'. source: <20230809171532.2564880-1-oswald.buddenhagen@xxxxxx> * tb/repack-geometry-cleanup (2023-08-09) 1 commit (merged to 'next' on 2023-08-13 at d79c778057) + repack: move `pack_geometry` struct to the stack Code clean-up. Will cook in 'next'. source: <2e2a760381be1f7cdae83e2f43b17d16aa8ab161.1691613149.git.me@xxxxxxxxxxxx> * ws/git-push-doc-grammofix (2023-08-09) 1 commit (merged to 'next' on 2023-08-13 at f15e9bbe75) + git-push.txt: fix grammar Doc update. Will cook in 'next'. source: <20230810012105.1423462-1-wesleys@xxxxxxxxxxxxxxx> * ws/svn-with-new-readline (2023-08-11) 1 commit - git-svn: avoid creating more than one than one Term::ReadLine object Adjust to newer Term::ReadLine to prevent it from breaking the interactive prompt code in git-svn. Not needed for correctness. source: <20230810011831.1423208-1-wesleys@xxxxxxxxxxxxxxx> * ak/pretty-decorate-more (2023-08-10) 7 commits - pretty: add pointer and tag options to %(decorate) - pretty: add %(decorate[:<options>]) format - decorate: color each token separately - decorate: avoid some unnecessary color overhead - decorate: refactor format_decorations() - pretty-formats: enclose options in angle brackets - pretty-formats: define "literal formatting code" Teach "git log --format" a customizable %(decorate) placeholder. What's the status of this thing? source: <20230810211619.19055-1-andy.koppe@xxxxxxxxx> * ds/upload-pack-error-sequence-fix (2023-08-16) 2 commits (merged to 'next' on 2023-08-16 at d0522d547d) + upload-pack: fix exit code when denying fetch of unreachable object ID (merged to 'next' on 2023-08-13 at 6c740593cf) + upload-pack: fix race condition in error messages Error message generation fix. Will cook in 'next'. source: <pull.1572.git.1691678450757.gitgitgadget@xxxxxxxxx> source: <fe028981d353158e9840eb035194ca15e6a2c15e.1692165840.git.ps@xxxxxx> * mp/rebase-label-length-limit (2023-08-10) 2 commits (merged to 'next' on 2023-08-13 at 85536da9f7) + rebase: allow overriding the maximal length of the generated labels + sequencer: truncate labels to accommodate loose refs Chomp overly long label names used in the sequencer machinery. Will cook in 'next'. source: <pull.1562.git.git.1691685300.gitgitgadget@xxxxxxxxx> * tb/commit-graph-verify-fix (2023-08-10) 4 commits (merged to 'next' on 2023-08-13 at ba45da55f5) + commit-graph: invert negated conditional + t/t5318-commit-graph.sh: test generation zero transitions during fsck + commit-graph: verify swapped zero/non-zero generation cases + commit-graph: introduce `commit_graph_generation_from_graph()` Update commit-graph verification code that detects mixture of zero and non-zero generation numbers. Will cook in 'next'. source: <cover.1691699851.git.me@xxxxxxxxxxxx> * la/trailer-cleanups (2023-08-06) 5 commits - trailer: rename *_DEFAULT enums to *_UNSPECIFIED - trailer: teach find_patch_start about --no-divider - trailer: split process_command_line_args into separate functions - trailer: split process_input_file into separate pieces - trailer: separate public from internal portion of trailer_iterator Code clean-up. Expecting a reroll. cf. <owlyy1iifq0n.fsf@xxxxxxxxxxxxxxxxxxx> source: <pull.1563.git.1691211879.gitgitgadget@xxxxxxxxx> * la/trailer-test-and-doc-updates (2023-08-10) 14 commits - SQUASH??? - trailer doc: <token> is a <key> or <keyAlias>, not both - trailer doc: separator within key suppresses default separator - trailer doc: emphasize the effect of configuration variables - trailer --unfold help: prefer "reformat" over "join" - trailer --parse docs: add explanation for its usefulness - trailer --only-input: prefer "configuration variables" over "rules" - trailer --parse help: expose aliased options - trailer --no-divider help: describe usual "---" meaning - trailer: trailer location is a place, not an action - trailer doc: narrow down scope of --where and related flags - trailer: add tests to check defaulting behavior with --no-* flags - trailer test description: this tests --where=after, not --where=before - trailer tests: make test cases self-contained Test coverage improvement for trailers. Expecting a reroll. cf. <owlyh6p5fpi7.fsf@xxxxxxxxxxxxxxxxxxx> source: <pull.1564.v2.git.1691702283.gitgitgadget@xxxxxxxxx> * ds/maintenance-schedule-fuzz (2023-08-10) 8 commits (merged to 'next' on 2023-08-18 at 8d17424818) + maintenance: update schedule before config + maintenance: fix systemd schedule overlaps + maintenance: use random minute in systemd scheduler + maintenance: swap method locations + maintenance: use random minute in cron scheduler + maintenance: use random minute in Windows scheduler + maintenance: use random minute in launchctl scheduler + maintenance: add get_random_minute() Allow "git maintenance" schedule to be randomly distributed. Will cook in 'next'. source: <pull.1567.v2.git.1691699987.gitgitgadget@xxxxxxxxx> * rj/branch-in-use-error-message (2023-08-08) 2 commits (merged to 'next' on 2023-08-09 at 5510985b1c) + branch: error message checking out a branch in use + branch: error message deleting a branch in use A message written in olden time prevented a branch from getting checked out saying it is already checked out elsewhere, but these days, we treat a branch that is being bisected or rebased just like a branch that is checked out and protect it. Rephrase the message to say that the branch is in use. Will cook in 'next'. source: <7710c002-0832-d8f6-59b8-30119bd5efe6@xxxxxxxxx> * mh/credential-libsecret-attrs (2023-06-16) 1 commit (merged to 'next' on 2023-08-08 at dc73a2c55a) + credential/libsecret: store new attributes The way authentication related data other than passwords (e.g. oath token and password expiration data) are stored in libsecret keyrings has been rethought. Will cook in 'next'. Needs review. source: <pull.1469.v5.git.git.1686945306242.gitgitgadget@xxxxxxxxx> * jc/rerere-cleanup (2023-08-03) 4 commits - rerere: modernize use of empty strbuf - rerere: try_merge() should use LL_MERGE_ERROR when it means an error - rerere: fix comment on handle_file() helper - rerere: simplify check_one_conflict() helper function (this branch uses jc/unresolve-removal.) Code clean-up. Not ready to be reviewed yet. source: <20230731224409.4181277-1-gitster@xxxxxxxxx> * pw/rebase-i-after-failure (2023-08-01) 7 commits - rebase -i: fix adding failed command to the todo list - rebase --continue: refuse to commit after failed command - rebase: fix rewritten list for failed pick - sequencer: factor out part of pick_commits() - sequencer: use rebase_path_message() - rebase -i: remove patch file after conflict resolution - rebase -i: move unlink() calls Various fixes to the behaviour of "rebase -i" when the command got interrupted by conflicting changes. Expecting a reroll. The latter half of the series should be reviewed by those who have more stake in the sequencer code than myself. cf. <619e458b-218b-a790-dfb4-9200e201b513@xxxxxxxxx> source: <pull.1492.v3.git.1690903412.gitgitgadget@xxxxxxxxx> * jc/unresolve-removal (2023-07-31) 7 commits - checkout: allow "checkout -m path" to unmerge removed paths - checkout/restore: add basic tests for --merge - checkout/restore: refuse unmerging paths unless checking out of the index - update-index: remove stale fallback code for "--unresolve" - update-index: use unmerge_index_entry() to support removal - resolve-undo: allow resurrecting conflicted state that resolved to deletion - update-index: do not read HEAD and MERGE_HEAD unconditionally (this branch is used by jc/rerere-cleanup.) "checkout --merge -- path" and "update-index --unresolve path" did not resurrect conflicted state that was resolved to remove path, but now they do. Needs review. source: <20230731224409.4181277-1-gitster@xxxxxxxxx> * rj/status-bisect-while-rebase (2023-08-01) 1 commit - status: fix branch shown when not only bisecting "git status" is taught to show both the branch being bisected and being rebased when both are in effect at the same time. Needs review. cf. <xmqqtttia3vn.fsf@gitster.g> source: <48745298-f12b-8efb-4e48-90d2c22a8349@xxxxxxxxx> * rs/parse-options-negation-help (2023-08-06) 8 commits (merged to 'next' on 2023-08-18 at 9d37b5fbfe) + parse-options: simplify usage_padding() + parse-options: no --[no-]no-... + parse-options: factor out usage_indent() and usage_padding() + parse-options: show negatability of options in short help + t1502: test option negation + t1502: move optionspec help output to a file + t1502, docs: disallow --no-help + subtree: disallow --no-{help,quiet,debug,branch,message} "git cmd -h" learned to signal which options can be negated by listing such options like "--[no-]opt". Will cook in 'next'. cf. <xmqqbkfm3gne.fsf@gitster.g> source: <e4d46d97-1cd4-7fea-afd1-7de5023b1b09@xxxxxx> * mh/credential-erase-improvements-more (2023-07-26) 2 commits (merged to 'next' on 2023-08-08 at fd1ba4accf) + credential/wincred: erase matching creds only + credential/libsecret: erase matching creds only Update two credential helpers to correctly match which credential to erase; they dropped not the ones with stale password. Will cook in 'next'. Needs review. source: <pull.1527.v2.git.git.1690387585634.gitgitgadget@xxxxxxxxx> source: <pull.1529.git.git.1687596777147.gitgitgadget@xxxxxxxxx> * cc/repack-sift-filtered-objects-to-separate-pack (2023-08-13) 8 commits . gc: add `gc.repackFilterTo` config option . repack: implement `--filter-to` for storing filtered out objects . gc: add `gc.repackFilter` config option . repack: add `--filter=<filter-spec>` option . repack: refactor finding pack prefix . repack: refactor finishing pack-objects command . t/helper: add 'find-pack' test-tool . pack-objects: allow `--filter` without `--stdout` "git repack" machinery learns to pay attention to the "--filter=" option. Kicked out of the 'seen', as it still seems to be failing tests. cf. https://github.com/git/git/actions/runs/5850998716/job/15861158252#step:4:1822 source: <20230812000011.1227371-1-christian.couder@xxxxxxxxx> * js/doc-unit-tests (2023-08-17) 3 commits - ci: run unit tests in CI - unit tests: add TAP unit test framework - unit tests: Add a project plan document Process to add some form of low-level unit tests has started. Comments? source: <cover.1692297001.git.steadmon@xxxxxxxxxx> * jt/path-filter-fix (2023-08-08) 8 commits (merged to 'next' on 2023-08-09 at 59952b9ec9) + commit-graph: fix small leak with invalid changedPathsVersion (merged to 'next' on 2023-08-03 at d99958c287) + commit-graph: new filter ver. that fixes murmur3 + repo-settings: introduce commitgraph.changedPathsVersion + t4216: test changed path filters with high bit paths + t/helper/test-read-graph: implement `bloom-filters` mode + bloom.h: make `load_bloom_filter_from_graph()` public + t/helper/test-read-graph.c: extract `dump_graph_info()` + gitformat-commit-graph: describe version 2 of BDAT The Bloom filter used for path limited history traversal was broken on systems whose "char" is unsigned; update the implementation and bump the format version to 2. Will cook in 'next'. cf. <ZMqp6K2iXixWH/zT@nand.local> source: <cover.1690912539.git.jonathantanmy@xxxxxxxxxx> source: <20230808192240.GA4091261@xxxxxxxxxxxxxxxxxxxxxxx> * ob/test-lib-rebase-fake-editor-updates (2023-08-10) 3 commits (merged to 'next' on 2023-08-13 at 16b87e890a) + t/lib-rebase: improve documentation of set_fake_editor() + t/lib-rebase: set_fake_editor(): handle FAKE_LINES more consistently + t/lib-rebase: set_fake_editor(): fix recognition of reset's short command Test updates. Will cook in 'next'. source: <20230807170935.2336663-1-oswald.buddenhagen@xxxxxx> source: <20230809171531.2564785-1-oswald.buddenhagen@xxxxxx> -------------------------------------------------- [Discarded] * ab/tag-object-type-errors (2023-05-10) 4 commits . tag: don't emit potentially incorrect "object is a X, not a Y" . tag: don't misreport type of tagged objects in errors . object tests: add test for unexpected objects in tags . Merge branch 'jk/parse-object-type-mismatch' into ab/tag-object-type-errors Hardening checks around mismatched object types when one of those objects is a tag. Stalled for too long. source: <cover-v2-0.3-00000000000-20221230T011725Z-avarab@xxxxxxxxx>