What's cooking in git.git (May 2024, #12; Tue, 28)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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).

We unfortunately had serious regressions in 2.45.1 (and below, down
to 2.39 maintenance track are affected), and we are trying to assess
the extent of damage and which changes that went into the release to
revert.  We know about "git lfs" and "git annex" getting affected.
We have bunch of reverts planned to fix these regressions that are
already in 'next'.  Please test it if you think you're affected, so
that we can have 2.45.2 and friends to fix these regressions early
next month.

Copies of the source code to Git live in many repositories, and the
following is a list of the ones I push into or their mirrors.  Some
repositories have only a subset of branches.

With maint, master, next, seen, todo:

	git://git.kernel.org/pub/scm/git/git.git/
	git://repo.or.cz/alt-git.git/
	https://kernel.googlesource.com/pub/scm/git/git/
	https://github.com/git/git/
	https://gitlab.com/git-scm/git/

With all the integration branches and topics broken out:

	https://github.com/gitster/git/

Even though the preformatted documentation in HTML and man format
are not sources, they are published in these repositories for
convenience (replace "htmldocs" with "manpages" for the manual
pages):

	git://git.kernel.org/pub/scm/git/git-htmldocs.git/
	https://github.com/gitster/git-htmldocs.git/

Release tarballs are available at:

	https://www.kernel.org/pub/software/scm/git/

--------------------------------------------------
[Graduated to 'master']

* ds/send-email-per-message-block (2024-04-10) 1 commit
  (merged to 'next' on 2024-05-20 at 189c49a1ca)
 + send-email: move newline characters out of a few translatable strings

 Preliminary code clean-up for "git send-email".
 The topmost commit in the original series was dropped per author's request.
 cf. <a07d3807a24f6d68cb48ee48366ae25e@xxxxxxxxxxx>
 source: <29ea3a9b07bf1aa17b5d6a1e41325379c494bcb2.1712732383.git.dsimic@xxxxxxxxxxx>


* jc/doc-diff-name-only (2024-05-17) 1 commit
  (merged to 'next' on 2024-05-20 at 13b6f9350d)
 + diff: document what --name-only shows

 The documentation for "git diff --name-only" has been clarified
 that it is about showing the names in the post-image tree.
 source: <xmqqeda0jr7d.fsf@gitster.g>


* jc/doc-manpages-l10n (2024-05-17) 1 commit
  (merged to 'next' on 2024-05-20 at fb103ed70f)
 + SubmittingPatches: advertise git-manpages-l10n project a bit

 The SubmittingPatches document now refers folks to manpages
 translation project.
 source: <xmqqv83muc12.fsf@gitster.g>


* jc/format-patch-more-aggressive-range-diff (2024-05-06) 1 commit
  (merged to 'next' on 2024-05-21 at 899cce93fb)
 + format-patch: run range-diff with larger creation-factor

 The default "creation-factor" used by "git format-patch" has been
 raised to make it more aggressively find matching commits.
 source: <xmqqbk5i3ncw.fsf_-_@gitster.g>


* jc/rev-parse-fatal-doc (2024-05-01) 1 commit
  (merged to 'next' on 2024-05-21 at 9bbb973b7b)
 + rev-parse: document how --is-* options work outside a repository

 Doc update.
 source: <xmqqplu54fbg.fsf@gitster.g>


* jc/t0017-clarify-bogus-expectation (2024-05-16) 1 commit
  (merged to 'next' on 2024-05-20 at c64016ec43)
 + t0017: clarify dubious test set-up

 Test clean-up.
 source: <xmqqcypmx44l.fsf@gitster.g>


* kn/osxkeychain-skip-idempotent-store (2024-05-15) 2 commits
  (merged to 'next' on 2024-05-21 at 4d757167ad)
 + osxkeychain: state to skip unnecessary store operations
 + osxkeychain: exclusive lock to serialize execution of operations

 The credential helper that talks with osx keychain learned to avoid
 storing back the authentication material it just got received from
 the keychain.
 source: <pull.1729.v3.git.1715800868.gitgitgadget@xxxxxxxxx>


* kn/patch-iteration-doc (2024-05-17) 2 commits
  (merged to 'next' on 2024-05-20 at e0ee0051a9)
 + SubmittingPatches: add section for iterating patches
 + Merge branch 'jc/patch-flow-updates' into kn/patch-iteration-doc

 Doc updates.
 source: <20240517122724.270706-1-knayak@xxxxxxxxxx>


