You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
365 lines
15 KiB
365 lines
15 KiB
Git 2.31 Release Notes |
|
====================== |
|
|
|
Updates since v2.30 |
|
------------------- |
|
|
|
Backward incompatible and other important changes |
|
|
|
* The "pack-redundant" command, which has been left stale with almost |
|
unusable performance issues, now warns loudly when it gets used, as |
|
we no longer want to recommend its use (instead just "repack -d" |
|
instead). |
|
|
|
* The development community has adopted Contributor Covenant v2.0 to |
|
update from v1.4 that we have been using. |
|
|
|
* The support for deprecated PCRE1 library has been dropped. |
|
|
|
* Fixes for CVE-2021-21300 in Git 2.30.2 (and earlier) is included. |
|
|
|
|
|
UI, Workflows & Features |
|
|
|
* The "--format=%(trailers)" mechanism gets enhanced to make it |
|
easier to design output for machine consumption. |
|
|
|
* When a user does not tell "git pull" to use rebase or merge, the |
|
command gives a loud message telling a user to choose between |
|
rebase or merge but creates a merge anyway, forcing users who would |
|
want to rebase to redo the operation. Fix an early part of this |
|
problem by tightening the condition to give the message---there is |
|
no reason to stop or force the user to choose between rebase or |
|
merge if the history fast-forwards. |
|
|
|
* The configuration variable 'core.abbrev' can be set to 'no' to |
|
force no abbreviation regardless of the hash algorithm. |
|
|
|
* "git rev-parse" can be explicitly told to give output as absolute |
|
or relative path with the `--path-format=(absolute|relative)` option. |
|
|
|
* Bash completion (in contrib/) update to make it easier for |
|
end-users to add completion for their custom "git" subcommands. |
|
|
|
* "git maintenance" learned to drive scheduled maintenance on |
|
platforms whose native scheduling methods are not 'cron'. |
|
|
|
* After expiring a reflog and making a single commit, the reflog for |
|
the branch would record a single entry that knows both @{0} and |
|
@{1}, but we failed to answer "what commit were we on?", i.e. @{1} |
|
|
|
* "git bundle" learns "--stdin" option to read its refs from the |
|
standard input. Also, it now does not lose refs whey they point |
|
at the same object. |
|
|
|
* "git log" learned a new "--diff-merges=<how>" option. |
|
|
|
* "git ls-files" can and does show multiple entries when the index is |
|
unmerged, which is a source for confusion unless -s/-u option is in |
|
use. A new option --deduplicate has been introduced. |
|
|
|
* `git worktree list` now annotates worktrees as prunable, shows |
|
locked and prunable attributes in --porcelain mode, and gained |
|
a --verbose option. |
|
|
|
* "git clone" tries to locally check out the branch pointed at by |
|
HEAD of the remote repository after it is done, but the protocol |
|
did not convey the information necessary to do so when copying an |
|
empty repository. The protocol v2 learned how to do so. |
|
|
|
* There are other ways than ".." for a single token to denote a |
|
"commit range", namely "<rev>^!" and "<rev>^-<n>", but "git |
|
range-diff" did not understand them. |
|
|
|
* The "git range-diff" command learned "--(left|right)-only" option |
|
to show only one side of the compared range. |
|
|
|
* "git mergetool" feeds three versions (base, local and remote) of |
|
a conflicted path unmodified. The command learned to optionally |
|
prepare these files with unconflicted parts already resolved. |
|
|
|
* The .mailmap is documented to be read only from the root level of a |
|
working tree, but a stray file in a bare repository also was read |
|
by accident, which has been corrected. |
|
|
|
* "git maintenance" tool learned a new "pack-refs" maintenance task. |
|
|
|
* The error message given when a configuration variable that is |
|
expected to have a boolean value has been improved. |
|
|
|
* Signed commits and tags now allow verification of objects, whose |
|
two object names (one in SHA-1, the other in SHA-256) are both |
|
signed. |
|
|
|
* "git rev-list" command learned "--disk-usage" option. |
|
|
|
* "git {diff,log} --{skip,rotate}-to=<path>" allows the user to |
|
discard diff output for early paths or move them to the end of the |
|
output. |
|
|
|
* "git difftool" learned "--skip-to=<path>" option to restart an |
|
interrupted session from an arbitrary path. |
|
|
|
* "git grep" has been tweaked to be limited to the sparse checkout |
|
paths. |
|
|
|
* "git rebase --[no-]fork-point" gained a configuration variable |
|
rebase.forkPoint so that users do not have to keep specifying a |
|
non-default setting. |
|
|
|
|
|
Performance, Internal Implementation, Development Support etc. |
|
|
|
* A 3-year old test that was not testing anything useful has been |
|
corrected. |
|
|
|
* Retire more names with "sha1" in it. |
|
|
|
* The topological walk codepath is covered by new trace2 stats. |
|
|
|
* Update the Code-of-conduct to version 2.0 from the upstream (we've |
|
been using version 1.4). |
|
|
|
* "git mktag" validates its input using its own rules before writing |
|
a tag object---it has been updated to share the logic with "git |
|
fsck". |
|
|
|
* Two new ways to feed configuration variable-value pairs via |
|
environment variables have been introduced, and the way |
|
GIT_CONFIG_PARAMETERS encodes variable/value pairs has been tweaked |
|
to make it more robust. |
|
|
|
* Tests have been updated so that they do not to get affected by the |
|
name of the default branch "git init" creates. |
|
|
|
* "git fetch" learns to treat ref updates atomically in all-or-none |
|
fashion, just like "git push" does, with the new "--atomic" option. |
|
|
|
* The peel_ref() API has been replaced with peel_iterated_oid(). |
|
|
|
* The .use_shell flag in struct child_process that is passed to |
|
run_command() API has been clarified with a bit more documentation. |
|
|
|
* Document, clean-up and optimize the code around the cache-tree |
|
extension in the index. |
|
|
|
* The ls-refs protocol operation has been optimized to narrow the |
|
sub-hierarchy of refs/ it walks to produce response. |
|
|
|
* When removing many branches and tags, the code used to do so one |
|
ref at a time. There is another API it can use to delete multiple |
|
refs, and it makes quite a lot of performance difference when the |
|
refs are packed. |
|
|
|
* The "pack-objects" command needs to iterate over all the tags when |
|
automatic tag following is enabled, but it actually iterated over |
|
all refs and then discarded everything outside "refs/tags/" |
|
hierarchy, which was quite wasteful. |
|
|
|
* A perf script was made more portable. |
|
|
|
* Our setting of GitHub CI test jobs were a bit too eager to give up |
|
once there is even one failure found. Tweak the knob to allow |
|
other jobs keep running even when we see a failure, so that we can |
|
find more failures in a single run. |
|
|
|
* We've carried compatibility codepaths for compilers without |
|
variadic macros for quite some time, but the world may be ready for |
|
them to be removed. Force compilation failure on exotic platforms |
|
where variadic macros are not available to find out who screams in |
|
such a way that we can easily revert if it turns out that the world |
|
is not yet ready. |
|
|
|
* Code clean-up to ensure our use of hashtables using object names as |
|
keys use the "struct object_id" objects, not the raw hash values. |
|
|
|
* Lose the debugging aid that may have been useful in the past, but |
|
no longer is, in the "grep" codepaths. |
|
|
|
* Some pretty-format specifiers do not need the data in commit object |
|
(e.g. "%H"), but we were over-eager to load and parse it, which has |
|
been made even lazier. |
|
|
|
* Get rid of "GETTEXT_POISON" support altogether, which may or may |
|
not be controversial. |
|
|
|
* Introduce an on-disk file to record revindex for packdata, which |
|
traditionally was always created on the fly and only in-core. |
|
|
|
* The commit-graph learned to use corrected commit dates instead of |
|
the generation number to help topological revision traversal. |
|
|
|
* Piecemeal of rewrite of "git bisect" in C continues. |
|
|
|
* When a pager spawned by us exited, the trace log did not record its |
|
exit status correctly, which has been corrected. |
|
|
|
* Removal of GIT_TEST_GETTEXT_POISON continues. |
|
|
|
* The code to implement "git merge-base --independent" was poorly |
|
done and was kept from the very beginning of the feature. |
|
|
|
* Preliminary changes to fsmonitor integration. |
|
|
|
* Performance improvements for rename detection. |
|
|
|
* The common code to deal with "chunked file format" that is shared |
|
by the multi-pack-index and commit-graph files have been factored |
|
out, to help codepaths for both filetypes to become more robust. |
|
|
|
* The approach to "fsck" the incoming objects in "index-pack" is |
|
attractive for performance reasons (we have them already in core, |
|
inflated and ready to be inspected), but fundamentally cannot be |
|
applied fully when we receive more than one pack stream, as a tree |
|
object in one pack may refer to a blob object in another pack as |
|
".gitmodules", when we want to inspect blobs that are used as |
|
".gitmodules" file, for example. Teach "index-pack" to emit |
|
objects that must be inspected later and check them in the calling |
|
"fetch-pack" process. |
|
|
|
* The logic to handle "trailer" related placeholders in the |
|
"--format=" mechanisms in the "log" family and "for-each-ref" |
|
family is getting unified. |
|
|
|
* Raise the buffer size used when writing the index file out from |
|
(obviously too small) 8kB to (clearly sufficiently large) 128kB. |
|
|
|
* It is reported that open() on some platforms (e.g. macOS Big Sur) |
|
can return EINTR even though our timers are set up with SA_RESTART. |
|
A workaround has been implemented and enabled for macOS to rerun |
|
open() transparently from the caller when this happens. |
|
|
|
|
|
Fixes since v2.30 |
|
----------------- |
|
|
|
* Diagnose command line error of "git rebase" early. |
|
|
|
* Clean up option descriptions in "git cmd --help". |
|
|
|
* "git stash" did not work well in a sparsely checked out working |
|
tree. |
|
|
|
* Some tests expect that "ls -l" output has either '-' or 'x' for |
|
group executable bit, but setgid bit can be inherited from parent |
|
directory and make these fields 'S' or 's' instead, causing test |
|
failures. |
|
|
|
* "git for-each-repo --config=<var> <cmd>" should not run <cmd> for |
|
any repository when the configuration variable <var> is not defined |
|
even once. |
|
|
|
* Fix 2.29 regression where "git mergetool --tool-help" fails to list |
|
all the available tools. |
|
|
|
* Fix for procedure to building CI test environment for mac. |
|
|
|
* The implementation of "git branch --sort" wrt the detached HEAD |
|
display has always been hacky, which has been cleaned up. |
|
|
|
* Newline characters in the host and path part of git:// URL are |
|
now forbidden. |
|
|
|
* "git diff" showed a submodule working tree with untracked cruft as |
|
"Submodule commit <objectname>-dirty", but a natural expectation is |
|
that the "-dirty" indicator would align with "git describe --dirty", |
|
which does not consider having untracked files in the working tree |
|
as source of dirtiness. The inconsistency has been fixed. |
|
|
|
* When more than one commit with the same patch ID appears on one |
|
side, "git log --cherry-pick A...B" did not exclude them all when a |
|
commit with the same patch ID appears on the other side. Now it |
|
does. |
|
|
|
* Documentation for "git fsck" lost stale bits that has become |
|
incorrect. |
|
|
|
* Doc fix for packfile URI feature. |
|
|
|
* When "git rebase -i" processes "fixup" insn, there is no reason to |
|
clean up the commit log message, but we did the usual stripspace |
|
processing. This has been corrected. |
|
(merge f7d42ceec5 js/rebase-i-commit-cleanup-fix later to maint). |
|
|
|
* Fix in passing custom args from "git clone" to "upload-pack" on the |
|
other side. |
|
(merge ad6b5fefbd jv/upload-pack-filter-spec-quotefix later to maint). |
|
|
|
* The command line completion (in contrib/) completed "git branch -d" |
|
with branch names, but "git branch -D" offered tagnames in addition, |
|
which has been corrected. "git branch -M" had the same problem. |
|
(merge 27dc071b9a jk/complete-branch-force-delete later to maint). |
|
|
|
* When commands are started from a subdirectory, they may have to |
|
compare the path to the subdirectory (called prefix and found out |
|
from $(pwd)) with the tracked paths. On macOS, $(pwd) and |
|
readdir() yield decomposed path, while the tracked paths are |
|
usually normalized to the precomposed form, causing mismatch. This |
|
has been fixed by taking the same approach used to normalize the |
|
command line arguments. |
|
(merge 5c327502db tb/precompose-prefix-too later to maint). |
|
|
|
* Even though invocations of "die()" were logged to the trace2 |
|
system, "BUG()"s were not, which has been corrected. |
|
(merge 0a9dde4a04 jt/trace2-BUG later to maint). |
|
|
|
* "git grep --untracked" is meant to be "let's ALSO find in these |
|
files on the filesystem" when looking for matches in the working |
|
tree files, and does not make any sense if the primary search is |
|
done against the index, or the tree objects. The "--cached" and |
|
"--untracked" options have been marked as mutually incompatible. |
|
(merge 0c5d83b248 mt/grep-cached-untracked later to maint). |
|
|
|
* Fix "git fsck --name-objects" which apparently has not been used by |
|
anybody who is motivated enough to report breakage. |
|
(merge e89f89361c js/fsck-name-objects-fix later to maint). |
|
|
|
* Avoid individual tests in t5411 from getting affected by each other |
|
by forcing them to use separate output files during the test. |
|
(merge 822ee894f6 jx/t5411-unique-filenames later to maint). |
|
|
|
* Test to make sure "git rev-parse one-thing one-thing" gives |
|
the same thing twice (when one-thing is --since=X). |
|
(merge a5cdca4520 ew/rev-parse-since-test later to maint). |
|
|
|
* When certain features (e.g. grafts) used in the repository are |
|
incompatible with the use of the commit-graph, we used to silently |
|
turned commit-graph off; we now tell the user what we are doing. |
|
(merge c85eec7fc3 js/commit-graph-warning later to maint). |
|
|
|
* Objects that lost references can be pruned away, even when they |
|
have notes attached to it (and these notes will become dangling, |
|
which in turn can be pruned with "git notes prune"). This has been |
|
clarified in the documentation. |
|
(merge fa9ab027ba mz/doc-notes-are-not-anchors later to maint). |
|
|
|
* The error codepath around the "--temp/--prefix" feature of "git |
|
checkout-index" has been improved. |
|
(merge 3f7ba60350 mt/checkout-index-corner-cases later to maint). |
|
|
|
* The "git maintenance register" command had trouble registering bare |
|
repositories, which had been corrected. |
|
|
|
* A handful of multi-word configuration variable names in |
|
documentation that are spelled in all lowercase have been corrected |
|
to use the more canonical camelCase. |
|
(merge 7dd0eaa39c dl/doc-config-camelcase later to maint). |
|
|
|
* "git push $there --delete ''" should have been diagnosed as an |
|
error, but instead turned into a matching push, which has been |
|
corrected. |
|
(merge 20e416409f jc/push-delete-nothing later to maint). |
|
|
|
* Test script modernization. |
|
(merge 488acf15df sv/t7001-modernize later to maint). |
|
|
|
* An under-allocation for the untracked cache data has been corrected. |
|
(merge 6347d649bc jh/untracked-cache-fix later to maint). |
|
|
|
* Other code cleanup, docfix, build fix, etc. |
|
(merge e3f5da7e60 sg/t7800-difftool-robustify later to maint). |
|
(merge 9d336655ba js/doc-proto-v2-response-end later to maint). |
|
(merge 1b5b8cf072 jc/maint-column-doc-typofix later to maint). |
|
(merge 3a837b58e3 cw/pack-config-doc later to maint). |
|
(merge 01168a9d89 ug/doc-commit-approxidate later to maint). |
|
(merge b865734760 js/params-vs-args later to maint).
|
|
|