Avoid segfault with 'git branch' when the HEAD is detached
[git/ericb.git] / Documentation / RelNotes-1.6.2.txt
blob6ed31595baa2325c224948ef7ddb75f62d5b2fb2
1 GIT v1.6.2 Release Notes
2 ========================
4 With the next major release, "git push" into a branch that is
5 currently checked out will be refused by default.  You can choose
6 what should happen upon such a push by setting the configuration
7 variable receive.denyCurrentBranch in the receiving repository.
9 To ease the transition plan, the receiving repository of such a
10 push running this release will issue a big warning when the
11 configuration variable is missing.  Please refer to:
13   http://thread.gmane.org/gmane.comp.version-control.git/107758/focus=108007
15 for more details on the transition plan.
18 Updates since v1.6.1
19 --------------------
21 (subsystems)
23 * git-svn updates.
25 * gitweb updates, including a new patch view and RSS/Atom feed
26   improvements.
28 * (contrib/emacs) git.el now has commands for checking out a branch,
29   creating a branch, cherry-picking and reverting commits; vc-git.el
30   is not shipped with git anymore (it is part of official Emacs).
32 (performance)
34 * pack-objects autodetects the number of CPUs available and uses threaded
35   version.
37 (usability, bells and whistles)
39 * automatic typo correction works on aliases as well
41 * @{-1} is a way to refer to the last branch you were on.  This is
42   accepted not only where an object name is expected, but anywhere
43   a branch name is expected.  E.g. "git branch --track mybranch @{-1}"
44   "git rev-parse --symbolic-full-name @{-1}".
46 * "git add -p" learned 'g'oto action to jump directly to a hunk.
48 * "git add -p" learned to find a hunk with given text with '/'.
50 * "git add -p" optionally can be told to work with just the command letter
51   without Enter.
53 * when "git am" stops upon a patch that does not apply, it shows the
54   title of the offending patch.
56 * "git am --directory=<dir>" and "git am --reject" passes these options
57   to underlying "git apply".
59 * "git am" learned --ignore-date option.
61 * "git blame" aligns author names better when they are spelled in
62   non US-ASCII encoding.
64 * "git clone" now makes its best effort when cloning from an empty
65   repository to set up configuration variables to refer to the remote
66   repository.
68 * "git checkout -" is a shorthand for "git checkout @{-1}".
70 * "git cherry" defaults to whatever the current branch is tracking (if
71   exists) when the <upstream> argument is not given.
73 * "git cvsserver" can be told not to add extra "via git-CVS emulator" to
74   the commit log message it serves via gitcvs.commitmsgannotation
75   configuration.
77 * "git cvsserver" learned to handle 'noop' command some CVS clients seem
78   to expect to work.
80 * "git diff" learned a new option --inter-hunk-context to coalesce close
81   hunks together and show context between them.
83 * The definition of what constitutes a word for "git diff --color-words"
84   can be customized via gitattributes, command line or a configuration.
86 * "git diff" learned --patience to run "patience diff" algorithm.
88 * "git filter-branch" learned --prune-empty option that discards commits
89   that do not change the contents.
91 * "git fsck" now checks loose objects in alternate object stores, instead
92   of misreporting them as missing.
94 * "git grep -w" and "git grep" for fixed strings have been optimized.
96 * "git mergetool" learned -y(--no-prompt) option to disable prompting.
98 * "git rebase -i" can transplant a history down to root to elsewhere
99   with --root option.
101 * "git reset --merge" is a new mode that works similar to the way
102   "git checkout" switches branches, taking the local changes while
103   switching to another commit.
105 * "git tag" learned --contains that works the same way as the same option
106   from "git branch".
109 Fixes since v1.6.1
110 ------------------
112 All of the fixes in v1.6.1.X maintenance series are included in this
113 release, unless otherwise noted.
115 Here are fixes that this release has, but have not been backported to
116 v1.6.1.X series.
118 * "git-add sub/file" when sub is a submodule incorrectly added the path to
119   the superproject.
121 * "git bundle" did not exclude annotated tags even when a range given
122   from the command line wanted to.
124 * "git filter-branch" unnecessarily refused to work when you had
125   checked out a different commit from what is recorded in the superproject
126   index in a submodule.
128 * "git filter-branch" incorrectly tried to update a nonexistent work tree
129   at the end when it is run in a bare repository.
131 * "git mergetool" used to ignore autocrlf and other attributes
132   based content rewriting.
134 * branch switching and merges had a silly bug that did not validate
135   the correct directory when making sure an existing subdirectory is
136   clean.
138 * "git -p cmd" when cmd is not a built-in one left the display in funny state
139   when killed in the middle.
142 exec >/var/tmp/1
143 O=v1.6.1.3-371-gc19923a
144 echo O=$(git describe master)
145 git shortlog --no-merges $O..master ^maint