* mt/t0211-typofix (2024-05-16) 1 commit
  (merged to 'next' on 2024-05-20 at f4fba3c7d2)
 + t/t0211-trace2-perf.sh: fix typo patern -> pattern

 Test fix.
 source: <ZkW5ggOVlglfi64u@telcontar>


* ps/builtin-config-cleanup (2024-05-15) 22 commits
  (merged to 'next' on 2024-05-20 at b6f728f1f5)
 + builtin/config: pass data between callbacks via local variables
 + builtin/config: convert flags to a local variable
 + builtin/config: track "fixed value" option via flags only
 + builtin/config: convert `key` to a local variable
 + builtin/config: convert `key_regexp` to a local variable
 + builtin/config: convert `regexp` to a local variable
 + builtin/config: convert `value_pattern` to a local variable
 + builtin/config: convert `do_not_match` to a local variable
 + builtin/config: move `respect_includes_opt` into location options
 + builtin/config: move default value into display options
 + builtin/config: move type options into display options
 + builtin/config: move display options into local variables
 + builtin/config: move location options into local variables
 + builtin/config: refactor functions to have common exit paths
 + config: make the config source const
 + builtin/config: check for writeability after source is set up
 + builtin/config: move actions into `cmd_config_actions()`
 + builtin/config: move legacy options into `cmd_config()`
 + builtin/config: move subcommand options into `cmd_config()`
 + builtin/config: move legacy mode into its own function
 + builtin/config: stop printing full usage on misuse
 + Merge branch 'ps/config-subcommands' into ps/builtin-config-cleanup

 Code clean-up to reduce inter-function communication inside
 builtin/config.c done via the use of global variables.
 source: <cover.1715755055.git.ps@xxxxxx>


* ps/complete-config-w-subcommands (2024-05-17) 1 commit
  (merged to 'next' on 2024-05-20 at 14453d34fc)
 + completion: adapt git-config(1) to complete subcommands

 The command line completion script (in contrib/) has been adjusted
 to the recent update to "git config" that adopted subcommand based
 UI.
 source: <8d43dee33289969a5afbbf7635ac40b7312d8e19.1715926344.git.ps@xxxxxx>


* ps/leakfixes-base (2024-05-27) 2 commits
  (merged to 'next' on 2024-05-27 at bab1589fc0)
 + t: mark a bunch of tests as leak-free
 + ci: add missing dependency for TTY prereq
 (this branch is used by ps/leakfixes.)

 Will merge to 'master'.
 source: <cover.1716810168.git.ps@xxxxxx>


* ps/pseudo-ref-terminology (2024-05-15) 10 commits
  (merged to 'next' on 2024-05-20 at fc0f1f2607)
 + refs: refuse to write pseudorefs
 + ref-filter: properly distinuish pseudo and root refs
 + refs: pseudorefs are no refs
 + refs: classify HEAD as a root ref
 + refs: do not check ref existence in `is_root_ref()`
 + refs: rename `is_special_ref()` to `is_pseudo_ref()`
 + refs: rename `is_pseudoref()` to `is_root_ref()`
 + Documentation/glossary: define root refs as refs
 + Documentation/glossary: clarify limitations of pseudorefs
 + Documentation/glossary: redefine pseudorefs as special refs
 (this branch is used by ps/ref-storage-migration.)

 Terminology to call various ref-like things are getting
 straightened out.
 cf. <vgzwb5xnlvz2gfiqamzrfcjs2xya3zhhoootyzopfpdrjapayq@wfsomyal4cf6>
 source: <cover.1715755591.git.ps@xxxxxx>


* tb/pack-bitmap-write-cleanups (2024-05-15) 6 commits
  (merged to 'next' on 2024-05-20 at 585e7bde21)
 + pack-bitmap: introduce `bitmap_writer_free()`
 + pack-bitmap-write.c: avoid uninitialized 'write_as' field
 + pack-bitmap: drop unused `max_bitmaps` parameter
 + pack-bitmap: avoid use of static `bitmap_writer`
 + pack-bitmap-write.c: move commit_positions into commit_pos fields
 + object.h: add flags allocated by pack-bitmap.h
 (this branch is used by tb/pseudo-merge-reachability-bitmap.)

 The pack bitmap code saw some clean-up to prepare for a follow-up topic.
 source: <cover.1715716605.git.me@xxxxxxxxxxxx>

