From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on dcvr.yhbt.net X-Spam-Level: X-Spam-ASN: AS3215 2.6.0.0/16 X-Spam-Status: No, score=-4.0 required=3.0 tests=AWL,BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE shortcircuit=no autolearn=ham autolearn_force=no version=3.4.2 Received: from out1.vger.email (out1.vger.email [IPv6:2620:137:e000::1:20]) by dcvr.yhbt.net (Postfix) with ESMTP id 3ADEF1F54E for ; Sat, 9 Jul 2022 20:38:32 +0000 (UTC) Authentication-Results: dcvr.yhbt.net; dkim=pass (1024-bit key; unprotected) header.d=pobox.com header.i=@pobox.com header.b="wLHkyEAY"; dkim-atps=neutral Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229521AbiGIUhL (ORCPT ); Sat, 9 Jul 2022 16:37:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42442 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229448AbiGIUhK (ORCPT ); Sat, 9 Jul 2022 16:37:10 -0400 Received: from pb-smtp21.pobox.com (pb-smtp21.pobox.com [173.228.157.53]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8F06EE0A2 for ; Sat, 9 Jul 2022 13:37:06 -0700 (PDT) Received: from pb-smtp21.pobox.com (unknown [127.0.0.1]) by pb-smtp21.pobox.com (Postfix) with ESMTP id F1F8818FD93; Sat, 9 Jul 2022 16:37:03 -0400 (EDT) (envelope-from junio@pobox.com) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed; d=pobox.com; h=from:to :subject:date:message-id:mime-version:content-type; s=sasl; bh=c ASEc+Whj5kiqCMm5YEAZYnItYFNHCq0YDPLNPl6034=; b=wLHkyEAYmkB7ATQCb usG4KeOP6iwAzRNLH4pkwIGDHPGjHPwKKTfcMrfZhmI838rsg/cg/f1jkHWBuSW8 7mrb94dIGbZEAXvpcz6KVyZ4ecACbGqFkBPfctVLIOjUxC4iidhfJr4esJWw18jv z5F8LejWgGoSCQhnT01AbEnBb4= Received: from pb-smtp21.sea.icgroup.com (unknown [127.0.0.1]) by pb-smtp21.pobox.com (Postfix) with ESMTP id EAFB418FD8F; Sat, 9 Jul 2022 16:37:03 -0400 (EDT) (envelope-from junio@pobox.com) Received: from pobox.com (unknown [34.83.92.57]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by pb-smtp21.pobox.com (Postfix) with ESMTPSA id 9130218FD8C; Sat, 9 Jul 2022 16:37:00 -0400 (EDT) (envelope-from junio@pobox.com) From: Junio C Hamano To: git@vger.kernel.org Subject: What's cooking in git.git (Jul 2022, #02; Fri, 8) X-master-at: 30cc8d0f147546d4dd77bf497f4dec51e7265bd8 X-next-at: cef32db0b66f484ee602159300027f9396ab5473 Date: Sat, 09 Jul 2022 13:36:59 -0700 Message-ID: User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/27.2 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain X-Pobox-Relay-ID: E23FB9BA-FFC6-11EC-B0FE-CBA7845BAAA9-77302942!pb-smtp21.pobox.com Precedence: bulk List-ID: X-Mailing-List: git@vger.kernel.org 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. 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] * ab/cocci-unused (2022-07-06) 6 commits - cocci: generalize "unused" rule to cover more than "strbuf" - cocci: add and apply a rule to find "unused" strbufs - cocci: have "coccicheck{,-pending}" depend on "coccicheck-test" - cocci: add a "coccicheck-test" target and test *.cocci rules - Makefile & .gitignore: ignore & clean "git.res", not "*.res" - Makefile: remove mandatory "spatch" arguments from SPATCH_FLAGS Add Coccinelle rules to detect the pattern of initializing and then finalizing a structure without using it in between at all, which happens after code restructuring and the compilers fail to recognize as an unused varilable. Will merge to 'next'. source: * jk/clone-unborn-confusion (2022-07-07) 3 commits - clone: use remote branch if it matches default HEAD - clone: propagate empty remote HEAD even with other branches - clone: drop extra newline from warning message "git clone" from a repository with some ref whose HEAD is unborn did not set the HEAD in the resulting repository correctly, which has been corrected. Will merge to 'next'? source: * ac/bitmap-lookup-table (2022-07-06) 6 commits - p5310-pack-bitmaps.sh: remove pack.writeReverseIndex - bitmap-lookup-table: add performance tests for lookup table - pack-bitmap: prepare to read lookup table extension - pack-bitmap-write: learn pack.writeBitmapLookupTable and add tests - pack-bitmap-write.c: write lookup table extension - Documentation/technical: describe bitmap lookup table extension The pack bitmap file gained a bitmap-lookup table to speed up locating the necessary bitmap for a given commit. Will merge to 'next'? source: * bc/nettle-sha256 (2022-07-07) 1 commit - sha256: add support for Nettle Support for libnettle as SHA256 implementation has been added. Expecting a reroll. cf. source: <20220705230518.713218-1-sandals@crustytoothpaste.net> * jc/builtin-mv-move-array (2022-07-06) 1 commit - builtin/mv.c: use the MOVE_ARRAY() macro instead of memmove() Apply Coccinelle rule to turn raw memmove() into MOVE_ARRAY() cpp macro, which would improve maintainability and readability. Will merge to 'next'? source: * jd/gpg-interface-trust-level-string (2022-07-08) 1 commit - gpg-interface: add function for converting trust level to string The code to convert between GPG trust level strings and internal constants we use to represent them have been cleaned up. Will merge to 'next'. source: * kk/p4-client-name-encoding-fix (2022-07-08) 1 commit - git-p4: fix bug with encoding of p4 client name "git p4" did not handle non-ASCII client name well, which has been corrected. Will merge to 'next'. source: * sa/cat-file-mailmap (2022-07-07) 5 commits - SQUASH??? - cat-file: add mailmap support - ident: rename commit_rewrite_person() to apply_mailmap_to_header() - ident: move commit_rewrite_person() to ident.c - revision: improve commit_rewrite_person() source: <20220707161554.6900-1-siddharthasthana31@gmail.com> * fr/vimdiff-layout-fix (2022-07-08) 1 commit - vimdiff: make layout engine more robust against user vim settings source: <20220708181024.45839-1-greenfoo@u92.eu> -------------------------------------------------- [Graduated to 'master'] * js/add-i-delete (2022-06-28) 1 commit (merged to 'next' on 2022-06-28 at 8ac04bfd24) + add --interactive: allow `update` to stage deleted files Rewrite of "git add -i" in C that appeared in Git 2.25 didn't correctly record a removed file to the index, which was fixed. source: -------------------------------------------------- [Stalled] * ll/curl-accept-language (2022-06-13) 2 commits - PREP??? give initializer to rpc_state - remote-curl: send Accept-Language header to server source: * bc/stash-export (2022-04-08) 4 commits - 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 A mechanism to export and import stash entries to and from a normal commit to transfer it across repositories has been introduced. Expecting a reroll. cf. source: <20220407215352.3491567-1-sandals@crustytoothpaste.net> * cw/remote-object-info (2022-05-06) 11 commits - SQUASH??? coccicheck - SQUASH??? ensure that coccicheck is happy - SQUASH??? compilation fix - cat-file: add --batch-command remote-object-info command - cat-file: move parse_cmd and DEFAULT_FORMAT up - transport: add object-info fallback to fetch - transport: add client side capability to request object-info - object-info: send attribute packet regardless of object ids - object-store: add function to free object_info contents - fetch-pack: move fetch default settings - fetch-pack: refactor packet writing A client component to talk with the object-info endpoint. Expecting a reroll. source: <20220502170904.2770649-1-calvinwan@google.com> -------------------------------------------------- [Cooking] * ds/git-rebase-doc-markup (2022-06-30) 1 commit (merged to 'next' on 2022-07-08 at 24a0b80b71) + git-rebase.txt: use back-ticks consistently References to commands-to-be-typed-literally in "git rebase" documentation mark-up have been corrected. Will merge to 'master'. source: * ds/rebase-update-ref (2022-06-28) 8 commits - rebase: add rebase.updateRefs config option - rebase: update refs from 'update-ref' commands - rebase: add --update-refs option - sequencer: add update-ref command - sequencer: define array with enum values - rebase-interactive: update 'merge' description - branch: consider refs under 'update-refs' - t2407: test branches currently using apply backend (this branch uses ds/branch-checked-out.) "git rebase -i" learns to update branches whose tip appear in the rebased range. Expecting a reroll. cf. <15631ea2-6722-fd24-c8a6-0cee638b0602@github.com> source: * ds/vscode-settings (2022-06-27) 1 commit (merged to 'next' on 2022-07-02 at fcbd2e7aca) + vscode: improve tab size and wrapping Will merge to 'master'. source: * tb/pack-objects-remove-pahole-comment (2022-06-28) 1 commit (merged to 'next' on 2022-07-06 at d7494fbdef) + pack-objects.h: remove outdated pahole results Comment fix. Will merge to 'master'. source: <1379af2e9d271b501ef3942398e7f159a9c77973.1656440978.git.me@ttaylorr.com> * ab/leakfix (2022-07-01) 11 commits - pull: fix a "struct oid_array" memory leak - cat-file: fix a common "struct object_context" memory leak - gc: fix a memory leak - checkout: avoid "struct unpack_trees_options" leak - merge-file: fix memory leaks on error path - merge-file: refactor for subsequent memory leak fix - cat-file: fix a memory leak in --batch-command mode - revert: free "struct replay_opts" members - submodule.c: free() memory from xgetcwd() - clone: fix memory leak in wanted_peer_refs() - check-ref-format: fix trivial memory leak Plug various memory leaks. Will merge to 'next'. source: * ab/test-tool-leakfix (2022-07-01) 9 commits - test-tool delta: fix a memory leak - test-tool ref-store: fix a memory leak - test-tool bloom: fix memory leaks - test-tool json-writer: fix memory leaks - test-tool regex: call regfree(), fix memory leaks - test-tool urlmatch-normalization: fix a memory leak - test-tool {dump,scrap}-cache-tree: fix memory leaks - test-tool path-utils: fix a memory leak - test-tool test-hash: fix a memory leak Plug various memory leaks in test-tool commands. Will merge to 'next'. source: * en/t6429-test-must-be-empty-fix (2022-06-30) 1 commit (merged to 'next' on 2022-07-06 at 627c51773c) + t6429: fix use of non-existent function A test fix. Will merge to 'master'. source: * gc/submodule-use-super-prefix (2022-06-30) 8 commits - submodule--helper: remove display path helper - submodule--helper update: use --super-prefix - submodule--helper: remove unused SUPPORT_SUPER_PREFIX flags - submodule--helper: use correct display path helper - submodule--helper: don't recreate recursive prefix - submodule--helper update: use display path helper - submodule--helper tests: add missing "display path" coverage - Merge branch 'ab/submodule-cleanup' into gc/submodule-use-super-prefix (this branch uses ab/submodule-cleanup.) Another step to rewrite more parts of "git submodule" in C. Will merge to 'next'. source: <20220701021157.88858-1-chooglen@google.com> * hx/lookup-commit-in-graph-fix (2022-06-30) 1 commit (merged to 'next' on 2022-07-08 at cef32db0b6) + commit-graph.c: no lazy fetch in lookup_commit_in_graph() A corner case bug where lazily fetching objects from a promisor remote resulted in infinite recursion has been corrected. Will merge to 'master'. source: <96d4bb71505d87ed501c058bbd89bfc13d08b24a.1656593279.git.hanxin.hx@bytedance.com> * ll/ls-files-tests-update (2022-07-06) 1 commit (merged to 'next' on 2022-07-06 at 444d1eabd0) + ls-files: update test style Test update. Will merge to 'master'. source: * pw/xdiff-alloc (2022-07-08) 4 commits - xdiff: introduce XDL_ALLOC_GROW() - xdiff: introduce XDL_CALLOC_ARRAY() - xdiff: introduce xdl_calloc - xdiff: introduce XDL_ALLOC_ARRAY() Add a level of redirection to array allocation API in xdiff part, to make it easier to share with the libgit2 project. Will merge to 'next'? source: * sy/mv-out-of-cone (2022-07-01) 8 commits (merged to 'next' on 2022-07-08 at 654970fdb7) + mv: add check_dir_in_index() and solve general dir check issue + mv: use flags mode for update_mode + mv: check if exists in index to handle overwriting + mv: check if out-of-cone file exists in index with SKIP_WORKTREE bit + mv: decouple if/else-if checks using goto + mv: update sparsity after moving from out-of-cone to in-cone + t1092: mv directory from out-of-cone to in-cone + t7002: add tests for moving out-of-cone file/directory "git mv A B" in a sparsely populated working tree can be asked to move a path between directories that are "in cone" (i.e. expected to be materialized in the working tree) and "out of cone" (i.e. expected to be hidden). The handling of such cases has been improved. Will merge to 'master'. source: <20220630023737.473690-1-shaoxuan.yuan02@gmail.com> * ab/squelch-empty-fsync-traces (2022-06-30) 1 commit . trace2: don't include "fsync" events in all trace2 logs Omit fsync-related trace2 entries when their values are all zero. Breaks tests in hx/unpack-streaming with an interesting interaction. source: * cl/grep-max-count (2022-06-22) 1 commit (merged to 'next' on 2022-07-08 at 646199ab4c) + grep: add --max-count command line option "git grep -m" is a way to limit the hits shown per file. Will merge to 'master'. source: * jk/revisions-doc-markup-fix (2022-06-22) 1 commit (merged to 'next' on 2022-07-02 at e25dbe8cfb) + revisions.txt: escape "..." to avoid asciidoc horizontal ellipsis Documentation mark-up fix. Will merge to 'master'. source: * tk/rev-parse-doc-clarify-at-u (2022-06-23) 1 commit (merged to 'next' on 2022-07-08 at 1075452f32) + rev-parse: documentation adjustment - mention remote tracking with @{u} Doc update. Will merge to 'master'. source: * en/merge-tree (2022-06-22) 17 commits (merged to 'next' on 2022-07-08 at a29b4896ab) + git-merge-tree.txt: add a section on potentional usage mistakes + merge-tree: add a --allow-unrelated-histories flag + merge-tree: allow `ls-files -u` style info to be NUL terminated + merge-ort: optionally produce machine-readable output + merge-ort: store more specific conflict information + merge-ort: make `path_messages` a strmap to a string_list + merge-ort: store messages in a list, not in a single strbuf + merge-tree: provide easy access to `ls-files -u` style info + merge-tree: provide a list of which files have conflicts + merge-ort: remove command-line-centric submodule message from merge-ort + merge-ort: provide a merge_get_conflicted_files() helper function + merge-tree: support including merge messages in output + merge-ort: split out a separate display_update_messages() function + merge-tree: implement real merges + merge-tree: add option parsing and initial shell for real merge function + merge-tree: move logic for existing merge into new function + merge-tree: rename merge_trees() to trivial_merge_trees() A new command is introduced that takes two commits and computes a tree that would be contained in the resulting merge commit, if the histories leading to these two commits were to be merged, and is added as a new mode of "git merge-tree" subcommand. Will merge to 'master'. source: * dr/i18n-die-warn-error-usage (2022-06-21) 1 commit (merged to 'next' on 2022-07-08 at 6f639750a1) + i18n: mark message helpers prefix for translation Give _() markings to fatal/warning/usage: labels that are shown in front of these messages. Will merge to 'master'. source: * ds/t5510-brokequote (2022-06-21) 1 commit (merged to 'next' on 2022-07-06 at 2776bed385) + t5510: replace 'origin' with URL more carefully Test fix. Will merge to 'master'. source: <484a330e-0902-6e1b-8189-63c72dcea494@github.com> * en/merge-restore-to-pristine (2022-06-21) 6 commits - merge: do not exit restore_state() prematurely - merge: ensure we can actually restore pre-merge state - merge: make restore_state() restore staged state too - merge: fix save_state() to work when there are racy-dirty files - merge: remove unused variable - t6424: make sure a failed merge preserves local changes When "git merge" finds that it cannot perform a merge, it should restore the working tree to the state before the command was initiated, but in some corner cases it didn't. Needs review. source: * rs/combine-diff-with-incompatible-options (2022-06-21) 2 commits (merged to 'next' on 2022-07-02 at 0fe8b80a3e) + combine-diff: abort if --output is given + combine-diff: abort if --ignore-matching-lines is given Certain diff options are currently ignored when combined-diff is shown; mark them as incompatible with the feature. Will merge to 'master'. source: <220524.86v8tuvfl1.gmgdl@evledraar.gmail.com> * tk/apply-case-insensitive (2022-06-21) 3 commits - apply: support case-only renames in case-insensitive filesystems - reset: new failing test for reset of case-insensitive duplicate in index - t4141: test "git apply" with core.ignorecase "git apply" barfed on a patch that makes a case-only rename on a case-insensitive filesystem. Needs review. source: * zh/ls-files-format (2022-07-06) 1 commit - ls-files: introduce "--format" option "git ls-files" learns the "--format" option to tweak its output. Getting closer to finish? cf. <220705.86sfng9c5a.gmgdl@evledraar.gmail.com> source: * ab/test-quoting-fix (2022-06-30) 3 commits (merged to 'next' on 2022-07-06 at 0aa78fd9db) + config tests: fix harmless but broken "rm -r" cleanup + test-lib.sh: fix prepend_var() quoting issue + tests: add missing double quotes to included library paths Fixes for tests when the source directory has unusual characters in its path, e.g. whitespaces, double-quotes, etc. Will merge to 'master'. source: * en/merge-dual-dir-renames-fix (2022-07-06) 5 commits - merge-ort: fix issue with dual rename and add/add conflict - merge-ort: shuffle the computation and cleanup of potential collisions - merge-ort: make a separate function for freeing struct collisions - merge-ort: small cleanups of check_for_directory_rename - t6423: add tests of dual directory rename plus add/add conflict Fixes a long-standing corner case bug around directory renames in the merge-ort strategy. Will merge to 'next'. source: * cr/setup-bug-typo (2022-06-17) 1 commit (merged to 'next' on 2022-06-17 at 8834ffe0ab) + setup: fix function name in a BUG() message Typofix in a BUG() message. Will cook in 'next'. source: * zk/push-use-bitmaps (2022-06-17) 1 commit (merged to 'next' on 2022-07-08 at 8aa1f94fad) + send-pack.c: add config push.useBitmaps "git push" sometimes perform poorly when reachability bitmaps are used, even in a repository where other operations are helped by bitmaps. The push.useBitmaps configuration variable is introduced to allow disabling use of reachability bitmaps only for "git push". Will merge to 'master'. source: * jk/remote-show-with-negative-refspecs (2022-06-17) 1 commit (merged to 'next' on 2022-07-08 at d4e49ad22a) + remote: handle negative refspecs in git remote show (this branch is used by jk/t5505-restructure.) "git remote show [-n] frotz" now pays attention to negative pathspecs. Will merge to 'master'. source: <20220617002036.1577-2-jacob.keller@gmail.com> * js/commit-graph-parsing-without-repo-settings (2022-06-15) 1 commit - commit-graph: refactor to avoid prepare_repo_settings Expecting a reroll. source: <9b56496b0809cc8a25af877ea97042e2cb7f2af6.1655246092.git.steadmon@google.com> * jk/optim-promisor-object-enumeration (2022-06-16) 1 commit (merged to 'next' on 2022-06-16 at ce0712a74c) + is_promisor_object(): walk promisor packs in pack-order Collection of what is referenced by objects in promisor packs have been optimized to inspect these objects in the in-pack order. Will cook in 'next'. source: * ro/mktree-allow-missing-fix (2022-06-21) 1 commit (merged to 'next' on 2022-07-08 at 599ed6fb84) + mktree: do not check type of remote objects "git mktree --missing" lazily fetched objects that are missing from the local object store, which was totally unnecessary for the purpose of creating the tree object(s) from its input. Will merge to 'master'. source: <748f39a9-65aa-2110-cf92-7ddf81b5f507@roku.com> * pb/diff-doc-raw-format (2022-06-13) 3 commits (merged to 'next' on 2022-07-02 at 198480cbc6) + diff-index.txt: update raw output format in examples + diff-format.txt: correct misleading wording + diff-format.txt: dst can be 0* SHA-1 when path is deleted, too Update "git diff/log --raw" format documentation. Will merge to 'master'. source: * rs/archive-with-internal-gzip (2022-06-15) 6 commits (merged to 'next' on 2022-06-17 at ab5af6acd1) + archive-tar: use internal gzip by default + archive-tar: use OS_CODE 3 (Unix) for internal gzip + archive-tar: add internal gzip implementation + archive-tar: factor out write_block() + archive: rename archiver data field to filter_command + archive: update format documentation Teach "git archive" to (optionally and then by default) avoid spawning an external "gzip" process when creating ".tar.gz" (and ".tgz") archives. Will cook in 'next'. source: <9df761c3-355a-ede9-7971-b32687fe9abb@web.de> * ds/branch-checked-out (2022-06-21) 7 commits (merged to 'next' on 2022-06-21 at e42bc4566f) + branch: drop unused worktrees variable + fetch: stop passing around unused worktrees variable (merged to 'next' on 2022-06-17 at c881874257) + branch: fix branch_checked_out() leaks + branch: use branch_checked_out() when deleting refs + fetch: use new branch_checked_out() and add tests + branch: check for bisects and rebases + branch: add branch_checked_out() helper (this branch is used by ds/rebase-update-ref.) Introduce a helper to see if a branch is already being worked on (hence should not be newly checked out in a working tree), which performs much better than the existing find_shared_symref() to replace many uses of the latter. Will cook in 'next'. source: * jt/connected-show-missing-from-which-side (2022-06-10) 1 commit - fetch,fetch-pack: clarify connectivity check error We may find an object missing after a "git fetch" stores the objects it obtained from the other side, but it is not necessarily because the remote failed to send necessary objects. Reword the messages in an attempt to help users explore other possibilities when they hit this error. Expecting a reroll. source: <20220610195247.1177549-1-jonathantanmy@google.com> * ab/submodule-cleanup (2022-06-28) 12 commits (merged to 'next' on 2022-07-08 at 6f3886aa03) + git-sh-setup.sh: remove "say" function, change last users + git-submodule.sh: use "$quiet", not "$GIT_QUIET" + submodule--helper: eliminate internal "--update" option + submodule--helper: understand --checkout, --merge and --rebase synonyms + submodule--helper: report "submodule" as our name in some "-h" output + submodule--helper: rename "absorb-git-dirs" to "absorbgitdirs" + submodule update: remove "-v" option + submodule--helper: have --require-init imply --init + git-submodule.sh: remove unused top-level "--branch" argument + git-submodule.sh: make the "$cached" variable a boolean + git-submodule.sh: remove unused $prefix variable + git-submodule.sh: remove unused sanitize_submodule_env() (this branch is used by gc/submodule-use-super-prefix.) Further preparation to turn git-submodule.sh into a builtin. Will merge to 'master'. source: * jc/resolve-undo (2022-06-09) 1 commit (merged to 'next' on 2022-06-15 at c195e5a2d9) + revision: mark blobs needed for resolve-undo as reachable The resolve-undo information in the index was not protected against GC, which has been corrected. Will cook in 'next'. source: * ab/build-gitweb (2022-06-28) 8 commits - gitweb/Makefile: add a "NO_GITWEB" parameter - Makefile: build 'gitweb' in the default target - gitweb/Makefile: include in top-level Makefile - gitweb: remove "test" and "test-installed" targets - gitweb/Makefile: prepare to merge into top-level Makefile - gitweb/Makefile: clear up and de-duplicate the gitweb.{css,js} vars - gitweb/Makefile: add a $(GITWEB_ALL) variable - gitweb/Makefile: define all .PHONY prerequisites inline Teach "make all" to build gitweb as well. Will merge to 'next'? source: * ab/test-without-templates (2022-06-06) 7 commits - tests: don't assume a .git/info for .git/info/sparse-checkout - tests: don't assume a .git/info for .git/info/exclude - tests: don't assume a .git/info for .git/info/refs - tests: don't assume a .git/info for .git/info/attributes - tests: don't assume a .git/info for .git/info/grafts - tests: don't depend on template-created .git/branches - t0008: don't rely on default ".git/info/exclude" Tweak tests so that they still work when the "git init" template did not create .git/info directory. Will merge to 'next'? source: * ac/bitmap-format-doc (2022-06-16) 3 commits (merged to 'next' on 2022-06-16 at 5591d11601) + bitmap-format.txt: add information for trailing checksum + bitmap-format.txt: fix some formatting issues + bitmap-format.txt: feed the file to asciidoc to generate html Adjust technical/bitmap-format to be formatted by AsciiDoc, and add some missing information to the documentation. Will cook in 'next'. source: * hx/unpack-streaming (2022-06-13) 6 commits (merged to 'next' on 2022-07-08 at 4eb375ec2f) + unpack-objects: use stream_loose_object() to unpack large objects + core doc: modernize core.bigFileThreshold documentation + object-file.c: add "stream_loose_object()" to handle large object + object-file.c: factor out deflate part of write_loose_object() + object-file.c: refactor write_loose_object() to several steps + unpack-objects: low memory footprint for get_data() in dry_run mode Allow large objects read from a packstream to be streamed into a loose object file straight, without having to keep it in-core as a whole. Will merge to 'master'. source: * tb/show-ref-count (2022-06-06) 2 commits - builtin/show-ref.c: limit output with `--count` - builtin/show-ref.c: rename `found_match` to `matches_nr` "git show-ref" learned to stop after emitting N refs with the new "--count=N" option. Expecting a reroll. cf. source: * ds/bundle-uri-more (2022-06-06) 6 commits - fetch: add 'refs/bundle/' to log.excludeDecoration - bundle-uri: add support for http(s):// and file:// - fetch: add --bundle-uri option - bundle-uri: create basic file-copy logic - remote-curl: add 'get' capability - docs: document bundle URI standard The "bundle URI" topic. Needs review. source: * js/bisect-in-c (2022-06-27) 16 commits - bisect: no longer try to clean up left-over `.git/head-name` files - bisect: remove Cogito-related code - Turn `git bisect` into a full built-in - bisect: move even the command-line parsing to `bisect--helper` - bisect: teach the `bisect--helper` command to show the correct usage strings - bisect--helper: return only correct exit codes in `cmd_*()` - bisect--helper: move the `BISECT_STATE` case to the end - bisect--helper: make `--bisect-state` optional - bisect--helper: align the sub-command order with git-bisect.sh - bisect--helper: using `--bisect-state` without an argument is a bug - bisect--helper: really retire `--bisect-autostart` - bisect--helper: really retire --bisect-next-check - bisect--helper: retire the --no-log option - bisect: avoid double-quoting when printing the failed command - bisect run: fix the error message - bisect: verify that a bogus option won't try to start a bisection Final bits of "git bisect.sh" have been rewritten in C. Expecting a (hopefully final) reroll. cf. <20627.86ilolhnnn.gmgdl@evledraar.gmail.com> source: * gc/bare-repo-discovery (2022-07-07) 5 commits - setup.c: create `discovery.bare` - safe.directory: use git_protected_config() - config: learn `git_protected_config()` - Documentation: define protected configuration - Documentation/git-config.txt: add SCOPES section Introduce a discovery.barerepository configuration variable that allows users to forbid discovery of bare repositories. source: * gg/worktree-from-the-above (2022-06-21) 2 commits (merged to 'next' on 2022-07-08 at fa0e71ba39) + dir: minor refactoring / clean-up + dir: traverse into repository In a non-bare repository, the behavior of Git when the core.worktree configuration variable points at a directory that has a repository as its subdirectory, regressed in Git 2.27 days. Will merge to 'master'. source: <20220616234433.225-1-gg.oss@outlook.com> source: <20220616231956.154-1-gg.oss@outlook.com> -------------------------------------------------- [Discarded] * ar/send-email-confirm-by-default (2022-04-22) 1 commit . send-email: always confirm by default "git send-email" is changed so that by default it asks for confirmation before sending each message out. Discarded. I wanted to like this, and had it in the version of Git I use myself for daily work, but the prompting turned out to be somewhat distracting. source: <20220422083629.1404989-1-hi@alyssa.is>