|
|
|
Git 2.28 Release Notes
|
|
|
|
======================
|
|
|
|
|
|
|
|
Updates since v2.27
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
Backward compatibility notes
|
|
|
|
|
|
|
|
* "fetch.writeCommitGraph" is deemed to be still a bit too risky and
|
|
|
|
is no longer part of the "feature.experimental" set.
|
|
|
|
|
|
|
|
|
|
|
|
UI, Workflows & Features
|
|
|
|
|
|
|
|
* The commands in the "diff" family learned to honor "diff.relative"
|
|
|
|
configuration variable.
|
|
|
|
|
|
|
|
* The check in "git fsck" to ensure that the tree objects are sorted
|
|
|
|
still had corner cases it missed unsorted entries.
|
|
|
|
|
|
|
|
* The interface to redact sensitive information in the trace output
|
|
|
|
has been simplified.
|
|
|
|
|
|
|
|
* The command line completion (in contrib/) learned to complete
|
|
|
|
options that the "git switch" command takes.
|
|
|
|
|
|
|
|
* "git diff" used to take arguments in random and nonsense range
|
|
|
|
notation, e.g. "git diff A..B C", "git diff A..B C...D", etc.,
|
|
|
|
which has been cleaned up.
|
|
|
|
|
|
|
|
* "git diff-files" has been taught to say paths that are marked as
|
|
|
|
intent-to-add are new files, not modified from an empty blob.
|
|
|
|
|
|
|
|
* "git status" learned to report the status of sparse checkout.
|
|
|
|
|
|
|
|
* "git difftool" has trouble dealing with paths added to the index
|
|
|
|
with the intent-to-add bit.
|
|
|
|
|
|
|
|
* "git fast-export --anonymize" learned to take customized mapping to
|
|
|
|
allow its users to tweak its output more usable for debugging.
|
|
|
|
|
|
|
|
* The command line completion support (in contrib/) used to be
|
|
|
|
prepared to work with "set -u" but recent changes got a bit more
|
|
|
|
sloppy. This has been corrected.
|
|
|
|
|
|
|
|
* "git gui" now allows opening work trees from the start-up dialog.
|
|
|
|
|
|
|
|
|
|
|
|
Performance, Internal Implementation, Development Support etc.
|
|
|
|
|
|
|
|
* Code optimization for a common case.
|
|
|
|
(merge 8777616e4d an/merge-single-strategy-optim later to maint).
|
|
|
|
|
|
|
|
* We've adopted a convention that any on-stack structure can be
|
|
|
|
initialized to have zero values in all fields with "= { 0 }",
|
|
|
|
even when the first field happens to be a pointer, but sparse
|
|
|
|
complained that a null pointer should be spelled NULL for a long
|
|
|
|
time. Start using -Wno-universal-initializer option to squelch
|
|
|
|
it (the latest sparse has it on by default).
|
|
|
|
|
|
|
|
* "git log -L..." now takes advantage of the "which paths are touched
|
|
|
|
by this commit?" info stored in the commit-graph system.
|
|
|
|
|
|
|
|
* As FreeBSD is not the only platform whose regexp library reports
|
|
|
|
a REG_ILLSEQ error when fed invalid UTF-8, add logic to detect that
|
|
|
|
automatically and skip the affected tests.
|
|
|
|
|
|
|
|
* "git bugreport" learns to report what shell is in use.
|
|
|
|
|
|
|
|
* Support for GIT_CURL_VERBOSE has been rewritten in terms of
|
|
|
|
GIT_TRACE_CURL.
|
|
|
|
|
|
|
|
* Preliminary clean-ups around refs API, plus file format
|
|
|
|
specification documentation for the reftable backend.
|
|
|
|
|
|
|
|
* Workaround breakage in MSVC build, where "curl-config --cflags"
|
|
|
|
gives settings appropriate for GCC build.
|
|
|
|
|
|
|
|
* Code clean-up of "git clean" resulted in a fix of recent
|
|
|
|
performance regression.
|
|
|
|
|
|
|
|
* Code clean-up in the codepath that serves "git fetch" continues.
|
|
|
|
|
|
|
|
* "git merge-base --is-ancestor" is taught to take advantage of the
|
|
|
|
commit graph.
|
|
|
|
|
|
|
|
* Rewrite of parts of the scripted "git submodule" Porcelain command
|
|
|
|
continues; this time it is "git submodule set-branch" subcommand's
|
|
|
|
turn.
|
|
|
|
|
|
|
|
* The "fetch/clone" protocol has been updated to allow the server to
|
|
|
|
instruct the clients to grab pre-packaged packfile(s) in addition
|
|
|
|
to the packed object data coming over the wire.
|
|
|
|
|
|
|
|
* A misdesigned strbuf_write_fd() function has been retired.
|
|
|
|
|
|
|
|
* SHA-256 migration work continues, including CVS/SVN interface.
|
|
|
|
|
|
|
|
* A few fields in "struct commit" that do not have to always be
|
|
|
|
present have been moved to commit slabs.
|
|
|
|
|
|
|
|
* API cleanup for get_worktrees()
|
|
|
|
|
|
|
|
* By renumbering object flag bits, "struct object" managed to lose
|
|
|
|
bloated inter-field padding.
|
|
|
|
|
|
|
|
* The name of the primary branch in existing repositories, and the
|
|
|
|
default name used for the first branch in newly created
|
|
|
|
repositories, is made configurable, so that we can eventually wean
|
|
|
|
ourselves off of the hardcoded 'master'.
|
|
|
|
|
|
|
|
* The effort to avoid using test_must_fail on non-git command continues.
|
|
|
|
|
|
|
|
* In 2.28-rc0, we corrected a bug that some repository extensions are
|
|
|
|
honored by mistake even in a version 0 repositories (these
|
|
|
|
configuration variables in extensions.* namespace were supposed to
|
|
|
|
have special meaning in repositories whose version numbers are 1 or
|
|
|
|
higher), but this was a bit too big a change. The behaviour in
|
|
|
|
recent versions of Git where certain extensions.* were honored by
|
|
|
|
mistake even in version 0 repositories has been restored.
|
|
|
|
|
|
|
|
|
|
|
|
Fixes since v2.27
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
* The "--prepare-p4-only" option of "git p4" is supposed to stop
|
|
|
|
after replaying one changeset, but kept going (by mistake?)
|
|
|
|
|
|
|
|
* The error message from "git checkout -b foo -t bar baz" was
|
|
|
|
confusing.
|
|
|
|
|
|
|
|
* Some repositories in the wild have commits that record nonsense
|
|
|
|
committer timezone (e.g. rails.git); "git fast-import" learned an
|
|
|
|
option to pass these nonsense timestamps intact to allow recreating
|
|
|
|
existing repositories as-is.
|
|
|
|
(merge d42a2fb72f en/fast-import-looser-date later to maint).
|
|
|
|
|
|
|
|
* The command line completion script (in contrib/) tried to complete
|
|
|
|
"git stash -p" as if it were "git stash push -p", but it was too
|
|
|
|
aggressive and also affected "git stash show -p", which has been
|
|
|
|
corrected.
|
|
|
|
(merge fffd0cf520 vs/complete-stash-show-p-fix later to maint).
|
|
|
|
|
|
|
|
* On-the-wire protocol v2 easily falls into a deadlock between the
|
|
|
|
remote-curl helper and the fetch-pack process when the server side
|
|
|
|
prematurely throws an error and disconnects. The communication has
|
|
|
|
been updated to make it more robust.
|
|
|
|
|
|
|
|
* "git checkout -p" did not handle a newly added path at all.
|
|
|
|
(merge 2c8bd8471a js/checkout-p-new-file later to maint).
|
|
|
|
|
|
|
|
* The code to parse "git bisect start" command line was lax in
|
|
|
|
validating the arguments.
|
|
|
|
(merge 4d9005ff5d cb/bisect-helper-parser-fix later to maint).
|
|
|
|
|
|
|
|
* Reduce memory usage during "diff --quiet" in a worktree with too
|
|
|
|
many stat-unmatched paths.
|
|
|
|
(merge d2d7fbe129 jk/diff-memuse-optim-with-stat-unmatch later to maint).
|
|
|
|
|
|
|
|
* The reflog entries for "git clone" and "git fetch" did not
|
|
|
|
anonymize the URL they operated on.
|
|
|
|
(merge 46da295a77 js/reflog-anonymize-for-clone-and-fetch later to maint).
|
|
|
|
|
|
|
|
* The behaviour of "sparse-checkout" in the state "git clone
|
|
|
|
--no-checkout" left was changed accidentally in 2.27, which has
|
|
|
|
been corrected.
|
|
|
|
|
|
|
|
* Use of negative pathspec, while collecting paths including
|
|
|
|
untracked ones in the working tree, was broken.
|
|
|
|
|
|
|
|
* The same worktree directory must be registered only once, but
|
|
|
|
"git worktree move" allowed this invariant to be violated, which
|
|
|
|
has been corrected.
|
|
|
|
(merge 810382ed37 es/worktree-duplicate-paths later to maint).
|
|
|
|
|
|
|
|
* The effect of sparse checkout settings on submodules is documented.
|
|
|
|
(merge e7d7c73249 en/sparse-with-submodule-doc later to maint).
|
|
|
|
|
|
|
|
* Code clean-up around "git branch" with a minor bugfix.
|
|
|
|
(merge dc44639904 dl/branch-cleanup later to maint).
|
|
|
|
|
|
|
|
* A branch name used in a test has been clarified to match what is
|
|
|
|
going on.
|
|
|
|
(merge 08dc26061f pb/t4014-unslave later to maint).
|
|
|
|
|
|
|
|
* An in-code comment in "git diff" has been updated.
|
|
|
|
(merge c592fd4c83 dl/diff-usage-comment-update later to maint).
|
|
|
|
|
|
|
|
* The documentation and some tests have been adjusted for the recent
|
|
|
|
renaming of "pu" branch to "seen".
|
|
|
|
(merge 6dca5dbf93 js/pu-to-seen later to maint).
|
|
|
|
|
|
|
|
* The code to push changes over "dumb" HTTP had a bad interaction
|
|
|
|
with the commit reachability code due to incorrect allocation of
|
|
|
|
object flag bits, which has been corrected.
|
|
|
|
(merge 64472d15e9 bc/http-push-flagsfix later to maint).
|
|
|
|
|
|
|
|
* "git send-email --in-reply-to=<msg>" did not use the In-Reply-To:
|
|
|
|
header with the value given from the command line, and let it be
|
|
|
|
overridden by the value on In-Reply-To: header in the messages
|
|
|
|
being sent out (if exists).
|
|
|
|
(merge f9f60d7066 ra/send-email-in-reply-to-from-command-line-wins later to maint).
|
|
|
|
|
|
|
|
* "git log -Lx,y:path --before=date" lost track of where the range
|
|
|
|
should be because it didn't take the changes made by the youngest
|
|
|
|
commits that are omitted from the output into account.
|
|
|
|
|
|
|
|
* When "fetch.writeCommitGraph" configuration is set in a shallow
|
|
|
|
repository and a fetch moves the shallow boundary, we wrote out
|
|
|
|
broken commit-graph files that do not match the reality, which has
|
|
|
|
been corrected.
|
|
|
|
|
|
|
|
* "git checkout" failed to catch an error from fstat() after updating
|
|
|
|
a path in the working tree.
|
|
|
|
(merge 35e6e212fd mt/entry-fstat-fallback-fix later to maint).
|
|
|
|
|
|
|
|
* When an aliased command, whose output is piped to a pager by git,
|
|
|
|
gets killed by a signal, the pager got into a funny state, which
|
|
|
|
has been corrected (again).
|
|
|
|
(merge c0d73a59c9 ta/wait-on-aliased-commands-upon-signal later to maint).
|
|
|
|
|
|
|
|
* The code to produce progress output from "git commit-graph --write"
|
|
|
|
had a few breakages, which have been fixed.
|
|
|
|
|
|
|
|
* Other code cleanup, docfix, build fix, etc.
|
|
|
|
(merge 2c31a7aa44 jx/pkt-line-doc-count-fix later to maint).
|
|
|
|
(merge d63ae31962 cb/t5608-cleanup later to maint).
|
|
|
|
(merge 788db145c7 dl/t-readme-spell-git-correctly later to maint).
|
|
|
|
(merge 45a87a83bb dl/python-2.7-is-the-floor-version later to maint).
|
|
|
|
(merge b75a219904 es/advertise-contribution-doc later to maint).
|
|
|
|
(merge 0c9a4f638a rs/pull-leakfix later to maint).
|
|
|
|
(merge d546fe2874 rs/commit-reach-leakfix later to maint).
|
|
|
|
(merge 087bf5409c mk/pb-pretty-email-without-domain-part-fix later to maint).
|
|
|
|
(merge 5f4ee57ad9 es/worktree-code-cleanup later to maint).
|
|
|
|
(merge 0172f7834a cc/cat-file-usage-update later to maint).
|
|
|
|
(merge 81de0c01cf ma/rebase-doc-typofix later to maint).
|