--------------------------------------------------
[Cooking]

* gt/t-hash-unit-test (2024-05-27) 2 commits
 - t/: migrate helper/test-{sha1, sha256} to unit-tests/t-hash
 - strbuf: introduce strbuf_addstrings() to repeatedly add a string

 A pair of test helpers that essentially are unit tests on hash
 algorithms have been rewritten using the unit-tests framework.

 Will merge to 'next'?
 source: <20240526084345.24138-1-shyamthakkar001@xxxxxxxxx>


* pp/add-parse-range-unit-test (2024-05-27) 1 commit
 - apply: add unit tests for parse_range

 A unit test for code that parses the hunk offset and length from a
 patch fragment header as been added.

 Will merge to 'next'?
 source: <pull.1677.v2.git.git.1716710073910.gitgitgadget@xxxxxxxxx>


* rs/difftool-env-simplify (2024-05-27) 1 commit
 - difftool: add env vars directly in run_file_diff()

 Code simplification.

 Will merge to 'next'.
 source: <c7c843b9-0ccf-4bcb-a036-d794729a99d6@xxxxxx>


* jc/format-patch-with-range-diff (2024-05-24) 2 commits
 - format-patch: move range/inter diff at the end of a single patch output
 - show_log: factor out interdiff/range-diff generation

 Move inter/range-diff output to the end of the patch when
 format-patch adds it to a single patch, instead of writing it
 before the patch text, to be consistent with what is done for a
 cover letter for a multi-patch series.

 Will merge to 'next'?
 source: <20240523225007.2871766-1-gitster@xxxxxxxxx>


* cc/upload-pack-missing-action (2024-05-24) 3 commits
 - upload-pack: allow configuring a missing-action
 - pack-objects: use the missing action API
 - rev-list: refactor --missing=<missing-action>

 Allow a server S that is a lazy clone of another repository X to
 respond to a request by C that is a lazy clone of S in a way that
 it omits objects it itself does not have (and has to be lazily
 fetched from X).

 I would say this is a terribly irresponsive design, especially
 there is no negociation for S to learn if the objects it is going
 to omit is obtainable by C from elsewhere.

 Will discard.
 source: <20240524163926.2019648-1-christian.couder@xxxxxxxxx>


* iw/trace-argv-on-alias (2024-05-27) 4 commits
 - SQUASH???
 - run-command: show prepared command
 - Documentation: alias: add notes on shell expansion
 - Documentation: alias: rework notes into points

 Log the alias-expanded command lines to the trace output.

 Will merge to 'next' after squashing the fix in?
 source: <20240525234454.1489598-1-iwienand@xxxxxxxxxx>


* ps/document-breaking-changes (2024-05-24) 1 commit
 - docs: document upcoming breaking changes

 The structure of the document that records longer-term project
 decisions to deprecate/remove/update various behaviour has been
 outlined.

 Under discussion.
 source: <84c01f1b0a2d24d7de912606f548623601c0d715.1716555034.git.ps@xxxxxx>


* ps/leakfixes (2024-05-27) 19 commits
 - builtin/mv: fix leaks for submodule gitfile paths
 - builtin/mv: refactor to use `struct strvec`
 - builtin/mv duplicate string list memory
 - builtin/mv: refactor `add_slash()` to always return allocated strings
 - strvec: add functions to replace and remove strings
 - submodule: fix leaking memory for submodule entries
 - commit-reach: fix memory leak in `ahead_behind()`
 - builtin/credential: clear credential before exit
 - config: plug various memory leaks
 - config: clarify memory ownership in `git_config_string()`
 - builtin/log: stop using globals for format config
 - builtin/log: stop using globals for log config
 - convert: refactor code to clarify ownership of check_roundtrip_encoding
 - diff: refactor code to clarify memory ownership of prefixes
 - config: clarify memory ownership in `git_config_pathname()`
 - http: refactor code to clarify memory ownership
 - checkout: clarify memory ownership in `unique_tracking_name()`
 - strbuf: fix leak when `appendwholeline()` fails with EOF
 - transport-helper: fix leaking helper name

 Leakfixes.

 Will merge to 'next'.
 source: <cover.1716810168.git.ps@xxxxxx>


