225bc32a98
Signed-off-by: Junio C Hamano <gitster@pobox.com>
280 lines
12 KiB
Plaintext
280 lines
12 KiB
Plaintext
Git 2.33 Release Notes
|
|
======================
|
|
|
|
Updates since Git 2.32
|
|
----------------------
|
|
|
|
UI, Workflows & Features
|
|
|
|
* "git send-email" learned the "--sendmail-cmd" command line option
|
|
and the "sendemail.sendmailCmd" configuration variable, which is a
|
|
more sensible approach than the current way of repurposing the
|
|
"smtp-server" that is meant to name the server to instead name the
|
|
command to talk to the server.
|
|
|
|
* The userdiff pattern for C# learned the token "record".
|
|
|
|
* "git rev-list" learns to omit the "commit <object-name>" header
|
|
lines from the output with the `--no-commit-header` option.
|
|
|
|
* "git worktree add --lock" learned to record why the worktree is
|
|
locked with a custom message.
|
|
|
|
|
|
Performance, Internal Implementation, Development Support etc.
|
|
|
|
* The code to handle the "--format" option in "for-each-ref" and
|
|
friends made too many string comparisons on %(atom)s used in the
|
|
format string, which has been corrected by converting them into
|
|
enum when the format string is parsed.
|
|
|
|
* Use the hashfile API in the codepath that writes the index file to
|
|
reduce code duplication.
|
|
|
|
* Repeated rename detections in a sequence of mergy operations have
|
|
been optimized out for the 'ort' merge strategy.
|
|
|
|
* Preliminary clean-up of tests before the main reftable changes
|
|
hits the codebase.
|
|
|
|
* The backend for "diff -G/-S" has been updated to use pcre2 engine
|
|
when available.
|
|
|
|
* Use ".DELETE_ON_ERROR" pseudo target to simplify our Makefile.
|
|
|
|
* Code cleanup around struct_type_init() functions.
|
|
|
|
* "git send-email" optimization.
|
|
|
|
* GitHub Actions / CI update.
|
|
(merge 0dc787a9f2 js/ci-windows-update later to maint).
|
|
|
|
* Object accesses in repositories with many alternate object store
|
|
have been optimized.
|
|
|
|
* "git log" has been optimized not to waste cycles to load ref
|
|
decoration data that may not be needed.
|
|
|
|
* Many "printf"-like helper functions we have have been annotated
|
|
with __attribute__() to catch placeholder/parameter mismatches.
|
|
|
|
* Tests that cover protocol bits have been updated and helpers
|
|
used there have been consolidated.
|
|
|
|
* The CI gained a new job to run "make sparse" check.
|
|
|
|
* "git status" codepath learned to work with sparsely populated index
|
|
without hydrating it fully.
|
|
|
|
* A guideline for gender neutral documentation has been added.
|
|
|
|
* Documentation on "git diff -l<n>" and diff.renameLimit have been
|
|
updated, and the defaults for these limits have been raised.
|
|
|
|
* The completion support used to offer alternate spelling of options
|
|
that exist only for compatibility, which has been corrected.
|
|
|
|
* "TEST_OUTPUT_DIRECTORY=there make test" failed to work, which has
|
|
been corrected.
|
|
|
|
* "git bundle" gained more test coverage.
|
|
|
|
* "git read-tree" had a codepath where blobs are fetched one-by-one
|
|
from the promisor remote, which has been corrected to fetch in bulk.
|
|
|
|
* Rewrite of "git submodule" in C continues.
|
|
|
|
* "git checkout" and "git commit" learn to work without unnecessarily
|
|
expanding sparse indexes.
|
|
|
|
|
|
Fixes since v2.32
|
|
-----------------
|
|
|
|
* We historically rejected a very short string as an author name
|
|
while accepting a patch e-mail, which has been loosened.
|
|
(merge 72ee47ceeb ef/mailinfo-short-name later to maint).
|
|
|
|
* The parallel checkout codepath did not initialize object ID field
|
|
used to talk to the worker processes in a futureproof way.
|
|
|
|
* Rewrite code that triggers undefined behaviour warning.
|
|
(merge aafa5df0df jn/size-t-casted-to-off-t-fix later to maint).
|
|
|
|
* The description of "fast-forward" in the glossary has been updated.
|
|
(merge e22f2daed0 ry/clarify-fast-forward-in-glossary later to maint).
|
|
|
|
* Recent "git clone" left a temporary directory behind when the
|
|
transport layer returned an failure.
|
|
(merge 6aacb7d861 jk/clone-clean-upon-transport-error later to maint).
|
|
|
|
* "git fetch" over protocol v2 left its side of the socket open after
|
|
it finished speaking, which unnecessarily wasted the resource on
|
|
the other side.
|
|
(merge ae1a7eefff jk/fetch-pack-v2-half-close-early later to maint).
|
|
|
|
* The command line completion (in contrib/) learned that "git diff"
|
|
takes the "--anchored" option.
|
|
(merge d1e7c2cac9 tb/complete-diff-anchored later to maint).
|
|
|
|
* "git-svn" tests assumed that "locale -a", which is used to pick an
|
|
available UTF-8 locale, is available everywhere. A knob has been
|
|
introduced to allow testers to specify a suitable locale to use.
|
|
(merge 482c962de4 dd/svn-test-wo-locale-a later to maint).
|
|
|
|
* Update "git subtree" to work better on Windows.
|
|
(merge 77f37de39f js/subtree-on-windows-fix later to maint).
|
|
|
|
* Remove multimail from contrib/
|
|
(merge f74d11471f js/no-more-multimail later to maint).
|
|
|
|
* Make the codebase MSAN clean.
|
|
(merge 4dbc55e87d ah/uninitialized-reads-fix later to maint).
|
|
|
|
* Work around inefficient glob substitution in older versions of bash
|
|
by rewriting parts of a test.
|
|
(merge eb87c6f559 jx/t6020-with-older-bash later to maint).
|
|
|
|
* Avoid duplicated work while building reachability bitmaps.
|
|
(merge aa9ad6fee5 jk/bitmap-tree-optim later to maint).
|
|
|
|
* We broke "GIT_SKIP_TESTS=t?000" to skip certain tests in recent
|
|
update, which got fixed.
|
|
|
|
* The side-band demultiplexer that is used to display progress output
|
|
from the remote end did not clear the line properly when the end of
|
|
line hits at a packet boundary, which has been corrected.
|
|
|
|
* Some test scripts assumed that readlink(1) was universally
|
|
installed and available, which is not the case.
|
|
(merge 7c0afdf23c jk/test-without-readlink-1 later to maint).
|
|
|
|
* Recent update to completion script (in contrib/) broke those who
|
|
use the __git_complete helper to define completion to their custom
|
|
command.
|
|
(merge cea232194d fw/complete-cmd-idx-fix later to maint).
|
|
|
|
* Output from some of our tests were affected by the width of the
|
|
terminal that they were run in, which has been corrected by
|
|
exporting a fixed value in the COLUMNS environment.
|
|
(merge c49a177bec ab/fix-columns-to-80-during-tests later to maint).
|
|
|
|
* On Windows, mergetool has been taught to find kdiff3.exe just like
|
|
it finds winmerge.exe.
|
|
(merge 47eb4c6890 ms/mergetools-kdiff3-on-windows later to maint).
|
|
|
|
* When we cannot figure out how wide the terminal is, we use a
|
|
fallback value of 80 ourselves (which cannot be avoided), but when
|
|
we run the pager, we export it in COLUMNS, which forces the pager
|
|
to use the hardcoded value, even when the pager is perfectly
|
|
capable to figure it out itself. Stop exporting COLUMNS when we
|
|
fall back on the hardcoded default value for our own use.
|
|
(merge 9b6e2c8b98 js/stop-exporting-bogus-columns later to maint).
|
|
|
|
* "git cat-file --batch-all-objects"" misbehaved when "--batch" is in
|
|
use and did not ask for certain object traits.
|
|
(merge ee02ac6164 zh/cat-file-batch-fix later to maint).
|
|
|
|
* Some code and doc clarification around "git push".
|
|
|
|
* The "union" conflict resultion variant misbehaved when used with
|
|
binary merge driver.
|
|
(merge 382b601acd jk/union-merge-binary later to maint).
|
|
|
|
* Prevent "git p4" from failing to submit changes to binary file.
|
|
(merge 54662d5958 dc/p4-binary-submit-fix later to maint).
|
|
|
|
* "git grep --and -e foo" ought to have been diagnosed as an error
|
|
but instead segfaulted, which has been corrected.
|
|
(merge fe7fe62d8d rs/grep-parser-fix later to maint).
|
|
|
|
* The merge code had funny interactions between content based rename
|
|
detection and directory rename detection.
|
|
(merge 3585d0ea23 en/merge-dir-rename-corner-case-fix later to maint).
|
|
|
|
* When rebuilding the multi-pack index file reusing an existing one,
|
|
we used to blindly trust the existing file and ended up carrying
|
|
corrupted data into the updated file, which has been corrected.
|
|
(merge f89ecf7988 tb/midx-use-checksum later to maint).
|
|
|
|
* Update the location of system-side configuration file on Windows.
|
|
(merge e355307692 js/gfw-system-config-loc-fix later to maint).
|
|
|
|
* Code recently added to support common ancestry negotiation during
|
|
"git push" did not sanity check its arguments carefully enough.
|
|
(merge eff40457a4 ab/fetch-negotiate-segv-fix later to maint).
|
|
|
|
* Update the documentation not to assume users are of certain gender
|
|
and adds to guidelines to do so.
|
|
(merge 46a237f42f ds/gender-neutral-doc later to maint).
|
|
|
|
* "git commit --allow-empty-message" won't abort the operation upon
|
|
an empty message, but the hint shown in the editor said otherwise.
|
|
(merge 6f70f00b4f hj/commit-allow-empty-message later to maint).
|
|
|
|
* The code that gives an error message in "git multi-pack-index" when
|
|
no subcommand is given tried to print a NULL pointer as a strong,
|
|
which has been corrected.
|
|
(merge 88617d11f9 tb/reverse-midx later to maint).
|
|
|
|
* CI update.
|
|
(merge a066a90db6 js/ci-check-whitespace-updates later to maint).
|
|
|
|
* Documentation fix for "git pull --rebase=no".
|
|
(merge d3236becec fc/pull-no-rebase-merges-theirs-into-ours later to maint).
|
|
|
|
* A race between repacking and using pack bitmaps has been corrected.
|
|
(merge dc1daacdcc jk/check-pack-valid-before-opening-bitmap later to maint).
|
|
|
|
* The local changes stashed by "git merge --autostash" were lost when
|
|
the merge failed in certain ways, which has been corrected.
|
|
|
|
* Windows rmdir() equivalent behaves differently from POSIX ones in
|
|
that when used on a symbolic link that points at a directory, the
|
|
target directory gets removed, which has been corrected.
|
|
(merge 3e7d4888e5 tb/mingw-rmdir-symlink-to-directory later to maint).
|
|
|
|
* Other code cleanup, docfix, build fix, etc.
|
|
(merge bfe35a6165 ah/doc-describe later to maint).
|
|
(merge f302c1e4aa jc/clarify-revision-range later to maint).
|
|
(merge 3127ff90ea tl/fix-packfile-uri-doc later to maint).
|
|
(merge a84216c684 jk/doc-color-pager later to maint).
|
|
(merge 4e0a64a713 ab/trace2-squelch-gcc-warning later to maint).
|
|
(merge 225f7fa847 ps/rev-list-object-type-filter later to maint).
|
|
(merge 5317dfeaed dd/honor-users-tar-in-tests later to maint).
|
|
(merge ace6d8e3d6 tk/partial-clone-repack-doc later to maint).
|
|
(merge 7ba68e0cf1 js/trace2-discard-event-docfix later to maint).
|
|
(merge 8603c419d3 fc/doc-default-to-upstream-config later to maint).
|
|
(merge 1d72b604ef jk/revision-squelch-gcc-warning later to maint).
|
|
(merge abcb66c614 ar/typofix later to maint).
|
|
(merge 9853830787 ah/graph-typofix later to maint).
|
|
(merge aac578492d ab/config-hooks-path-testfix later to maint).
|
|
(merge 98c7656a18 ar/more-typofix later to maint).
|
|
(merge 6fb9195f6c jk/doc-max-pack-size later to maint).
|
|
(merge 4184cbd635 ar/mailinfo-memcmp-to-skip-prefix later to maint).
|
|
(merge 91d2347033 ar/doc-libera-chat-in-my-first-contrib later to maint).
|
|
(merge 338abb0f04 ab/cmd-foo-should-return later to maint).
|
|
(merge 546096a5cb ab/xdiff-bug-cleanup later to maint).
|
|
(merge b7b793d1e7 ab/progress-cleanup later to maint).
|
|
(merge d94f9b8e90 ba/object-info later to maint).
|
|
(merge 52ff891c03 ar/test-code-cleanup later to maint).
|
|
(merge a0538e5c8b dd/document-log-decorate-default later to maint).
|
|
(merge ce24797d38 mr/cmake later to maint).
|
|
(merge 9eb542f2ee ab/pre-auto-gc-hook-test later to maint).
|
|
(merge 9fffc38583 bk/doc-commit-typofix later to maint).
|
|
(merge 1cf823d8f0 ks/submodule-cleanup later to maint).
|
|
(merge ebbf5d2b70 js/config-mak-windows-pcre-fix later to maint).
|
|
(merge 617480d75b hn/refs-iterator-peel-returns-boolean later to maint).
|
|
(merge 6a24cc71ed ar/submodule-helper-include-cleanup later to maint).
|
|
(merge 5632e838f8 rs/khash-alloc-cleanup later to maint).
|
|
(merge b1d87fbaf1 jk/typofix later to maint).
|
|
(merge e04170697a ab/gitignore-discovery-doc later to maint).
|
|
(merge 8232a0ff48 dl/packet-read-response-end-fix later to maint).
|
|
(merge eb448631fb dl/diff-merge-base later to maint).
|
|
(merge c510928a25 hn/refs-debug-empty-prefix later to maint).
|
|
(merge ddcb189d9d tb/bitmap-type-filter-comment-fix later to maint).
|
|
(merge 878b399734 pb/submodule-recurse-doc later to maint).
|
|
(merge 734283855f jk/config-env-doc later to maint).
|
|
(merge 482e1488a9 ab/getcwd-test later to maint).
|
|
(merge f0b922473e ar/doc-markup-fix later to maint).
|