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-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/ -------------------------------------------------- [New Topics] * jp/use-diff-index-in-pre-commit-sample (2023-12-03) 1 commit - hooks--pre-commit: detect non-ASCII when renaming The sample pre-commit hook that tries to catch introduction of new paths that use potentially non-portable characters did not notice an existing path getting renamed to such a problematic path, when rename detection was enabled. Will merge to 'next'. source: <pull.1291.v2.git.git.1701360836307.gitgitgadget@xxxxxxxxx> * mk/doc-gitfile-more (2023-12-03) 1 commit - doc: make the gitfile syntax easier to discover Doc update. Will merge to 'next'. source: <20231128065558.1061206-1-mk+copyleft@xxxxxxxxxxxxx> * ps/ref-tests-update-more (2023-12-03) 10 commits - t6301: write invalid object ID via `test-tool ref-store` - t5551: stop writing packed-refs directly - t5401: speed up creation of many branches - t4013: simplify magic parsing and drop "failure" - t3310: stop checking for reference existence via `test -f` - t1417: make `reflog --updateref` tests backend agnostic - t1410: use test-tool to create empty reflog - t1401: stop treating FETCH_HEAD as real reference - t1400: split up generic reflog tests from the reffile-specific ones - t0410: mark tests to require the reffiles backend Tests update. Will merge to 'next'. source: <cover.1701242407.git.ps@xxxxxx> * sh/completion-with-reftable (2023-12-03) 2 commits - completion: stop checking for reference existence via `test -f` - completion: refactor existence checks for special refs Command line completion script (in contrib/) learned to work better with the reftable backend. Expecting a reroll. source: <20231130202404.89791-1-stanhu@xxxxxxxxx> * en/header-cleanup (2023-12-03) 12 commits - treewide: remove unnecessary includes in source files - treewide: add direct includes currently only pulled in transitively - trace2/tr2_tls.h: remove unnecessary include - submodule-config.h: remove unnecessary include - pkt-line.h: remove unnecessary include - line-log.h: remove unnecessary include - http.h: remove unnecessary include - fsmonitor--daemon.h: remove unnecessary includes - blame.h: remove unnecessary includes - archive.h: remove unnecessary include - treewide: remove unnecessary includes in source files - treewide: remove unnecessary includes from header files Remove unused header "#include". Has a few interactions with topics in flight. source: <pull.1617.git.1701585682.gitgitgadget@xxxxxxxxx> * jc/revision-parse-int (2023-12-09) 1 commit - revision: parse integer arguments to --max-count, --skip, etc., more carefully The command line parser for the "log" family of commands was too loose when parsing certain numbers, e.g., silently ignoring the extra 'q' in "git log -n 1q" without complaining, which has been tightened up. Will merge to 'next'. source: <xmqq5y181fx0.fsf_-_@gitster.g> * jk/bisect-reset-fix (2023-12-09) 1 commit - bisect: always clean on reset "git bisect reset" has been taught to clean up state files and refs even when BISECT_START file is gone. Will merge to 'next'. source: <20231207065341.GA778781@xxxxxxxxxxxxxxxxxxxxxxx> * jk/implicit-true (2023-12-09) 7 commits - fsck: handle NULL value when parsing message config - trailer: handle NULL value when parsing trailer-specific config - submodule: handle NULL value when parsing submodule.*.branch - help: handle NULL value for alias.* config - trace2: handle NULL values in tr2_sysenv config callback - setup: handle NULL value when parsing extensions - config: handle NULL value when parsing non-bools (this branch is used by jk/config-cleanup.) Some codepaths did not correctly parse configuration variables specified with valueless "true", which has been corrected. Will merge to 'next'. source: <20231207071030.GA1275835@xxxxxxxxxxxxxxxxxxxxxxx> * jk/config-cleanup (2023-12-09) 9 commits - sequencer: simplify away extra git_config_string() call - gpg-interface: drop pointless config_error_nonbool() checks - push: drop confusing configset/callback redundancy - config: use git_config_string() for core.checkRoundTripEncoding - diff: give more detailed messages for bogus diff.* config - config: use config_error_nonbool() instead of custom messages - imap-send: don't use git_die_config() inside callback - git_xmerge_config(): prefer error() to die() - config: reject bogus values for core.checkstat (this branch uses jk/implicit-true.) Code clean-up around use of configuration variables. Will merge to 'next'. source: <20231207071030.GA1275835@xxxxxxxxxxxxxxxxxxxxxxx> source: <20231207072338.GA1277727@xxxxxxxxxxxxxxxxxxxxxxx> * jk/end-of-options (2023-12-09) 1 commit - parse-options: decouple "--end-of-options" and "--" "git log --end-of-options --rev -- --path" learned to interpret "--rev" as a rev, and "--path" as a path, as expected. Will merge to 'next'. source: <20231206222145.GA136253@xxxxxxxxxxxxxxxxxxxxxxx> * ps/clone-into-reftable-repository (2023-12-09) 7 commits - builtin/clone: create the refdb with the correct object format - builtin/clone: skip reading HEAD when retrieving remote - builtin/clone: set up sparse checkout later - builtin/clone: fix bundle URIs with mismatching object formats - remote-curl: rediscover repository when fetching refs - setup: allow skipping creation of the refdb - setup: extract function to create the refdb "git clone" has been prepared to allow cloning a repository with non-default hash function into a repository that uses the reftable backend. Will merge to 'next'? source: <cover.1701863960.git.ps@xxxxxx> * rs/incompatible-options-messages (2023-12-09) 7 commits - worktree: simplify incompatibility message for --orphan and commit-ish - worktree: standardize incompatibility messages - clean: factorize incompatibility message - revision, rev-parse: factorize incompatibility messages about - -exclude-hidden - revision: use die_for_incompatible_opt3() for - -graph/--reverse/--walk-reflogs - repack: use die_for_incompatible_opt3() for -A/-k/--cruft - push: use die_for_incompatible_opt4() for - -delete/--tags/--all/--mirror Clean-up code that handles combinations of incompatible options. Will merge to 'next'. source: <20231206115215.94467-1-l.s.r@xxxxxx> -------------------------------------------------- [Stalled] * pw/rebase-sigint (2023-09-07) 1 commit - rebase -i: ignore signals when forking subprocesses If the commit log editor or other external programs (spawned via "exec" insn in the todo list) receive internactive signal during "git rebase -i", it caused not just the spawned program but the "Git" process that spawned them, which is often not what the end user intended. "git" learned to ignore SIGINT and SIGQUIT while waiting for these subprocesses. Expecting a reroll. cf. <12c956ea-330d-4441-937f-7885ab519e26@xxxxxxxxx> source: <pull.1581.git.1694080982621.gitgitgadget@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> * jc/diff-cached-fsmonitor-fix (2023-09-15) 3 commits - diff-lib: fix check_removed() when fsmonitor is active - Merge branch 'jc/fake-lstat' into jc/diff-cached-fsmonitor-fix - Merge branch 'js/diff-cached-fsmonitor-fix' into jc/diff-cached-fsmonitor-fix (this branch uses jc/fake-lstat.) The optimization based on fsmonitor in the "diff --cached" codepath is resurrected with the "fake-lstat" introduced earlier. It is unknown if the optimization is worth resurrecting, but in case... source: <xmqqr0n0h0tw.fsf@gitster.g> -------------------------------------------------- [Cooking] * ad/merge-file-diff-algo (2023-11-22) 1 commit - merge-file: add --diff-algorithm option "git merge-file" learned to take the "--diff-algorithm" option to use algorithm different from the default "myers" diff. Will merge to 'next'. source: <pull.1606.v2.git.git.1700507932937.gitgitgadget@xxxxxxxxx> * ak/p4-initial-empty-commits (2023-11-23) 1 commit - git-p4: fix fast import when empty commit is first Expecting a reroll. source: <pull.1609.git.git.1700639764041.gitgitgadget@xxxxxxxxx> * jc/checkout-B-branch-in-use (2023-12-09) 3 commits - fixup! checkout: forbid "-B <branch>" from touching a branch used elsewhere - checkout: forbid "-B <branch>" from touching a branch used elsewhere - checkout: refactor die_if_checked_out() caller "git checkout -B <branch> [<start-point>]" allowed a branch that is in use in another worktree to be updated and checked out, which might be a bit unexpected. The rule has been tightened, which is a breaking change. "--ignore-other-worktrees" option is required to unbreak you, if you are used to the current behaviour that "-B" overrides the safety. Needs review. source: <xmqqjzq9cl70.fsf@gitster.g> * jh/trace2-redact-auth (2023-11-23) 4 commits - t0212: test URL redacting in EVENT format - t0211: test URL redacting in PERF format - trace2: redact passwords from https:// URLs by default - trace2: fix signature of trace2_def_param() macro trace2 streams used to record the URLs that potentially embed authentication material, which has been corrected. Will merge to 'next'. source: <pull.1616.git.1700680717.gitgitgadget@xxxxxxxxx> * ps/commit-graph-less-paranoid (2023-11-26) 1 commit - commit-graph: disable GIT_COMMIT_GRAPH_PARANOIA by default Earlier we stopped relying on commit-graph that (still) records information about commits that are lost from the object store, which has negative performance implications. The default has been flipped to disable this pessimization. Will merge to 'next'. source: <17e08289cd59d20de0de9b4e18f5e6bf77987351.1700823746.git.ps@xxxxxx> * ps/reftable-fixes (2023-11-22) 8 commits - reftable/stack: fix stale lock when dying - reftable/merged: reuse buffer to compute record keys - reftable/stack: reuse buffers when reloading stack - reftable/stack: perform auto-compaction with transactional interface - reftable/stack: verify that `reftable_stack_add()` uses auto-compaction - reftable: handle interrupted writes - reftable: handle interrupted reads - reftable: wrap EXPECT macros in do/while Bunch of small fix-ups to the reftable code. Needs review. source: <cover.1700549493.git.ps@xxxxxx> * en/complete-sparse-checkout (2023-12-03) 4 commits - completion: avoid user confusion in non-cone mode - completion: avoid misleading completions in cone mode - completion: fix logic for determining whether cone mode is active - completion: squelch stray errors in sparse-checkout completion Command line completion (in contrib/) learned to complete path arguments to the "add/set" subcommands of "git sparse-checkout" better. Will merge to 'next'. source: <pull.1349.v3.git.1701583024.gitgitgadget@xxxxxxxxx> * jb/reflog-expire-delete-dry-run-options (2023-11-26) 1 commit - builtin/reflog.c: fix dry-run option short name Command line parsing fix for "git reflog". Will merge to 'next'. source: <20231126000514.85509-1-josh@xxxxxxx> * jc/orphan-unborn (2023-11-24) 2 commits - orphan/unborn: fix use of 'orphan' in end-user facing messages - orphan/unborn: add to the glossary and use them consistently Doc updates to clarify what an "unborn branch" means. Comments? source: <xmqq4jhb977x.fsf@gitster.g> * rs/column-leakfix (2023-11-27) 1 commit - column: release strbuf and string_list after use Leakfix. Will merge to 'next'. source: <f087137d-a5aa-487e-a1cb-0ad7117b38ed@xxxxxx> * rs/i18n-cannot-be-used-together (2023-11-27) 1 commit - i18n: factorize even more 'incompatible options' messages Clean-up code that handles combinations of incompatible options. Will merge to 'next'. source: <e6eb12e4-bb63-473c-9c2f-965a4d5981ad@xxxxxx> * ac/fuzz-show-date (2023-11-20) 1 commit - fuzz: add new oss-fuzz fuzzer for date.c / date.h Subject approxidate() and show_date() machinery to OSS-Fuzz. Will merge to 'next'. source: <pull.1612.v4.git.1700243267653.gitgitgadget@xxxxxxxxx> * js/packfile-h-typofix (2023-11-20) 1 commit - packfile.c: fix a typo in `each_file_in_pack_dir_fn()`'s declaration Typofix. Will merge to 'next'. source: <pull.1614.git.1700226915859.gitgitgadget@xxxxxxxxx> * jw/builtin-objectmode-attr (2023-11-16) 2 commits - SQUASH??? - attr: add builtin objectmode values support The builtin_objectmode attribute is populated for each path without adding anything in .gitattributes files, which would be useful in magic pathspec, e.g., ":(attr:builtin_objectmode=100755)" to limit to executables. Will merge to 'next' after squashing the fix-up in? source: <20231116054437.2343549-1-jojwang@xxxxxxxxxx> * ps/ref-deletion-updates (2023-11-17) 4 commits - refs: remove `delete_refs` callback from backends - refs: deduplicate code to delete references - refs/files: use transactions to delete references - t5510: ensure that the packed-refs file needs locking Simplify API implementation to delete references by eliminating duplication. Will merge to 'next'. source: <cover.1699951815.git.ps@xxxxxx> * tz/send-email-negatable-options (2023-11-17) 2 commits (merged to 'next' on 2023-11-17 at f09e533e43) + send-email: avoid duplicate specification warnings + perl: bump the required Perl version to 5.8.1 from 5.8.0 Newer versions of Getopt::Long started giving warnings against our (ab)use of it in "git send-email". Bump the minimum version requirement for Perl to 5.8.1 (from September 2002) to allow simplifying our implementation. Will merge to 'master'. source: <20231116193014.470420-1-tmz@xxxxxxxxx> * js/ci-discard-prove-state (2023-11-14) 1 commit (merged to 'next' on 2023-11-14 at fade3ba143) + ci: avoid running the test suite _twice_ (this branch uses ps/ci-gitlab.) The way CI testing used "prove" could lead to running the test suite twice needlessly, which has been corrected. Will merge to 'master'. source: <pull.1613.git.1699894837844.gitgitgadget@xxxxxxxxx> * jk/chunk-bounds-more (2023-11-09) 9 commits (merged to 'next' on 2023-11-13 at 3df4b18bea) + commit-graph: mark chunk error messages for translation + commit-graph: drop verify_commit_graph_lite() + commit-graph: check order while reading fanout chunk + commit-graph: use fanout value for graph size + commit-graph: abort as soon as we see a bogus chunk + commit-graph: clarify missing-chunk error messages + commit-graph: drop redundant call to "lite" verification + midx: check consistency of fanout table + commit-graph: handle overflow in chunk_size checks (this branch is used by tb/pair-chunk-expect.) Code clean-up for jk/chunk-bounds topic. Will merge to 'master'. source: <20231109070310.GA2697602@xxxxxxxxxxxxxxxxxxxxxxx> * ps/httpd-tests-on-nixos (2023-11-11) 3 commits (merged to 'next' on 2023-11-13 at 81bd6f5334) + t9164: fix inability to find basename(1) in Subversion hooks + t/lib-httpd: stop using legacy crypt(3) for authentication + t/lib-httpd: dynamically detect httpd and modules path Portability tweak. Will merge to 'master'. source: <cover.1699596457.git.ps@xxxxxx> * ss/format-patch-use-encode-headers-for-cover-letter (2023-11-10) 1 commit (merged to 'next' on 2023-11-14 at 1a4bd59e15) + format-patch: fix ignored encode_email_headers for cover letter "git format-patch --encode-email-headers" ignored the option when preparing the cover letter, which has been corrected. Will merge to 'master'. source: <20231109111950.387219-1-contact@xxxxxxxxxxx> * ps/ban-a-or-o-operator-with-test (2023-11-11) 4 commits (merged to 'next' on 2023-11-14 at d84471baab) + Makefile: stop using `test -o` when unlinking duplicate executables + contrib/subtree: convert subtree type check to use case statement + contrib/subtree: stop using `-o` to test for number of args + global: convert trivial usages of `test <expr> -a/-o <expr>` Test and shell scripts clean-up. Will merge to 'master'. source: <cover.1699609940.git.ps@xxxxxx> * ak/rebase-autosquash (2023-11-16) 3 commits (merged to 'next' on 2023-11-17 at 3ed6e79445) + rebase: rewrite --(no-)autosquash documentation + rebase: support --autosquash without -i + rebase: fully ignore rebase.autoSquash without -i "git rebase --autosquash" is now enabled for non-interactive rebase, but it is still incompatible with the apply backend. Will merge to 'master'. source: <20231114214339.10925-1-andy.koppe@xxxxxxxxx> * vd/for-each-ref-unsorted-optimization (2023-11-16) 10 commits (merged to 'next' on 2023-11-17 at ff99420bf6) + t/perf: add perf tests for for-each-ref + ref-filter.c: use peeled tag for '*' format fields + for-each-ref: clean up documentation of --format + ref-filter.c: filter & format refs in the same callback + ref-filter.c: refactor to create common helper functions + ref-filter.c: rename 'ref_filter_handler()' to 'filter_one()' + ref-filter.h: add functions for filter/format & format-only + ref-filter.h: move contains caches into filter + ref-filter.h: add max_count and omit_empty to ref_format + ref-filter.c: really don't sort when using --no-sort "git for-each-ref --no-sort" still sorted the refs alphabetically which paid non-trivial cost. It has been redefined to show output in an unspecified order, to allow certain optimizations to take advantage of. Will merge to 'master'. source: <pull.1609.v2.git.1699991638.gitgitgadget@xxxxxxxxx> * jw/git-add-attr-pathspec (2023-11-04) 1 commit (merged to 'next' on 2023-11-13 at b61be94e4d) + attr: enable attr pathspec magic for git-add and git-stash "git add" and "git stash" learned to support the ":(attr:...)" magic pathspec. Will merge to 'master'. source: <20231103163449.1578841-1-jojwang@xxxxxxxxxx> * ps/ci-gitlab (2023-11-09) 8 commits (merged to 'next' on 2023-11-10 at ea7ed67945) + ci: add support for GitLab CI + ci: install test dependencies for linux-musl + ci: squelch warnings when testing with unusable Git repo + ci: unify setup of some environment variables + ci: split out logic to set up failed test artifacts + ci: group installation of Docker dependencies + ci: make grouping setup more generic + ci: reorder definitions for grouping functions (this branch is used by js/ci-discard-prove-state.) Add support for GitLab CI. Will merge to 'master'. source: <cover.1699514143.git.ps@xxxxxx> * ps/ref-tests-update (2023-11-03) 10 commits (merged to 'next' on 2023-11-13 at dc26e55d6f) + t: mark several tests that assume the files backend with REFFILES + t7900: assert the absence of refs via git-for-each-ref(1) + t7300: assert exact states of repo + t4207: delete replace references via git-update-ref(1) + t1450: convert tests to remove worktrees via git-worktree(1) + t: convert tests to not access reflog via the filesystem + t: convert tests to not access symrefs via the filesystem + t: convert tests to not write references via the filesystem + t: allow skipping expected object ID in `ref-store update-ref` + Merge branch 'ps/show-ref' into ps/ref-tests-update Update ref-related tests. Will merge to 'master'. source: <cover.1698914571.git.ps@xxxxxx> * jx/fetch-atomic-error-message-fix (2023-10-19) 2 commits - fetch: no redundant error message for atomic fetch - t5574: test porcelain output of atomic fetch "git fetch --atomic" issued an unnecessary empty error message, which has been corrected. Expecting an update. cf. <ZTjQIrCgSANAT8wR@tanuki> source: <ced46baeb1c18b416b4b4cc947f498bea2910b1b.1697725898.git.zhiyou.jx@xxxxxxxxxxxxxxx> * js/bugreport-in-the-same-minute (2023-10-16) 1 commit - bugreport: include +i in outfile suffix as needed Instead of auto-generating a filename that is already in use for output and fail the command, `git bugreport` learned to fuzz the filename to avoid collisions with existing files. Expecting a reroll. cf. <ZTtZ5CbIGETy1ucV.jacob@xxxxxxxxxxxxxxxx> source: <20231016214045.146862-2-jacob@xxxxxxxxxxxxxxxx> * kh/t7900-cleanup (2023-10-17) 9 commits - t7900: fix register dependency - t7900: factor out packfile dependency - t7900: fix `print-args` dependency - t7900: fix `pfx` dependency - t7900: factor out common schedule setup - t7900: factor out inheritance test dependency - t7900: create commit so that branch is born - t7900: setup and tear down clones - t7900: remove register dependency Test clean-up. Perhaps discard? cf. <655ca147-c214-41be-919d-023c1b27b311@xxxxxxxxxxxxxxxx> source: <cover.1697319294.git.code@xxxxxxxxxxxxxxx> * tb/merge-tree-write-pack (2023-10-23) 5 commits - builtin/merge-tree.c: implement support for `--write-pack` - bulk-checkin: introduce `index_tree_bulk_checkin_incore()` - bulk-checkin: introduce `index_blob_bulk_checkin_incore()` - bulk-checkin: generify `stream_blob_to_pack()` for arbitrary types - bulk-checkin: extract abstract `bulk_checkin_source` "git merge-tree" learned "--write-pack" to record its result without creating loose objects. Broken when an object created during a merge is needed to continue merge cf. <CABPp-BEfy9VOvimP9==ry_rZXu=metOQ8s=_-XiG_Pdx9c06Ww@xxxxxxxxxxxxxx> source: <cover.1698101088.git.me@xxxxxxxxxxxx> * tb/pair-chunk-expect (2023-11-10) 8 commits - midx: read `OOFF` chunk with `pair_chunk_expect()` - midx: read `OIDL` chunk with `pair_chunk_expect()` - commit-graph: read `BIDX` chunk with `pair_chunk_expect()` - commit-graph: read `GDAT` chunk with `pair_chunk_expect()` - commit-graph: read `CDAT` chunk with `pair_chunk_expect()` - commit-graph: read `OIDL` chunk with `pair_chunk_expect()` - chunk-format: introduce `pair_chunk_expect()` helper - Merge branch 'jk/chunk-bounds-more' into HEAD (this branch uses jk/chunk-bounds-more.) Further code clean-up. Needs review. source: <cover.1699569246.git.me@xxxxxxxxxxxx> * tb/path-filter-fix (2023-10-18) 17 commits - bloom: introduce `deinit_bloom_filters()` - commit-graph: reuse existing Bloom filters where possible - object.h: fix mis-aligned flag bits table - commit-graph: drop unnecessary `graph_read_bloom_data_context` - commit-graph.c: unconditionally load Bloom filters - bloom: prepare to discard incompatible Bloom filters - bloom: annotate filters with hash version - 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 - commit-graph: ensure Bloom filters are read with consistent settings - revision.c: consult Bloom filters for root commits - t/t4216-log-bloom.sh: harden `test_bloom_filters_not_used()` 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. Needs (hopefully final and quick) review. source: <cover.1697653929.git.me@xxxxxxxxxxxx> * cc/git-replay (2023-11-26) 14 commits - replay: stop assuming replayed branches do not diverge - replay: add --contained to rebase contained branches - replay: add --advance or 'cherry-pick' mode - 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: change rev walking options - 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 Introduce "git replay", a tool meant on the server side without working tree to recreate a history. Will merge to 'next'. cf. <6bfe1541-54dd-ca6b-e930-94d3038060f1@xxxxxx> source: <20231124111044.3426007-1-christian.couder@xxxxxxxxx> * ak/color-decorate-symbols (2023-10-23) 7 commits - log: add color.decorate.pseudoref config variable - refs: exempt pseudorefs from pattern prefixing - refs: add pseudorefs array and iteration functions - log: add color.decorate.ref config variable - log: add color.decorate.symbol config variable - log: use designated inits for decoration_colors - config: restructure color.decorate documentation A new config for coloring. Needs review. source: <20231023221143.72489-1-andy.koppe@xxxxxxxxx> * js/update-urls-in-doc-and-comment (2023-11-26) 4 commits - doc: refer to internet archive - doc: update links for andre-simon.de - doc: switch links to https - doc: update links to current pages Stale URLs have been updated to their current counterparts (or archive.org) and HTTP links are replaced with working HTTPS links. Will merge to 'next'. source: <pull.1589.v3.git.1700796916.gitgitgadget@xxxxxxxxx> * la/trailer-cleanups (2023-10-20) 3 commits - trailer: use offsets for trailer_start/trailer_end - trailer: find the end of the log message - commit: ignore_non_trailer computes number of bytes to ignore Code clean-up. Comments? source: <pull.1563.v5.git.1697828495.gitgitgadget@xxxxxxxxx> * eb/hash-transition (2023-10-02) 30 commits - t1016-compatObjectFormat: add tests to verify the conversion between objects - t1006: test oid compatibility with cat-file - t1006: rename sha1 to oid - test-lib: compute the compatibility hash so tests may use it - builtin/ls-tree: let the oid determine the output algorithm - object-file: handle compat objects in check_object_signature - tree-walk: init_tree_desc take an oid to get the hash algorithm - builtin/cat-file: let the oid determine the output algorithm - rev-parse: add an --output-object-format parameter - repository: implement extensions.compatObjectFormat - object-file: update object_info_extended to reencode objects - object-file-convert: convert commits that embed signed tags - object-file-convert: convert commit objects when writing - object-file-convert: don't leak when converting tag objects - object-file-convert: convert tag objects when writing - object-file-convert: add a function to convert trees between algorithms - object: factor out parse_mode out of fast-import and tree-walk into in object.h - cache: add a function to read an OID of a specific algorithm - tag: sign both hashes - commit: export add_header_signature to support handling signatures on tags - commit: convert mergetag before computing the signature of a commit - commit: write commits for both hashes - object-file: add a compat_oid_in parameter to write_object_file_flags - object-file: update the loose object map when writing loose objects - loose: compatibilty short name support - loose: add a mapping between SHA-1 and SHA-256 for loose objects - repository: add a compatibility hash algorithm - object-names: support input of oids in any supported hash - oid-array: teach oid-array to handle multiple kinds of oids - object-file-convert: stubs for converting from one object format to another Teach a repository to work with both SHA-1 and SHA-256 hash algorithms. Needs review. source: <878r8l929e.fsf@xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx> * jx/remote-archive-over-smart-http (2023-10-04) 4 commits - archive: support remote archive from stateless transport - transport-helper: call do_take_over() in connect_helper - transport-helper: call do_take_over() in process_connect - transport-helper: no connection restriction in connect_helper "git archive --remote=<remote>" learned to talk over the smart http (aka stateless) transport. Needs review. source: <cover.1696432593.git.zhiyou.jx@xxxxxxxxxxxxxxx> * jx/sideband-chomp-newline-fix (2023-10-04) 3 commits - pkt-line: do not chomp newlines for sideband messages - pkt-line: memorize sideband fragment in reader - test-pkt-line: add option parser for unpack-sideband Sideband demultiplexer fixes. Needs review. source: <cover.1696425168.git.zhiyou.jx@xxxxxxxxxxxxxxx> * js/config-parse (2023-09-21) 5 commits - config-parse: split library out of config.[c|h] - config.c: accept config_parse_options in git_config_from_stdin - config: report config parse errors using cb - config: split do_event() into start and flush operations - config: split out config_parse_options The parsing routines for the configuration files have been split into a separate file. Needs review. source: <cover.1695330852.git.steadmon@xxxxxxxxxx> * jc/fake-lstat (2023-09-15) 1 commit - cache: add fake_lstat() (this branch is used by jc/diff-cached-fsmonitor-fix.) A new helper to let us pretend that we called lstat() when we know our cache_entry is up-to-date via fsmonitor. Needs review. source: <xmqqcyykig1l.fsf@gitster.g> * js/doc-unit-tests (2023-11-10) 3 commits (merged to 'next' on 2023-11-10 at 7d00ffd06b) + ci: run unit tests in CI + unit tests: add TAP unit test framework + unit tests: add a project plan document (this branch is used by js/doc-unit-tests-with-cmake.) Process to add some form of low-level unit tests has started. Will merge to 'master'. source: <cover.1699555664.git.steadmon@xxxxxxxxxx> * js/doc-unit-tests-with-cmake (2023-11-10) 7 commits (merged to 'next' on 2023-11-10 at b4503c9c8c) + cmake: handle also unit tests + cmake: use test names instead of full paths + cmake: fix typo in variable name + artifacts-tar: when including `.dll` files, don't forget the unit-tests + unit-tests: do show relative file paths + unit-tests: do not mistake `.pdb` files for being executable + cmake: also build unit tests (this branch uses js/doc-unit-tests.) Update the base topic to work with CMake builds. Will merge to 'master'. source: <pull.1579.v3.git.1695640836.gitgitgadget@xxxxxxxxx> * jc/rerere-cleanup (2023-08-25) 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 Code clean-up. Not ready to be reviewed yet. source: <20230824205456.1231371-1-gitster@xxxxxxxxx> * rj/status-bisect-while-rebase (2023-10-16) 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. source: <2e24ca9b-9c5f-f4df-b9f8-6574a714dfb2@xxxxxxxxx> -------------------------------------------------- [Discarded] * jc/strbuf-comment-line-char (2023-11-01) 4 commits . strbuf: move env-using functions to environment.c . strbuf: make add_lines() public . strbuf_add_commented_lines(): drop the comment_line_char parameter . strbuf_commented_addf(): drop the comment_line_char parameter Code simplification that goes directly against a past libification topic. It is hard to judge because the "libification" is done piecewise without seemingly clear design principle. Will discard. source: <cover.1698791220.git.jonathantanmy@xxxxxxxxxx>