* ps/ref-storage-migration (2024-05-28) 14 commits
 - builtin/refs: new command to migrate ref storage formats
 - refs: implement logic to migrate between ref storage formats
 - refs: implement removal of ref storages
 - worktree: don't store main worktree twice
 - reftable: inline `merged_table_release()`
 - refs/files: fix NULL pointer deref when releasing ref store
 - refs/files: extract function to iterate through root refs
 - refs/files: refactor `add_pseudoref_and_head_entries()`
 - refs: allow to skip creation of reflog entries
 - refs: pass storage format to `ref_store_init()` explicitly
 - refs: convert ref storage format to an enum
 - setup: unset ref storage when reinitializing repository version
 - Merge branch 'ps/pseudo-ref-terminology' into ps/ref-storage-migration
 - Merge branch 'ps/refs-without-the-repository-updates' into ps/ref-storage-migration
 (this branch uses ps/refs-without-the-repository-updates.)

 Allow migrating a repository that uses the files backend for its
 ref storage to use the reftable backend, with limitations.

 Will merge to 'next'.
 source: <cover.1716877224.git.ps@xxxxxx>


* tb/midx-write-cleanup (2024-05-24) 8 commits
 - pack-bitmap.c: reimplement `midx_bitmap_filename()` with helper
 - midx: replace `get_midx_rev_filename()` with a generic helper
 - midx-write.c: support reading an existing MIDX with `packs_to_include`
 - midx-write.c: extract `fill_packs_from_midx()`
 - midx-write.c: extract `should_include_pack()`
 - midx-write.c: pass `start_pack` to `get_sorted_entries()`
 - midx-write.c: reduce argument count for `get_sorted_entries()`
 - midx-write.c: tolerate `--preferred-pack` without bitmaps

 Code clean-up around writing the .midx files.

 Needs review.
 source: <cover.1716482279.git.me@xxxxxxxxxxxx>


* tb/pseudo-merge-reachability-bitmap (2024-05-24) 25 commits
 - t/perf: implement performance tests for pseudo-merge bitmaps
 - pseudo-merge: implement support for finding existing merges
 - ewah: `bitmap_equals_ewah()`
 - pack-bitmap: extra trace2 information
 - pack-bitmap.c: use pseudo-merges during traversal
 - t/test-lib-functions.sh: support `--notick` in `test_commit_bulk()`
 - pack-bitmap: implement test helpers for pseudo-merge
 - ewah: implement `ewah_bitmap_popcount()`
 - pseudo-merge: implement support for reading pseudo-merge commits
 - pack-bitmap.c: read pseudo-merge extension
 - pseudo-merge: scaffolding for reads
 - pack-bitmap: extract `read_bitmap()` function
 - pack-bitmap-write.c: write pseudo-merge table
 - pseudo-merge: implement support for selecting pseudo-merge commits
 - config: introduce `git_config_double()`
 - pack-bitmap: make `bitmap_writer_push_bitmapped_commit()` public
 - pack-bitmap: implement `bitmap_writer_has_bitmapped_object_id()`
 - pack-bitmap-write: support storing pseudo-merge commits
 - pseudo-merge.ch: initial commit
 - pack-bitmap: move some initialization to `bitmap_writer_init()`
 - ewah: implement `ewah_bitmap_is_subset()`
 - Documentation/technical: describe pseudo-merge bitmaps format
 - Documentation/gitpacking.txt: describe pseudo-merge bitmaps
 - Documentation/gitpacking.txt: initial commit
 - Merge branch 'tb/pack-bitmap-write-cleanups' into tb/pseudo-merge-reachability-bitmap

 The pseudo-merge reachability bitmap to help more efficient storage
 of the reachability bitmap in a repository with too many refs.

 Will merge to 'next'?
 source: <cover.1716499565.git.me@xxxxxxxxxxxx>


* th/push-local-ff-check-without-lazy-fetch (2024-05-22) 1 commit
  (merged to 'next' on 2024-05-25 at 520b6b2897)
 + push: don't fetch commit object when checking existence

 When "git push" notices that the commit at the tip of the ref on
 the other side it is about to overwrite does not exist locally, it
 used to first try fetching it if the local repository is a partial
 clone. The command has been taught not to do so and immediately
 fail instead.

 Will merge to 'master'.
 source: <20240522201559.1677959-1-tom@xxxxxxxxxx>


