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