|
|
|
Git v2.5.1 Release Notes
|
|
|
|
========================
|
|
|
|
|
|
|
|
Fixes since v2.5
|
|
|
|
----------------
|
|
|
|
|
|
|
|
* Running an aliased command from a subdirectory when the .git thing
|
|
|
|
in the working tree is a gitfile pointing elsewhere did not work.
|
|
|
|
|
|
|
|
* Often a fast-import stream builds a new commit on top of the
|
|
|
|
previous commit it built, and it often unconditionally emits a
|
|
|
|
"from" command to specify the first parent, which can be omitted in
|
|
|
|
such a case. This caused fast-import to forget the tree of the
|
|
|
|
previous commit and then re-read it from scratch, which was
|
|
|
|
inefficient. Optimize for this common case.
|
|
|
|
|
|
|
|
* The "rev-parse --parseopt" mode parsed the option specification
|
|
|
|
and the argument hint in a strange way to allow '=' and other
|
|
|
|
special characters in the option name while forbidding them from
|
|
|
|
the argument hint. This made it impossible to define an option
|
|
|
|
like "--pair <key>=<value>" with "pair=key=value" specification,
|
|
|
|
which instead would have defined a "--pair=key <value>" option.
|
|
|
|
|
|
|
|
* A "rebase" replays changes of the local branch on top of something
|
|
|
|
else, as such they are placed in stage #3 and referred to as
|
|
|
|
"theirs", while the changes in the new base, typically a foreign
|
|
|
|
work, are placed in stage #2 and referred to as "ours". Clarify
|
|
|
|
the "checkout --ours/--theirs".
|
|
|
|
|
|
|
|
* An experimental "untracked cache" feature used uname(2) in a
|
|
|
|
slightly unportable way.
|
|
|
|
|
|
|
|
* "sparse checkout" misbehaved for a path that is excluded from the
|
|
|
|
checkout when switching between branches that differ at the path.
|
|
|
|
|
|
|
|
* The low-level "git send-pack" did not honor 'user.signingkey'
|
|
|
|
configuration variable when sending a signed-push.
|
|
|
|
|
|
|
|
* An attempt to delete a ref by pushing into a repository whose HEAD
|
|
|
|
symbolic reference points at an unborn branch that cannot be
|
|
|
|
created due to ref D/F conflict (e.g. refs/heads/a/b exists, HEAD
|
|
|
|
points at refs/heads/a) failed.
|
|
|
|
|
|
|
|
* "git subtree" (in contrib/) depended on "git log" output to be
|
|
|
|
stable, which was a no-no. Apply a workaround to force a
|
|
|
|
particular date format.
|
|
|
|
|
|
|
|
* "git clone $URL" in recent releases of Git contains a regression in
|
|
|
|
the code that invents a new repository name incorrectly based on
|
|
|
|
the $URL. This has been corrected.
|
|
|
|
(merge db2e220 jk/guess-repo-name-regression-fix later to maint).
|
|
|
|
|
|
|
|
* Running tests with the "-x" option to make them verbose had some
|
|
|
|
unpleasant interactions with other features of the test suite.
|
|
|
|
(merge 9b5fe78 jk/test-with-x later to maint).
|
|
|
|
|
|
|
|
* "git pull" in recent releases of Git has a regression in the code
|
|
|
|
that allows custom path to the --upload-pack=<program>. This has
|
|
|
|
been corrected.
|
|
|
|
|
|
|
|
* pipe() emulation used in Git for Windows looked at a wrong variable
|
|
|
|
when checking for an error from an _open_osfhandle() call.
|
|
|
|
|
|
|
|
Also contains typofixes, documentation updates and trivial code
|
|
|
|
clean-ups.
|