* th/quiet-lazy-fetch-from-promisor (2024-05-26) 1 commit
 - promisor-remote: add promisor.quiet configuration option

 The promisor.quiet configuration knob can be set to true to make
 lazy fetching from promisor remotes silent.

 Will merge to 'next'.
 source: <20240525100927.2949808-1-tom@xxxxxxxxxx>


* gt/unit-test-strcmp-offset (2024-05-20) 1 commit
  (merged to 'next' on 2024-05-23 at f672ec425f)
 + t/: port helper/test-strcmp-offset.c to unit-tests/t-strcmp-offset.c

 The strcmp-offset tests have been rewritten using the unit test
 framework.

 Will merge to 'master'.
 source: <20240519204530.12258-3-shyamthakkar001@xxxxxxxxx>


* jc/add-patch-enforce-single-letter-input (2024-05-22) 1 commit
  (merged to 'next' on 2024-05-23 at 12fef48392)
 + add-patch: enforce only one-letter response to prompts

 "git add -p" learned to complain when an answer with more than one
 letter is given to a prompt that expects a single letter answer.

 Will merge to 'master'.
 source: <xmqqh6ep1pwz.fsf_-_@gitster.g>


* jc/fix-2.45.1-and-friends-for-2.39 (2024-05-22) 12 commits
 + Revert "fsck: warn about symlink pointing inside a gitdir"
 + Revert "Add a helper function to compare file contents"
 + clone: drop the protections where hooks aren't run
 + tests: verify that `clone -c core.hooksPath=/dev/null` works again
 + Revert "core.hooksPath: add some protection while cloning"
 + init: use the correct path of the templates directory again
 + hook: plug a new memory leak
 + ci: stop installing "gcc-13" for osx-gcc
 + ci: avoid bare "gcc" for osx-gcc job
 + ci: drop mention of BREW_INSTALL_PACKAGES variable
 + send-email: avoid creating more than one Term::ReadLine object
 + send-email: drop FakeTerm hack
 (this branch is used by jc/fix-2.45.1-and-friends-for-maint.)

 Revert overly aggressive "layered defence" that went into 2.45.1
 and friends, which broke "git-lfs", "git-annex", and other use
 cases, so that we can rebuild necessary counterparts in the open.

 Will merge to 'master' and then prepare 2.45.2 and friends.
 source: <20240521195659.870714-1-gitster@xxxxxxxxx>


* jc/fix-2.45.1-and-friends-for-maint (2024-05-24) 6 commits
  (merged to 'next' on 2024-05-25 at a090491028)
 + Merge branch 'fixes/2.45.1/2.44' into jc/fix-2.45.1-and-friends-for-maint
 + Merge branch 'fixes/2.45.1/2.43' into fixes/2.45.1/2.44
 + Merge branch 'fixes/2.45.1/2.42' into fixes/2.45.1/2.43
 + Merge branch 'fixes/2.45.1/2.41' into fixes/2.45.1/2.42
 + Merge branch 'fixes/2.45.1/2.40' into fixes/2.45.1/2.41
 + Merge branch 'jc/fix-2.45.1-and-friends-for-2.39' into fixes/2.45.1/2.40
 (this branch uses jc/fix-2.45.1-and-friends-for-2.39.)

 Adjust jc/fix-2.45.1-and-friends-for-2.39 for more recent
 maintenance track.

 Will be merged to 'next' when the base topic becomes ready.


* ps/fix-reinit-includeif-onbranch (2024-05-22) 1 commit
  (merged to 'next' on 2024-05-25 at 89c035186d)
 + setup: fix bug with "includeIf.onbranch" when initializing dir

 "git init" in an already created directory, when the user
 configuration has includeif.onbranch, started to fail recently,
 which has been corrected.

 Will merge to 'master'.
 source: <cf182bb9ee7d4a7eb46e5dbf4f3ef5deb198d823.1716374321.git.ps@xxxxxx>


