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/ -------------------------------------------------- [New Topics] * kh/doc-bundle-typofix (2024-12-02) 1 commit - Documentation/git-bundle.txt: fix word join typo Typofix. Will merge to 'next'. source: <164b94bab9214f6030909df8f1e7c476b7f79e55.1732822997.git.code@xxxxxxxxxxxxxxx> * kh/doc-update-ref-grammofix (2024-12-02) 1 commit - Documentation/git-update-ref.txt: add missing word Grammofix. Will merge to 'next'. source: <6cc7a9d60216c966bcf77675aa22a39cfa8993e2.1732906187.git.code@xxxxxxxxxxxxxxx> * ps/build-sign-compare (2024-12-03) 14 commits - t/helper: don't depend on implicit wraparound - scalar: address -Wsign-compare warnings - builtin/patch-id: fix type of `get_one_patchid()` - builtin/blame: fix type of `length` variable when emitting object ID - gpg-interface: address -Wsign-comparison warnings - daemon: fix type of `max_connections` - daemon: fix loops that have mismatching integer types - global: trivial conversions to fix `-Wsign-compare` warnings - diff.h: fix index used to loop through unsigned integer - config.mak.dev: drop `-Wno-sign-compare` - global: mark code units that generate warnings with `-Wsign-compare` - compat/win32: fix -Wsign-compare warning in "wWinMain()" - compat/regex: explicitly ignore "-Wsign-compare" warnings - git-compat-util: introduce macros to disable "-Wsign-compare" warnings Start working to make the codebase buildable with -Wsign-compare. source: <20241202-pks-sign-compare-v2-0-e7f0ad92a749@xxxxxx> * rj/strvec-splice-fix (2024-12-02) 2 commits - strvec: `strvec_splice()` to a statically initialized vector - Merge branch 'ps/leakfixes-part-10' into rj/strvec-splice-fix (this branch uses ps/leakfixes-part-10.) Correct strvec_splice() that misbehaved when the strvec is empty. Expecting a reroll. cf. <b0bd6c5d-83eb-4545-9b38-ab4e69d3882c@xxxxxxxxx> source: <37d0abbf-c703-481d-9f26-b237aac54c05@xxxxxxxxx> * jc/forbid-head-as-tagname (2024-12-03) 4 commits - tag: "git tag" refuses to use HEAD as a tagname - t5604: do not expect that HEAD can be a valid tagname - refs: drop strbuf_ prefix from helpers - refs: move ref name helpers around "git tag" has been taught to refuse to create refs/tags/HEAD as such a tag will be confusing in the context of UI provided by the Git Porcelain commands. Will merge to 'next'? source: <20241203023240.3852850-1-gitster@xxxxxxxxx> -------------------------------------------------- [Cooking] * en/fast-import-verify-path (2024-12-02) 2 commits (merged to 'next' on 2024-12-02 at 2932fa51e4) + fast-import: disallow more path components (merged to 'next' on 2024-11-27 at 8b145bb543) + fast-import: disallow "." and ".." path components "git fast-import" learned to reject paths with ".." and "." as their components to avoid creating invalid tree objects. Will merge to 'master'. source: <pull.1831.v2.git.1732561248717.gitgitgadget@xxxxxxxxx> source: <pull.1832.git.1732740464398.gitgitgadget@xxxxxxxxx> * kn/pass-repo-to-builtin-sub-sub-commands (2024-11-26) 1 commit (merged to 'next' on 2024-11-27 at 668c0913f5) + builtin: pass repository to sub commands (this branch is used by kn/midx-wo-the-repository.) Built-in Git subcommands are supplied the repository object to work with; they learned to do the same when they invoke sub-subcommands. Will merge to 'master'. source: <20241125-374-add-repository-to-subsubcommands-v1-1-637a5e22ba48@xxxxxxxxx> * ps/bisect-double-free-fix (2024-11-26) 2 commits (merged to 'next' on 2024-11-27 at e163bce018) + bisect: address Coverity warning about potential double free + Merge branch 'ps/leakfixes-part-10' into ps/bisect-double-free-fix (this branch uses ps/leakfixes-part-10.) Work around Coverity warning that would not trigger in practice. Will merge to 'master'. source: <20241125-pks-leak-fixes-address-double-free-v1-1-d33fd8ebf55b@xxxxxx> * sj/refs-symref-referent-fix (2024-11-27) 1 commit (merged to 'next' on 2024-11-28 at 65eba16b56) + ref-cache: fix invalid free operation in `free_ref_entry` A double-free that may not trigger in practice by luck has been corrected in the reference resolution code. Will merge to 'master'. source: <Z0Xd-cYPNNrxwuAB@ArchLinux> * bf/fetch-set-head-config (2024-12-02) 2 commits - fetch: add configuration for set_head behaviour - Merge branch 'bf/set-head-symref' into bf/fetch-set-head-config (this branch uses bf/set-head-symref.) "git fetch" honors "remote.<remote>.followRemoteHEAD" settings to tweak the remote-tracking HEAD in "refs/remotes/<remote>/HEAD". Will merge to 'next'. source: <20241128230806.2058962-1-bence@xxxxxxxxxxxxxx> * jc/doc-error-message-guidelines (2024-11-29) 1 commit - CodingGuidelines: a handful of error message guidelines Developer documentation update. Will merge to 'next'. source: <xmqq1pywvmhq.fsf_-_@gitster.g> * jc/doc-opt-tilde-expand (2024-11-25) 1 commit (merged to 'next' on 2024-12-02 at e345717b87) + doc: option value may be separate for valid reasons Describe a case where an option value needs to be spelled as a separate argument, i.e. "--opt val", not "--opt=val". Will merge to 'master'. source: <xmqqh67w6m4m.fsf@gitster.g> * kn/midx-wo-the-repository (2024-11-28) 10 commits - midx: inline the `MIDX_MIN_SIZE` definition - midx: pass down `hash_algo` to functions using global variables - midx: pass `repository` to `load_multi_pack_index` - midx: cleanup internal usage of `the_repository` and `the_hash_algo` - midx-write: pass down repository to `write_midx_file[_only]` - write-midx: add repository field to `write_midx_context` - midx-write: use `revs->repo` inside `read_refs_snapshot` - midx-write: pass down repository to static functions - Merge branch 'kn/pass-repo-to-builtin-sub-sub-commands' into kn/midx-wo-the-repository - Merge branch 'kn/the-repository' into kn/midx-wo-the-repository (this branch uses kn/pass-repo-to-builtin-sub-sub-commands and kn/the-repository.) Yet another "pass the repository through the callchain" topic. Will merge to 'next'? source: <20241127-374-refactor-midx-c-and-midx-write-c-to-not-depend-on-global-state-v3-0-c5a99f85009b@xxxxxxxxx> * tb/unsafe-hash-test (2024-11-21) 2 commits - t/helper/test-tool: implement sha1-unsafe helper - t/helper/test-sha1: prepare for an unsafe mode Preliminary addition to the test tool to allow a plain SHA-1 hash algorithm without collision protection. Comments? cf. <xmqqr073antj.fsf@gitster.g> source: <cover.1730833506.git.me@xxxxxxxxxxxx> * jt/bundle-fsck (2024-11-28) 4 commits - transport: propagate fsck configuration during bundle fetch - fetch-pack: split out fsck config parsing - bundle: support fsck message configuration - bundle: add bundle verification options type "git bundle --unbundle" and "git clone" running on a bundle file both learned to trigger fsck over the new objects with configurable fck check levels. Will merge to 'next'? source: <20241127233312.27710-1-jltobler@xxxxxxxxx> * tb/boundary-traversal-fix (2024-11-22) 1 commit (merged to 'next' on 2024-11-25 at f312b2f8eb) + pack-bitmap.c: typofix in `find_boundary_objects()` A trivial "correctness" fix that does not yet matter in practice. Will merge to 'master'. source: <cf49115db4e8dcd406a17c946659c2eef3ec6045.1732229420.git.me@xxxxxxxxxxxx> * tb/use-test-file-size-more (2024-11-22) 1 commit (merged to 'next' on 2024-11-25 at 2bdd016a16) + t/perf: use 'test_file_size' in more places Use the right helper program to measure file size in performance tests. Will merge to 'master'. source: <50c1368630684f235548d2e9a68d4de3745b5fe6.1732220875.git.me@xxxxxxxxxxxx> * bc/allow-upload-pack-from-other-people (2024-11-15) 1 commit (merged to 'next' on 2024-12-02 at bf711f018c) + Allow cloning from repositories owned by another user Loosen overly strict ownership check introduced in the recent past, to keep the promise "cloning a suspicious repository is a safe first step to inspect it". Will merge to 'master'. cf. <xmqqed2yzc5z.fsf@gitster.g> source: <20241115005404.3747302-2-sandals@xxxxxxxxxxxxxxxxxxxx> * ps/gc-stale-lock-warning (2024-11-25) 2 commits (merged to 'next' on 2024-11-26 at ed3858b2ea) + t7900: fix host-dependent behaviour when testing git-maintenance(1) (merged to 'next' on 2024-11-20 at 1099c31715) + builtin/gc: provide hint when maintenance hits a stale schedule lock Give a bit of advice/hint message when "git maintenance" stops finding a lock file left by another instance that still is potentially running. Will merge to 'master'. source: <20241119-pks-maintenance-hint-with-stale-lock-v1-1-f9f9a98e12a0@xxxxxx> source: <eb504a75147d8609be66e131d239a69d192d693d.1732511129.git.ps@xxxxxx> * tb/incremental-midx-part-2 (2024-11-20) 15 commits - midx: implement writing incremental MIDX bitmaps - pack-bitmap.c: use `ewah_or_iterator` for type bitmap iterators - pack-bitmap.c: keep track of each layer's type bitmaps - ewah: implement `struct ewah_or_iterator` - pack-bitmap.c: apply pseudo-merge commits with incremental MIDXs - pack-bitmap.c: compute disk-usage with incremental MIDXs - pack-bitmap.c: teach `rev-list --test-bitmap` about incremental MIDXs - pack-bitmap.c: support bitmap pack-reuse with incremental MIDXs - pack-bitmap.c: teach `show_objects_for_type()` about incremental MIDXs - pack-bitmap.c: teach `bitmap_for_commit()` about incremental MIDXs - pack-bitmap.c: open and store incremental bitmap layers - pack-revindex: prepare for incremental MIDX bitmaps - Documentation: describe incremental MIDX bitmaps - Merge branch 'tb/pseudo-merge-bitmap-fixes' into tb/incremental-midx-part-2 - Merge branch 'tb/incremental-midx-part-1' into tb/incremental-midx-part-2 Incrementally updating multi-pack index files. Needs review. source: <cover.1732054032.git.me@xxxxxxxxxxxx> * ja/git-diff-doc-markup (2024-11-19) 5 commits (merged to 'next' on 2024-11-27 at b33b5ae49b) + doc: git-diff: apply format changes to config part + doc: git-diff: apply format changes to diff-generate-patch + doc: git-diff: apply format changes to diff-format + doc: git-diff: apply format changes to diff-options + doc: git-diff: apply new documentation guidelines Documentation mark-up updates. Will merge to 'master'. source: <pull.1769.v4.git.1731967553.gitgitgadget@xxxxxxxxx> * pb/mergetool-errors (2024-11-25) 5 commits (merged to 'next' on 2024-12-02 at b439b146c2) + git-difftool--helper.sh: exit upon initialize_merge_tool errors + git-mergetool--lib.sh: add error message for unknown tool variant + git-mergetool--lib.sh: add error message if 'setup_user_tool' fails + git-mergetool--lib.sh: use TOOL_MODE when erroring about unknown tool + completion: complete '--tool-help' in 'git mergetool' End-user experience of "git mergetool" when the command errors out has been improved. Will merge to 'master'. source: <pull.1827.v2.git.1732305022.gitgitgadget@xxxxxxxxx> * ps/send-pack-unhide-error-in-atomic-push (2024-11-15) 6 commits - push: not send push-options to server with --dry-run - push: only ignore finish_connect() for dry-run mode - t5543: atomic push reports exit code failure - t5504: modernize test by moving heredocs into test bodies - push: fix the behavior of the Done message for porcelain - t5548: new test cases for push --porcelain and --dry-run "git push --atomic --porcelain" used to ignore failures from the other side, losing the error status from the child process, which has been corrected. Probably needs a redesign. cf. <Z0Q0wfSTk_cUXH0F@xxxxxx> source: <cover.1731603991.git.zhiyou.jx@xxxxxxxxxxxxxxx> * ps/ref-backend-migration-optim (2024-11-26) 12 commits (merged to 'next' on 2024-11-26 at 7bb66a1faf) + reftable: rename scratch buffer + refs: adapt `initial_transaction` flag to be unsigned (merged to 'next' on 2024-11-25 at ee2e588790) + reftable/block: optimize allocations by using scratch buffer + reftable/block: rename `block_writer::buf` variable + reftable/writer: optimize allocations by using a scratch buffer + refs: don't normalize log messages with `REF_SKIP_CREATE_REFLOG` + refs: skip collision checks in initial transactions + refs: use "initial" transaction semantics to migrate refs + refs/files: support symbolic and root refs in initial transaction + refs: introduce "initial" transaction flag + refs/files: move logic to commit initial transaction + refs: allow passing flags when setting up a transaction Optimize migration procedure between two ref backends. Will merge to 'master'. source: <20241120-pks-refs-optimize-migrations-v2-0-a233374b7452@xxxxxx> source: <20241125-pks-refs-migration-optimization-followup-v1-0-0e1b4a2af384@xxxxxx> * js/log-remerge-keep-ancestry (2024-11-12) 1 commit - log: --remerge-diff needs to keep around commit parents "git log -p --remerge-diff --reverse" was completely broken. Expecting a hopefully small and final reroll. cf. <xmqqa5e5berx.fsf@gitster.g> source: <pull.1825.v2.git.1731350009491.gitgitgadget@xxxxxxxxx> * ps/reftable-iterator-reuse (2024-11-26) 11 commits (merged to 'next' on 2024-12-02 at 3c1d2e2a6a) + refs/reftable: reuse iterators when reading refs + reftable/merged: drain priority queue on reseek + reftable/stack: add mechanism to notify callers on reload + refs/reftable: refactor reflog expiry to use reftable backend + refs/reftable: refactor reading symbolic refs to use reftable backend + refs/reftable: read references via `struct reftable_backend` + refs/reftable: figure out hash via `reftable_stack` + reftable/stack: add accessor for the hash ID + refs/reftable: handle reloading stacks in the reftable backend + refs/reftable: encapsulate reftable stack + Merge branch 'ps/reftable-detach' into ps/reftable-iterator-reuse (this branch uses ps/reftable-detach.) Optimize reading random references out of the reftable backend by allowing reuse of iterator objects. Will merge to 'master'. source: <20241126-pks-reftable-backend-reuse-iter-v4-0-b17fd27df126@xxxxxx> * jc/move-is-bare-repository-cfg-variable-to-repo (2024-11-07) 3 commits - repository: BUG when is_bare_cfg is not initialized - setup: initialize is_bare_cfg - git: remove is_bare_repository_cfg global variable Code rewrite to turn the is_bare_repository_cfg global variable into a member in the the_repo singleton repository object. Waiting for response to reviews. cf. <xmqqy116xvr3.fsf@gitster.g> source: <pull.1826.git.git.1730926082.gitgitgadget@xxxxxxxxx> * jk/describe-perf (2024-11-07) 4 commits (merged to 'next' on 2024-12-02 at 0f34109a85) + describe: stop traversing when we run out of names + describe: stop digging for max_candidates+1 + t/perf: add tests for git-describe + t6120: demonstrate weakness in disjoint-root handling "git describe" optimization. Will merge to 'master'. source: <20241106192236.GC880133@xxxxxxxxxxxxxxxxxxxxxxx> * js/range-diff-diff-merges (2024-11-11) 1 commit - range-diff: optionally include merge commits' diffs in the analysis "git range-diff" learned to optionally show and compare merge commits in the ranges being compared, with the --diff-merges option. Expecting a (hopefully final and) small reroll. cf. <eb502feb-1563-b1b5-5345-784673c89c79@xxxxxx> source: <pull.1734.v2.git.1731073383564.gitgitgadget@xxxxxxxxx> * ps/leakfixes-part-10 (2024-11-21) 28 commits (merged to 'next' on 2024-11-25 at 7284f186b8) + t: remove TEST_PASSES_SANITIZE_LEAK annotations + test-lib: unconditionally enable leak checking + t: remove unneeded !SANITIZE_LEAK prerequisites + t: mark some tests as leak free + t5601: work around leak sanitizer issue + git-compat-util: drop now-unused `UNLEAK()` macro + global: drop `UNLEAK()` annotation + t/helper: fix leaking commit graph in "read-graph" subcommand + builtin/branch: fix leaking sorting options + builtin/init-db: fix leaking directory paths + builtin/help: fix leaks in `check_git_cmd()` + help: fix leaking return value from `help_unknown_cmd()` + help: fix leaking `struct cmdnames` + help: refactor to not use globals for reading config + builtin/sparse-checkout: fix leaking sanitized patterns + split-index: fix memory leak in `move_cache_to_base_index()` + git: refactor builtin handling to use a `struct strvec` + git: refactor alias handling to use a `struct strvec` + strvec: introduce new `strvec_splice()` function + line-log: fix leak when rewriting commit parents + bisect: fix various cases where we leak commit list items + bisect: fix leaking commit list items in `check_merge_base()` + bisect: fix multiple leaks in `bisect_next_all()` + bisect: fix leaking `current_bad_oid` + bisect: fix leaking string in `handle_bad_merge_base()` + bisect: fix leaking good/bad terms when reading multipe times + builtin/blame: fix leaking blame entries with `--incremental` + Merge branch 'ps/leakfixes-part-9' into ps/leakfixes-part-10 (this branch is used by ps/bisect-double-free-fix and rj/strvec-splice-fix.) Leakfixes. Will merge to 'master'. source: <20241120-b4-pks-leak-fixes-pt10-v3-0-d67f08f45c74@xxxxxx> * kh/sequencer-comment-char (2024-11-26) 3 commits (merged to 'next' on 2024-11-28 at 84693f6bb7) + sequencer: comment commit messages properly + sequencer: comment `--reference` subject line properly + sequencer: comment checked-out branch properly The sequencer failed to honor core.commentString in some places. Will merge to 'master'. source: <cover.1732565412.git.code@xxxxxxxxxxxxxxx> * ds/name-hash-tweaks (2024-12-03) 8 commits - pack-objects: add third name hash version - pack-objects: prevent name hash version change - test-tool: add helper for name-hash values - p5313: add size comparison test - pack-objects: add GIT_TEST_NAME_HASH_VERSION - repack: add --name-hash-version option - pack-objects: add --name-hash-version option - pack-objects: create new name-hash function version "git pack-objects" and its wrapper "git repack" learned an option to use an alternative path-hash function to improve delta-base selection to produce a packfile with deeper history than window size. source: <pull.1823.v2.git.1733181682.gitgitgadget@xxxxxxxxx> * ds/path-walk-1 (2024-11-11) 6 commits - path-walk: mark trees and blobs as UNINTERESTING - path-walk: visit tags and cached objects - path-walk: allow consumer to specify object types - t6601: add helper for testing path-walk API - test-lib-functions: add test_cmp_sorted - path-walk: introduce an object walk by path Introduce a new API to visit objects in batches based on a common path, or by type. Comments? cf. <Z0V8D4r5YbxjNvPs@xxxxxx> source: <pull.1818.v2.git.1731181272.gitgitgadget@xxxxxxxxx> * bc/ancient-ci (2024-11-01) 3 commits (merged to 'next' on 2024-12-02 at f6128744ce) + Add additional CI jobs to avoid accidental breakage + ci: remove clause for Ubuntu 16.04 + gitlab-ci: switch from Ubuntu 16.04 to 20.04 Drop support for ancient environments in various CI jobs. Will merge to 'master'. source: <20241031234934.3451390-1-sandals@xxxxxxxxxxxxxxxxxxxx> * cw/worktree-extension (2024-12-02) 8 commits - worktree: refactor `repair_worktree_after_gitdir_move()` - worktree: add relative cli/config options to `repair` command - worktree: add relative cli/config options to `move` command - worktree: add relative cli/config options to `add` command - worktree: add `write_worktree_linking_files()` function - worktree: refactor infer_backlink return - worktree: add `relativeWorktrees` extension - setup: correctly reinitialize repository version Introduce a new repository extension to prevent older Git versions from mis-interpreting worktrees created with relative paths. Will merge to 'next'? source: <20241129-wt_relative_options-v6-0-44e4e0bec8c3@xxxxx> * as/show-index-uninitialized-hash (2024-11-11) 2 commits - t5300: add test for 'show-index --object-format' - show-index: fix uninitialized hash function Regression fix for 'show-index' when run outside of a repository. Comments? source: <20241109092739.14276-1-abhijeet.nkt@xxxxxxxxx> * ps/reftable-detach (2024-11-19) 8 commits (merged to 'next' on 2024-12-02 at e105e787b6) + reftable/system: provide thin wrapper for lockfile subsystem + reftable/stack: drop only use of `get_locked_file_path()` + reftable/system: provide thin wrapper for tempfile subsystem + reftable/stack: stop using `fsync_component()` directly + reftable/system: stop depending on "hash.h" + reftable: explicitly handle hash format IDs + reftable/system: move "dir.h" to its only user + Merge branch 'ps/reftable-strbuf' into ps/reftable-detach (this branch is used by ps/reftable-iterator-reuse.) Isolates the reftable subsystem from the rest of Git's codebase by using fewer pieces of Git's infrastructure. Will merge to 'master'. source: <cover.1731943954.git.ps@xxxxxx> * km/config-remote-by-name (2024-10-21) 1 commit - config: support remote name in includeIf.hasconfig condition Support conditionally including configuration by remote name, instead of just URL. Needs review. source: <20241020173216.40852-2-ken@xxxxxxxxxx> * y5/diff-pager (2024-10-21) 1 commit - diff: setup pager only before diff contents truly ready Delay setting up the pager in 'git diff' until after the diff contents itself is fully prepared. Needs review. source: <pull.1817.git.git.1729370390416.gitgitgadget@xxxxxxxxx> * bc/drop-ancient-libcurl-and-perl (2024-10-23) 12 commits (merged to 'next' on 2024-11-27 at aa7866a3ab) + gitweb: make use of s///r + Require Perl 5.26.0 + INSTALL: document requirement for libcurl 7.61.0 + git-curl-compat: remove check for curl 7.56.0 + git-curl-compat: remove check for curl 7.53.0 + git-curl-compat: remove check for curl 7.52.0 + git-curl-compat: remove check for curl 7.44.0 + git-curl-compat: remove check for curl 7.43.0 + git-curl-compat: remove check for curl 7.39.0 + git-curl-compat: remove check for curl 7.34.0 + git-curl-compat: remove check for curl 7.25.0 + git-curl-compat: remove check for curl 7.21.5 Drop support for older libcURL and Perl. Will merge to 'master'. source: <20241023004600.1645313-1-sandals@xxxxxxxxxxxxxxxxxxxx> * es/oss-fuzz (2024-10-16) 3 commits - fuzz: port fuzz-url-decode-mem from OSS-Fuzz - fuzz: port fuzz-parse-attr-line from OSS-Fuzz - fuzz: port fuzz-credential-from-url-gently from OSS-Fuzz Backport oss-fuzz tests for us to our codebase. Needs review. source: <cover.1728939687.git.steadmon@xxxxxxxxxx> * bf/set-head-symref (2024-11-25) 10 commits (merged to 'next' on 2024-12-02 at b142ff3d8e) + fetch set_head: handle mirrored bare repositories + fetch: set remote/HEAD if it does not exist + refs: add create_only option to refs_update_symref_extended + refs: add TRANSACTION_CREATE_EXISTS error + remote set-head: better output for --auto + remote set-head: refactor for readability + refs: atomically record overwritten ref in update_symref + refs: standardize output of refs_read_symbolic_ref + t/t5505-remote: test failure of set-head + t/t5505-remote: set default branch to main (this branch is used by bf/fetch-set-head-config.) When "git fetch $remote" notices that refs/remotes/$remote/HEAD is missing and discovers what branch the other side points with its HEAD, refs/remotes/$remote/HEAD is updated to point to it. Will merge to 'master'. source: <20241122123138.66960-1-bence@xxxxxxxxxxxxxx> * ps/build (2024-12-02) 24 commits - meson: fix conflicts with in-flight topics - Introduce support for the Meson build system - Documentation: add comparison of build systems - t: allow overriding build dir - t: better support for out-of-tree builds - Documentation: extract script to generate a list of mergetools - Documentation: teach "cmd-list.perl" about out-of-tree builds - Documentation: allow sourcing generated includes from separate dir - Makefile: simplify building of templates - Makefile: allow "bin-wrappers/" directory to exist - Makefile: refactor generators to be PWD-independent - Makefile: extract script to generate gitweb.js - Makefile: extract script to generate gitweb.cgi - Makefile: extract script to massage Shell scripts - Makefile: use "generate-perl.sh" to massage Perl library - Makefile: extract script to massage Perl scripts - Makefile: consistently use PERL_PATH - Makefile: generate doc versions via GIT-VERSION-GEN - Makefile: generate "git.rc" via GIT-VERSION-GEN - Makefile: propagate Git version via generated header - Makefile: refactor GIT-VERSION-GEN to be reusable - Makefile: consistently use @PLACEHOLDER@ to substitute - Makefile: use common template for GIT-BUILD-OPTIONS - Merge branch 'ps/clar-build-improvement' into ps/build Build procedure update plus introduction of Mason based builds Will merge to 'next'? source: <20241128-pks-meson-v10-0-79a3fb0cb3a6@xxxxxx> * ej/cat-file-remote-object-info (2024-11-25) 6 commits - cat-file: add remote-object-info to batch-command - transport: add client support for object-info - serve: advertise object-info feature - fetch-pack: move fetch initialization - fetch-pack: refactor packet writing - cat-file: add declaration of variable i inside its for loop "git cat-file --batch" and friends can optionally ask a remote server about objects it does not have. Expecting a reroll. cf. <Z0RIrKwUnaWWm_gJ@xxxxxx> source: <20241125053616.25170-1-eric.peijian@xxxxxxxxx> * sj/ref-contents-check (2024-11-21) 9 commits (merged to 'next' on 2024-11-25 at 53e29ae705) + ref: add symlink ref content check for files backend + ref: check whether the target of the symref is a ref + ref: add basic symref content check for files backend + ref: add more strict checks for regular refs + ref: port git-fsck(1) regular refs check for files backend + ref: support multiple worktrees check for refs + ref: initialize ref name outside of check functions + ref: check the full refname instead of basename + ref: initialize "fsck_ref_report" with zero "git fsck" learned to issue warnings on "curiously formatted" ref contents that have always been taken valid but something Git wouldn't have written itself (e.g., missing terminating end-of-line after the full object name). Will merge to 'master'. source: <Zz3MON9_9DGD6nsy@ArchLinux> * js/libgit-rust (2024-10-16) 5 commits - Makefile: add option to build and test libgit-rs and libgit-rs-sys - libgit: add higher-level libgit crate - libgit-sys: also export some config_set functions - libgit-sys: introduce Rust wrapper for libgit.a - common-main: split init and exit code into new files An rust binding to libgit.a functions has been introduced. Needs review. source: <cover.1729032373.git.steadmon@xxxxxxxxxx> * kn/the-repository (2024-11-27) 10 commits - packfile.c: remove unnecessary prepare_packed_git() call - midx: add repository to `multi_pack_index` struct - config: make `packed_git_(limit|window_size)` non-global variables - config: make `delta_base_cache_limit` a non-global variable - packfile: pass down repository to `for_each_packed_object` - packfile: pass down repository to `has_object[_kept]_pack` - packfile: pass down repository to `odb_pack_name` - packfile: pass `repository` to static function in the file - packfile: use `repository` from `packed_git` directly - packfile: add repository to struct `packed_git` (this branch is used by kn/midx-wo-the-repository.) Various implicit uses of 'the_repoository' in the packfile code have been eliminated. Will merge to 'next'? source: <cover.1732618495.git.karthik.188@xxxxxxxxx> -------------------------------------------------- [Discarded] * cc/promisor-remote-capability (2024-09-10) 4 commits . promisor-remote: check advertised name or URL . Add 'promisor-remote' capability to protocol v2 . strbuf: refactor strbuf_trim_trailing_ch() . version: refactor strbuf_sanitize() The v2 protocol learned to allow the server to advertise possible promisor remotes, and the client to respond with what promissor remotes it uses, so that the server side can omit objects that the client can lazily obtain from these other promissor remotes. Discarded for now. cf. <ZvpZv_fed_su4w2-@xxxxxx> cf. <xmqqserboqot.fsf@gitster.g> source: <20240910163000.1985723-1-christian.couder@xxxxxxxxx>