2021-01-07 08:22:15 +01:00
|
|
|
Git 2.31 Release Notes
|
|
|
|
======================
|
|
|
|
|
|
|
|
Updates since v2.30
|
|
|
|
-------------------
|
|
|
|
|
2021-01-25 23:04:49 +01:00
|
|
|
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.
|
|
|
|
|
2021-02-10 23:39:30 +01:00
|
|
|
* The support for deprecated PCRE1 library has been dropped.
|
|
|
|
|
2021-01-25 23:04:49 +01:00
|
|
|
|
2021-01-07 08:22:15 +01:00
|
|
|
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.
|
|
|
|
|
2021-01-16 00:03:23 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-01-16 06:48:20 +01:00
|
|
|
* "git maintenance" learned to drive scheduled maintenance on
|
|
|
|
platforms whose native scheduling methods are not 'cron'.
|
|
|
|
|
2021-01-25 23:04:49 +01:00
|
|
|
* 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.
|
2021-01-07 08:22:15 +01:00
|
|
|
|
2021-02-06 01:40:31 +01:00
|
|
|
* "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.
|
|
|
|
|
2021-02-10 23:39:30 +01:00
|
|
|
* `git worktree list` now annotates worktrees as prunable, shows
|
|
|
|
locked and prunable attributes in --porcelain mode, and gained
|
|
|
|
a --verbose option.
|
|
|
|
|
2021-02-06 01:40:31 +01:00
|
|
|
|
2021-01-07 08:22:15 +01:00
|
|
|
Performance, Internal Implementation, Development Support etc.
|
|
|
|
|
|
|
|
* A 3-year old test that was not testing anything useful has been
|
|
|
|
corrected.
|
|
|
|
|
2021-01-16 00:03:23 +01:00
|
|
|
* Retire more names with "sha1" in it.
|
|
|
|
|
|
|
|
* The topological walk codepath is covered by new trace2 stats.
|
|
|
|
|
2021-01-25 23:04:49 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-02-03 23:56:47 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-02-06 01:40:31 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-02-10 23:39:30 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-02-12 23:13:40 +01:00
|
|
|
* Introduce an on-disk file to record revindex for packdata, which
|
|
|
|
traditionally was always created on the fly and only in-core.
|
|
|
|
|
2021-01-07 08:22:15 +01:00
|
|
|
|
|
|
|
Fixes since v2.30
|
|
|
|
-----------------
|
|
|
|
|
2021-01-16 00:03:23 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-01-16 06:48:20 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-01-25 23:04:49 +01:00
|
|
|
* 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.
|
|
|
|
|
2021-02-03 23:56:47 +01:00
|
|
|
* Documentation for "git fsck" lost stale bits that has become
|
|
|
|
incorrect.
|
|
|
|
|
|
|
|
* Doc fix for packfile URI feature.
|
2021-02-10 23:39:30 +01:00
|
|
|
|
|
|
|
* 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).
|
2021-02-03 23:56:47 +01:00
|
|
|
|
2021-02-12 23:13:40 +01:00
|
|
|
* 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).
|
|
|
|
|
2021-01-07 08:22:15 +01:00
|
|
|
* Other code cleanup, docfix, build fix, etc.
|
2021-02-10 23:39:30 +01:00
|
|
|
(merge e3f5da7e60 sg/t7800-difftool-robustify later to maint).
|