* es/chainlint-ncores-fix (2024-05-22) 3 commits
  (merged to 'next' on 2024-05-22 at 1e4ab85522)
 + chainlint.pl: latch CPU count directly reported by /proc/cpuinfo
 + chainlint.pl: fix incorrect CPU count on Linux SPARC
 + chainlint.pl: make CPU count computation more robust

 The chainlint script (invoked during "make test") did nothing when
 it failed to detect the number of available CPUs.  It now falls
 back to 1 CPU to avoid the problem.

 Will merge to 'master'.
 source: <20240520190131.94904-1-ericsunshine@xxxxxxxxxxx>


* kn/update-ref-symref (2024-05-27) 8 commits
 - SQUASH??? leakfix
 - update-ref: add support for 'symref-update' command
 - reftable: pick either 'oid' or 'target' for new updates
 - update-ref: add support for 'symref-create' command
 - update-ref: add support for 'symref-delete' command
 - update-ref: add support for 'symref-verify' command
 - refs: create and use `ref_update_ref_must_exist()`
 - Merge branch 'kn/ref-transaction-symref' into kn/update-ref-symref

 "git update-ref --stdin" learned to handle transactional updates of
 symbolic-refs.

 Expecting a (hopefully minor and final) reroll.
 source: <20240514124411.1037019-1-knayak@xxxxxxxxxx>


* ps/refs-without-the-repository-updates (2024-05-17) 17 commits
  (merged to 'next' on 2024-05-22 at 744f37ab2b)
 + refs/packed: remove references to `the_hash_algo`
 + refs/files: remove references to `the_hash_algo`
 + refs/files: use correct repository
 + refs: remove `dwim_log()`
 + refs: drop `git_default_branch_name()`
 + refs: pass repo when peeling objects
 + refs: move object peeling into "object.c"
 + refs: pass ref store when detecting dangling symrefs
 + refs: convert iteration over replace refs to accept ref store
 + refs: retrieve worktree ref stores via associated repository
 + refs: refactor `resolve_gitlink_ref()` to accept a repository
 + refs: pass repo when retrieving submodule ref store
 + refs: track ref stores via strmap
 + refs: implement releasing ref storages
 + refs: rename `init_db` callback to avoid confusion
 + refs: adjust names for `init` and `init_db` callbacks
 + Merge branch 'ps/refs-without-the-repository' into ps/refs-without-the-repository-updates
 (this branch is used by ps/ref-storage-migration.)

 Further clean-up the refs subsystem to stop relying on
 the_repository, and instead use the repository associated to the
 ref_store object.

 Will merge to 'master'.
 source: <cover.1715929858.git.ps@xxxxxx>


* mt/openindiana-scalar (2024-05-17) 1 commit
 - scalar: make enlistment delete to work on all POSIX platforms

 Avoid removing the $(cwd) for portability.

 Needs review.
 source: <Zkds81OB7C5bTCl_@telcontar>


* ts/archive-prefix-with-add-virtual-file (2024-05-17) 1 commit
 - archive: make --add-virtual-file honor --prefix

 The "--add-virtual-file" option of "git archive", added primarily
 to help "git diagnose", has always ignored the "--prefix", but
 been documented to honor it.

 Iffy if updating the implementation is the best approach.
 cf. <bc3711a7-37d5-46bc-979e-83bd0b2cf900@xxxxxx>
 source: <pull.1719.v2.git.git.1715967267420.gitgitgadget@xxxxxxxxx>


* js/doc-decisions (2024-05-17) 1 commit
  (merged to 'next' on 2024-05-22 at 891a062720)
 + doc: describe the project's decision-making process

 The project decision making policy has been documented.

 Will merge to 'master'.
 source: <10f217915600eda3ebec886e4f020f87c22e318a.1715978031.git.steadmon@xxxxxxxxxx>


* jc/undecided-is-not-necessarily-sha1-fix (2024-05-21) 6 commits
  (merged to 'next' on 2024-05-22 at 4bd7982ebe)
 + apply: fix uninitialized hash function
 + builtin/hash-object: fix uninitialized hash function
 + builtin/patch-id: fix uninitialized hash function
 + t1517: test commands that are designed to be run outside repository
 + setup: add an escape hatch for "no more default hash algorithm" change
 + Merge branch 'ps/undecided-is-not-necessarily-sha1' into jc/undecided-is-not-necessarily-sha1-fix
 (this branch uses ps/undecided-is-not-necessarily-sha1.)

 The base topic started to make it an error for a command to leave
 the hash algorithm unspecified, which revealed a few commands that
 were not ready for the change.  Give users a knob to revert back to
 the "default is sha-1" behaviour as an escape hatch, and start
 fixing these breakages.

 Will merge to 'master'.
 source: <20240520231434.1816979-1-gitster@xxxxxxxxx>


