|
|
|
Git v1.7.0 Release Notes
|
|
|
|
========================
|
|
|
|
|
|
|
|
Notes on behaviour change
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
* "git push" into a branch that is currently checked out (i.e. pointed by
|
|
|
|
HEAD in a repository that is not bare) is refused by default.
|
|
|
|
|
|
|
|
Similarly, "git push $there :$killed" to delete the branch $killed
|
|
|
|
in a remote repository $there, when $killed branch is the current
|
|
|
|
branch pointed at by its HEAD, will be refused by default.
|
|
|
|
|
|
|
|
Setting the configuration variables receive.denyCurrentBranch and
|
|
|
|
receive.denyDeleteCurrent to 'ignore' in the receiving repository
|
|
|
|
can be used to override these safety features.
|
|
|
|
|
|
|
|
* "git send-email" does not make deep threads by default when sending a
|
|
|
|
patch series with more than two messages. All messages will be sent
|
|
|
|
as a reply to the first message, i.e. cover letter.
|
|
|
|
|
|
|
|
It has been possible to configure send-email to send "shallow thread"
|
|
|
|
by setting sendemail.chainreplyto configuration variable to false. The
|
|
|
|
only thing this release does is to change the default when you haven't
|
|
|
|
configured that variable.
|
|
|
|
|
|
|
|
* "git status" is not "git commit --dry-run" anymore. This change does
|
|
|
|
not affect you if you run the command without pathspec.
|
|
|
|
|
|
|
|
* "git diff" traditionally treated various "ignore whitespace" options
|
|
|
|
only as a way to filter the patch output. "git diff --exit-code -b"
|
|
|
|
exited with non-zero status even if all changes were about changing the
|
|
|
|
ammount of whitespace and nothing else. and "git diff -b" showed the
|
|
|
|
"diff --git" header line for such a change without patch text.
|
|
|
|
|
|
|
|
In this release, the "ignore whitespaces" options affect the semantics
|
|
|
|
of the diff operation. A change that does not affect anything but
|
|
|
|
whitespaces is reported with zero exit status when run with
|
|
|
|
--exit-code, and there is no "diff --git" header for such a change.
|
|
|
|
|
|
|
|
|
|
|
|
Updates since v1.6.6
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
(subsystems)
|
|
|
|
|
|
|
|
* "git fast-import" updates; adds "option" and "feature" to detect the
|
|
|
|
mismatch between fast-import and the frontends that produce the input
|
|
|
|
stream.
|
|
|
|
|
|
|
|
* "git svn" support of subversion "merge tickets" and miscellaneous fixes.
|
|
|
|
|
|
|
|
* "gitk" updates.
|
|
|
|
|
|
|
|
(portability)
|
|
|
|
|
|
|
|
* Some more MSVC portability patches for msysgit port.
|
|
|
|
|
|
|
|
* Minimum Pthreads emulation for msysgit port.
|
|
|
|
|
|
|
|
(performance)
|
|
|
|
|
|
|
|
* More performance improvement patches for msysgit port.
|
|
|
|
|
|
|
|
(usability, bells and whistles)
|
|
|
|
|
|
|
|
* More commands learned "--quiet" and "--[no-]progress" options.
|
|
|
|
|
|
|
|
* Various commands given by the end user (e.g. diff.type.textconv,
|
|
|
|
and GIT_EDITOR) can be specified with command line arguments. E.g. it
|
|
|
|
is now possible to say "[diff "utf8doc"] textconv = nkf -w".
|
|
|
|
|
|
|
|
* "sparse checkout" feature allows only part of the work tree to be
|
|
|
|
checked out.
|
|
|
|
|
|
|
|
* HTTP transfer can use authentication scheme other than basic
|
|
|
|
(i.e./e.g. digest).
|
|
|
|
|
|
|
|
* Switching from a version of superproject that used to have a submodule
|
|
|
|
to another version of superproject that no longer has it did not remove
|
|
|
|
the submodule directory when it should (namely, when you are not
|
|
|
|
interested in the submodule at all and didn't clone/checkout).
|
|
|
|
|
|
|
|
* A new attribute conflict-marker-size can be used to change the size of
|
|
|
|
the conflict markers from the default 7; this is useful when tracked
|
|
|
|
contents (e.g. git-merge documentation) have strings that resemble the
|
|
|
|
conflict markers.
|
|
|
|
|
|
|
|
* A new syntax "<branch>@{upstream}" can be used on the command line to
|
|
|
|
substitute the name of the "upstream" of the branch. Missing branch
|
|
|
|
defaults to the current branch, so "git fetch && git merge @{upstream}"
|
|
|
|
will be equivalent to "git pull".
|
|
|
|
|
|
|
|
* "git branch --set-upstream" can be used to update the (surprise!) upstream
|
|
|
|
i.e. where the branch is supposed to pull and merge from (or rebase onto).
|
|
|
|
|
|
|
|
* "git checkout A...B" is a way to detach HEAD at the merge base between
|
|
|
|
A and B.
|
|
|
|
|
|
|
|
* "git checkout -m path" to reset the work tree file back into the
|
|
|
|
conflicted state works even when you already ran "git add path" and
|
|
|
|
resolved the conflicts.
|
|
|
|
|
|
|
|
* "git commit --date='<date>'" can be used to override the author date
|
|
|
|
just like "git commit --author='<name> <email>'" can be used to
|
|
|
|
override the author identity.
|
|
|
|
|
|
|
|
* "git commit --no-status" can be used to omit the listing of the index
|
|
|
|
and the work tree status in the editor used to prepare the log message.
|
|
|
|
|
|
|
|
* "git commit" warns a bit more aggressively until you configure user.email,
|
|
|
|
whose default value almost always is not (and fundamentally cannot be)
|
|
|
|
what you want.
|
|
|
|
|
|
|
|
* "git difftool" has been extended to make it easier to integrate it
|
|
|
|
with gitk.
|
|
|
|
|
|
|
|
* "git fetch --all" can now be used in place of "git remote update".
|
|
|
|
|
|
|
|
* "git grep" does not rely on external grep anymore. It can use more than
|
|
|
|
one threads to accelerate the operation.
|
|
|
|
|
|
|
|
* "git grep" learned "--no-index" option, to search inside contents that
|
|
|
|
are not managed by git.
|
|
|
|
|
|
|
|
* "git grep" learned "--quiet" option.
|
|
|
|
|
|
|
|
* "git log" and friends learned "--glob=heads/*" syntax that is a more
|
|
|
|
flexible way to complement "--branches/--tags/--remotes".
|
|
|
|
|
|
|
|
* "git merge" learned to pass options specific to strategy-backends. E.g.
|
|
|
|
|
|
|
|
- "git merge -Xsubtree=path/to/directory" can be used to tell the subtree
|
|
|
|
strategy how much to shift the trees explicitly.
|
|
|
|
|
|
|
|
- "git merge -Xtheirs" can be used to auto-merge as much as possible,
|
|
|
|
while discarding your own changes and taking merged version in
|
|
|
|
conflicted regions.
|
|
|
|
|
|
|
|
* "git push" learned "git push origin --delete branch", a syntactic sugar
|
|
|
|
for "git push origin :branch".
|
|
|
|
|
|
|
|
* "git push" learned "git push --set-upstream origin forker:forkee" that
|
|
|
|
lets you configure your "forker" branch to later pull from "forkee"
|
|
|
|
branch at "origin".
|
|
|
|
|
|
|
|
* "git rebase --onto A...B" means the history is replayed on top of the
|
|
|
|
merge base between A and B.
|
|
|
|
|
|
|
|
* "git rebase -i" learned new action "fixup", that squashes the change
|
|
|
|
but does not affect existing log message.
|
|
|
|
|
|
|
|
* "git rebase -i" also learned --autosquash option, that is useful
|
|
|
|
together with the new "fixup" action.
|
|
|
|
|
|
|
|
* "git remote" learned set-url subcommand, to update (surprise!) url
|
|
|
|
for an existing remote nickname.
|
|
|
|
|
|
|
|
* "git rerere" learned "forget path" subcommand. Together with "git
|
|
|
|
checkout -m path" it will be useful when you recorded a wrong
|
|
|
|
resolution.
|
|
|
|
|
|
|
|
* Use of "git reset --merge" has become easier when resetting away a
|
|
|
|
conflicted mess left in the work tree.
|
|
|
|
|
|
|
|
* "git rerere" had rerere.autoupdate configuration but there was no way
|
|
|
|
to countermand it from the command line; --no-rerere-autoupdate option
|
|
|
|
given to "merge", "revert", etc. fixes this.
|
|
|
|
|
|
|
|
* "git status" learned "-s(hort)" output format.
|
|
|
|
|
|
|
|
(developers)
|
|
|
|
|
|
|
|
* The infrastructure to build foreign SCM interface has been updated.
|
|
|
|
|
|
|
|
* Many more commands are now built-in.
|
|
|
|
|
|
|
|
Fixes since v1.6.6
|
|
|
|
------------------
|
|
|
|
|
|
|
|
All of the fixes in v1.6.6.X maintenance series are included in this
|
|
|
|
release, unless otherwise noted.
|
|
|
|
|
|
|
|
* "git branch -d branch" used to refuse deleting the branch even when
|
|
|
|
the branch is fully merged to its upstream branch if it is not merged
|
|
|
|
to the current branch. It now deletes it in such a case.
|
|
|
|
|
|
|
|
* "git config -f <relative path>" run from a subdirectory misbehaved.
|
|
|
|
65807ee (builtin-config: Fix crash when using "-f <relative path>"
|
|
|
|
from non-root dir, 2010-01-26) may be merged to older maintenance
|
|
|
|
branches.
|
|
|
|
|
|
|
|
* When "git diff" is asked to compare the work tree with something,
|
|
|
|
it used to consider that a checked-out submodule with uncommitted
|
|
|
|
changes is not modified; this could cause people to forget committing
|
|
|
|
these changes in the submodule before committing in the superproject.
|
|
|
|
It now considers such a change as a modification.
|
|
|
|
|
|
|
|
--
|
|
|
|
exec >/var/tmp/1
|
|
|
|
O=v1.7.0-rc0-48-gdace5dd
|
|
|
|
O=v1.7.0-rc0-67-gb10b918
|
|
|
|
echo O=$(git describe master)
|
|
|
|
git shortlog --no-merges $O..master ^maint
|