1Git v1.6.6 Release Notes 2======================== 3 4Notes on behaviour change 5------------------------- 6 7 * In this release, "git fsck" defaults to "git fsck --full" and 8 checks packfiles, and because of this it will take much longer to 9 complete than before. If you prefer a quicker check only on loose 10 objects (the old default), you can say "git fsck --no-full". This 11 has been supported by 1.5.4 and newer versions of git, so it is 12 safe to write it in your script even if you use slightly older git 13 on some of your machines. 14 15Preparing yourselves for compatibility issues in 1.7.0 16------------------------------------------------------ 17 18In git 1.7.0, which is planned to be the release after 1.6.6, there will 19be a handful of behaviour changes that will break backward compatibility. 20 21These changes were discussed long time ago and existing behaviours have 22been identified as more problematic to the userbase than keeping them for 23the sake of backward compatibility. 24 25When necessary, transition strategy for existing users has been designed 26not to force them running around setting configuration variables and 27updating their scripts in order to either keep the traditional behaviour 28or adjust to the new behaviour on the day their sysadmin decides to install 29the new version of git. When we switched from "git-foo" to "git foo" in 301.6.0, even though the change had been advertised and the transition 31guide had been provided for a very long time, the users procrastinated 32during the entire transtion period, and ended up panicking on the day 33their sysadmins updated their git installation. We are trying to avoid 34repeating that unpleasantness in the 1.7.0 release. 35 36For changes decided to be in 1.7.0, commands that will be affected 37have been much louder to strongly discourage such procrastination. If 38you have been using recent versions of git, you would have seen 39warnings issued when you exercised features whose behaviour will 40change, with a clear instruction on how to keep the existing behaviour 41if you want to. You hopefully are already well prepared. 42 43Of course, we have also been giving "this and that will change in 441.7.0; prepare yourselves" warnings in the release notes and 45announcement messages for the past few releases. Let's see how well 46users will fare this time. 47 48 * "git push" into a branch that is currently checked out (i.e. pointed by 49 HEAD in a repository that is not bare) will be refused by default. 50 51 Similarly, "git push $there :$killed" to delete the branch $killed 52 in a remote repository $there, when $killed branch is the current 53 branch pointed at by its HEAD, will be refused by default. 54 55 Setting the configuration variables receive.denyCurrentBranch and 56 receive.denyDeleteCurrent to 'ignore' in the receiving repository 57 can be used to override these safety features. Versions of git 58 since 1.6.2 have issued a loud warning when you tried to do these 59 operations without setting the configuration, so repositories of 60 people who still need to be able to perform such a push should 61 already have been future proofed. 62 63 Please refer to: 64 65 http://git.or.cz/gitwiki/GitFaq#non-bare 66 http://thread.gmane.org/gmane.comp.version-control.git/107758/focus=108007 67 68 for more details on the reason why this change is needed and the 69 transition process that already took place so far. 70 71 * "git send-email" will not make deep threads by default when sending a 72 patch series with more than two messages. All messages will be sent 73 as a reply to the first message, i.e. cover letter. Git 1.6.6 (this 74 release) will issue a warning about the upcoming default change, when 75 it uses the traditional "deep threading" behaviour as the built-in 76 default. To squelch the warning but still use the "deep threading" 77 behaviour, give --chain-reply-to option or set sendemail.chainreplyto 78 to true. 79 80 It has been possible to configure send-email to send "shallow thread" 81 by setting sendemail.chainreplyto configuration variable to false. 82 The only thing 1.7.0 release will do is to change the default when 83 you haven't configured that variable. 84 85 * "git status" will not be "git commit --dry-run". This change does not 86 affect you if you run the command without pathspec. 87 88 Nobody sane found the current behaviour of "git status Makefile" useful 89 nor meaningful, and it confused users. "git commit --dry-run" has been 90 provided as a way to get the current behaviour of this command since 91 1.6.5. 92 93 * "git diff" traditionally treated various "ignore whitespace" options 94 only as a way to filter the patch output. "git diff --exit-code -b" 95 exited with non-zero status even if all changes were about changing the 96 ammount of whitespace and nothing else. and "git diff -b" showed the 97 "diff --git" header line for such a change without patch text. 98 99 In 1.7.0, the "ignore whitespaces" will affect the semantics of the 100 diff operation itself. A change that does not affect anything but 101 whitespaces will be reported with zero exit status when run with 102 --exit-code, and there will not be "diff --git" header for such a 103 change. 104 105 106Updates since v1.6.5 107-------------------- 108 109(subsystems) 110 111 * various git-gui updates including new translations, wm states, etc. 112 113 * git-svn updates. 114 115 * "git fetch" over http learned a new mode that is different from the 116 traditional "dumb commit walker". 117 118(portability) 119 120 * imap-send can be built on mingw port. 121 122(performance) 123 124 * "git diff -B" has smaller memory footprint. 125 126(usability, bells and whistles) 127 128 * The object replace mechanism can be bypassed with --no-replace-objects 129 global option given to the "git" program. 130 131 * In configuration files, a few variables that name paths can begin with ~/ 132 and ~username/ and they are expanded as expected. 133 134 * "git subcmd -h" now shows short usage help for many more subcommands. 135 136 * "git bisect reset" can reset to an arbitrary commit. 137 138 * "git checkout frotz" when there is no local branch "frotz" but there 139 is only one remote tracking branch "frotz" is taken as a request to 140 start the named branch at the corresponding remote tracking branch. 141 142 * "git commit -c/-C/--amend" can be told with a new "--reset-author" option 143 to ignore authorship information in the commit it is taking the message 144 from. 145 146 * "git describe" can be told to add "-dirty" suffix with "--dirty" option. 147 148 * "git diff" learned --submodule option to show a list of one-line logs 149 instead of differences between the commit object names. 150 151 * "git diff" learned to honor diff.color.func configuration to paint 152 function name hint printed on the hunk header "@@ -j,k +l,m @@" line 153 in the specified color. 154 155 * "git fetch" learned --all and --multiple options, to run fetch from 156 many repositories, and --prune option to remove remote tracking 157 branches that went stale. These make "git remote update" and "git 158 remote prune" less necessary (there is no plan to remove "remote 159 update" nor "remote prune", though). 160 161 * "git fsck" by default checks the packfiles (i.e. "--full" is the 162 default); you can turn it off with "git fsck --no-full". 163 164 * "git grep" can use -F (fixed strings) and -i (ignore case) together. 165 166 * import-tars contributed fast-import frontend learned more types of 167 compressed tarballs. 168 169 * "git instaweb" knows how to talk with mod_cgid to apache2. 170 171 * "git log --decorate" shows the location of HEAD as well. 172 173 * "git log" and "git rev-list" learned to take revs and pathspecs from 174 the standard input with the new "--stdin" option. 175 176 * "--pretty=format" option to "log" family of commands learned: 177 178 . to wrap text with the "%w()" specifier. 179 . to show reflog information with "%g[sdD]" specifier. 180 181 * "git notes" command to annotate existing commits. 182 183 * "git merge" (and "git pull") learned --ff-only option to make it fail 184 if the merge does not result in a fast-forward. 185 186 * "git mergetool" learned to use p4merge. 187 188 * "git rebase -i" learned "reword" that acts like "edit" but immediately 189 starts an editor to tweak the log message without returning control to 190 the shell, which is done by "edit" to give an opportunity to tweak the 191 contents. 192 193 * "git send-email" can be told with "--envelope-sender=auto" to use the 194 same address as "From:" address as the envelope sender address. 195 196 * "git send-email" will issue a warning when it defaults to the 197 --chain-reply-to behaviour without being told by the user and 198 instructs to prepare for the change of the default in 1.7.0 release. 199 200 * In "git submodule add <repository> <path>", <path> is now optional and 201 inferred from <repository> the same way "git clone <repository>" does. 202 203 * "git svn" learned to read SVN 1.5+ and SVK merge tickets. 204 205 * "gitweb" can optionally render its "blame" output incrementally (this 206 requires JavaScript on the client side). 207 208 * Author names shown in gitweb output are links to search commits by the 209 author. 210 211 212(developers) 213 214Fixes since v1.6.5 215------------------ 216 217All of the fixes in v1.6.5.X maintenance series are included in this 218release, unless otherwise noted. 219 220 * Enumeration of available merge strategies iterated over the list of 221 commands in a wrong way, sometimes producing an incorrect result. 222 Will backport by merging ed87465 (builtin-merge.c: call 223 exclude_cmds() correctly., 2009-11-25). 224 225 * "git format-patch revisions... -- path" issued an incorrect error 226 message that suggested to use "--" on the command line when path 227 does not exist in the current work tree (it is a separate matter if 228 it makes sense to limit format-patch with pathspecs like that 229 without using the --full-diff option). Will backport by merging 230 7e93d3b (format-patch: add test for parsing of "--", 2009-11-26). 231 232 * "git shortlog" did not honor the "encoding" header embedded in the 233 commit object like "git log" did. Will backport by merging 79f7ca0 234 (shortlog: respect commit encoding, 2009-11-25). 235 236--- 237exec >/var/tmp/1 238echo O=$(git describe master) 239O=v1.6.6-rc1-52-gff86bdd 240git shortlog --no-merges $O..master --not maint