* ps/reftable-reusable-iterator (2024-05-13) 13 commits
  (merged to 'next' on 2024-05-22 at b92eb9939f)
 + reftable/merged: adapt interface to allow reuse of iterators
 + reftable/stack: provide convenience functions to create iterators
 + reftable/reader: adapt interface to allow reuse of iterators
 + reftable/generic: adapt interface to allow reuse of iterators
 + reftable/generic: move seeking of records into the iterator
 + reftable/merged: simplify indices for subiterators
 + reftable/merged: split up initialization and seeking of records
 + reftable/reader: set up the reader when initializing table iterator
 + reftable/reader: inline `reader_seek_internal()`
 + reftable/reader: separate concerns of table iter and reftable reader
 + reftable/reader: unify indexed and linear seeking
 + reftable/reader: avoid copying index iterator
 + reftable/block: use `size_t` to track restart point index

 Code clean-up to make the reftable iterator closer to be reusable.

 Will merge to 'master'.
 source: <cover.1715589670.git.ps@xxxxxx>


* tb/precompose-getcwd (2024-05-21) 1 commit
 - macOS: ls-files path fails if path of workdir is NFD

 We forgot to normalize the result of getcwd() to NFC on macOS where
 all other paths are normalized, which has been corrected.

 Reverted out of 'next' to be replaced with an updated version (this one).
 Expectign a reroll to clarify the proposed log message.
 cf. <20240520160601.GA29154@tb-raspi4>
 cf. <20240521205749.GA8165@tb-raspi4>
 source: <20240521141452.26210-1-tboegi@xxxxxx>


* ps/reftable-write-options (2024-05-13) 11 commits
  (merged to 'next' on 2024-05-22 at ae8e378430)
 + refs/reftable: allow configuring geometric factor
 + reftable: make the compaction factor configurable
 + refs/reftable: allow disabling writing the object index
 + refs/reftable: allow configuring restart interval
 + reftable: use `uint16_t` to track restart interval
 + refs/reftable: allow configuring block size
 + reftable/dump: support dumping a table's block structure
 + reftable/writer: improve error when passed an invalid block size
 + reftable/writer: drop static variable used to initialize strbuf
 + reftable: pass opts as constant pointer
 + reftable: consistently refer to `reftable_write_options` as `opts`

 The knobs to tweak how reftable files are written have been made
 available as configuration variables.

 Will merge to 'master'.
 source: <cover.1715587849.git.ps@xxxxxx>


* ps/undecided-is-not-necessarily-sha1 (2024-05-06) 15 commits
  (merged to 'next' on 2024-05-08 at 9f8e894685)
 + repository: stop setting SHA1 as the default object hash
 + oss-fuzz/commit-graph: set up hash algorithm
 + builtin/shortlog: don't set up revisions without repo
 + builtin/diff: explicitly set hash algo when there is no repo
 + builtin/bundle: abort "verify" early when there is no repository
 + builtin/blame: don't access potentially unitialized `the_hash_algo`
 + builtin/rev-parse: allow shortening to more than 40 hex characters
 + remote-curl: fix parsing of detached SHA256 heads
 + attr: fix BUG() when parsing attrs outside of repo
 + attr: don't recompute default attribute source
 + parse-options-cb: only abbreviate hashes when hash algo is known
 + path: move `validate_headref()` to its only user
 + path: harden validation of HEAD with non-standard hashes
 + Merge branch 'ps/the-index-is-no-more' into ps/undecided-is-not-necessarily-sha1
 + Merge branch 'jc/no-default-attr-tree-in-bare' into ps/undecided-is-not-necessarily-sha1
 (this branch is used by jc/undecided-is-not-necessarily-sha1-fix.)

 Before discovering the repository details, We used to assume SHA-1
 as the "default" hash function, which has been corrected. Hopefully
 this will smoke out codepaths that rely on such an unwarranted
 assumptions.

 Will cook in 'next', as it has known breakage.
 source: <cover.1715057362.git.ps@xxxxxx>


* pw/rebase-i-error-message (2024-04-08) 2 commits
 - rebase -i: improve error message when picking merge
 - rebase -i: pass struct replay_opts to parse_insn_line()

 When the user adds to "git rebase -i" instruction to "pick" a merge
 commit, the error experience is not pleasant.  Such an error is now
 caught earlier in the process that parses the todo list.

 Expecting a reroll.
 cf. <88bc0787-e7ae-49e5-99e8-97f6c55ea8c6@xxxxxxxxx>
 source: <pull.1672.v2.git.1712585787.gitgitgadget@xxxxxxxxx>


* ew/khash-to-khashl (2024-03-28) 3 commits
 - khashl: fix ensemble lookups on empty table
 - treewide: switch to khashl for memory savings
 - list-objects-filter: use kh_size API

 The hashtable library "khash.h" has been replaced with "khashl.h"
 that has better memory usage characteristics.

 Needs review.
 cf. <xmqqy1a4ao3t.fsf@gitster.g>
 source: <20240328101356.300374-1-e@xxxxxxxxx>


* ds/doc-config-reflow (2024-03-14) 1 commit
 - config.txt: perform some minor reformatting

 Reflow a paragraph in the documentation source without any effect
 to the formatted text.

 Will discard.
 source: <97bdaf075bf5a68554cca1731eca78aff2662907.1710444774.git.dsimic@xxxxxxxxxxx>


* ie/config-includeif-hostname (2024-03-19) 2 commits
 - config: learn the "hostname:" includeIf condition
 - t: add a test helper for getting hostname

 The conditional inclusion mechanism for configuration files learned
 to switch on the hostname.

 Expecting a reroll.
 cf. <20240319210428.GC1159535@xxxxxxxxxxxxxxxxxxxxxxx>
 cf. <20240320001934.GA903718@xxxxxxxxxxxxxxxxxxxxxxx>
 source: <20240319183722.211300-1-ignacio@xxxxxxxxxxxx>


* cw/git-std-lib (2024-02-28) 4 commits
 . SQUASH??? get rid of apparent debugging crufts
 . test-stdlib: show that git-std-lib is independent
 . git-std-lib: introduce Git Standard Library
 . pager: include stdint.h because uintmax_t is used

 Split libgit.a out to a separate git-std-lib tor easier reuse.

 Expecting a reroll.
 source: <cover.1696021277.git.jonathantanmy@xxxxxxxxxx>


* bk/complete-dirname-for-am-and-format-patch (2024-01-12) 1 commit
 - completion: dir-type optargs for am, format-patch

 Command line completion support (in contrib/) has been
 updated for a few commands to complete directory names where a
 directory name is expected.

 Expecting a reroll.
 cf. <40c3a824-a961-490b-94d4-4eb23c8f713d@xxxxxxxxx>
 cf. <6683f24e-7e56-489d-be2d-8afe1fc38d2b@xxxxxxxxx>
 source: <d37781c3-6af2-409b-95a8-660a9b92d20b@xxxxxxxxxxxxxxxxxxxxxxxxx>


* bk/complete-send-email (2024-01-12) 1 commit
 - completion: don't complete revs when --no-format-patch

 Command line completion support (in contrib/) has been taught to
 avoid offering revision names as candidates to "git send-email" when
 the command is used to send pre-generated files.

 Expecting a reroll.
 cf. <CAC4O8c88Z3ZqxH2VVaNPpEGB3moL5dJcg3cOWuLWwQ_hLrJMtA@xxxxxxxxxxxxxx>
 source: <a718b5ee-afb0-44bd-a299-3208fac43506@xxxxxxxxxxxxxxxxxxxxxxxxx>


* tb/path-filter-fix (2024-01-31) 16 commits
 - bloom: introduce `deinit_bloom_filters()`
 - commit-graph: reuse existing Bloom filters where possible
 - object.h: fix mis-aligned flag bits table
 - commit-graph: new Bloom filter version that fixes murmur3
 - commit-graph: unconditionally load Bloom filters
 - bloom: prepare to discard incompatible Bloom filters
 - bloom: annotate filters with hash version
 - 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.

 Waiting for a final ack?
 cf. <ZcFjkfbsBfk7JQIH@nand.local>
 source: <cover.1706741516.git.me@xxxxxxxxxxxx>


* 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>




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux