|  | Git 1.7.12.1 Release Notes | 
|  | ========================== | 
|  |  | 
|  | Fixes since v1.7.12 | 
|  | ------------------- | 
|  |  | 
|  | * "git apply -p0" did not parse pathnames on "diff --git" line | 
|  | correctly.  This caused patches that had pathnames in no other | 
|  | places to be mistakenly rejected (most notably, binary patch that | 
|  | does not rename nor change mode).  Textual patches, renames or mode | 
|  | changes have preimage and postimage pathnames in different places | 
|  | in a form that can be parsed unambiguously and did not suffer from | 
|  | this problem. | 
|  |  | 
|  | * "git cherry-pick A C B" used to replay changes in A and then B and | 
|  | then C if these three commits had committer timestamps in that | 
|  | order, which is not what the user who said "A C B" naturally | 
|  | expects. | 
|  |  | 
|  | * "git commit --amend" let the user edit the log message and then | 
|  | died when the human-readable committer name was given | 
|  | insufficiently by getpwent(3). | 
|  |  | 
|  | * Some capabilities were asked by fetch-pack even when upload-pack | 
|  | did not advertise that they are available.  fetch-pack has been | 
|  | fixed not to do so. | 
|  |  | 
|  | * "git diff" had a confusion between taking data from a path in the | 
|  | working tree and taking data from an object that happens to have | 
|  | name 0{40} recorded in a tree. | 
|  |  | 
|  | * "git for-each-ref" did not correctly support more than one --sort | 
|  | option. | 
|  |  | 
|  | * "git log .." errored out saying it is both rev range and a path | 
|  | when there is no disambiguating "--" is on the command line. | 
|  | Update the command line parser to interpret ".." as a path in such | 
|  | a case. | 
|  |  | 
|  | * The "--topo-order", "--date-order" (and the lack of either means | 
|  | the default order) options to "rev-list" and "log" family of | 
|  | commands were poorly described in the documentation. | 
|  |  | 
|  | * "git prune" without "-v" used to warn about leftover temporary | 
|  | files (which is an indication of an earlier aborted operation). | 
|  |  | 
|  | * Pushing to smart HTTP server with recent Git fails without having | 
|  | the username in the URL to force authentication, if the server is | 
|  | configured to allow GET anonymously, while requiring authentication | 
|  | for POST. | 
|  |  | 
|  | * The reflog entries left by "git rebase" and "git rebase -i" were | 
|  | inconsistent (the interactive one gave an abbreviated object name). | 
|  |  | 
|  | * When "git push" triggered the automatic gc on the receiving end, a | 
|  | message from "git prune" that said it was removing cruft leaked to | 
|  | the standard output, breaking the communication protocol. | 
|  |  | 
|  | * "git show --quiet" ought to be a synonym for "git show -s", but | 
|  | wasn't. | 
|  |  | 
|  | * "git show --format='%ci'" did not give timestamp correctly for | 
|  | commits created without human readable name on "committer" line. | 
|  |  | 
|  | * "git send-email" did not unquote encoded words that appear on the | 
|  | header correctly, and lost "_" from strings. | 
|  |  | 
|  | * The interactive prompt "git send-email" gives was error prone. It | 
|  | asked "What e-mail address do you want to use?" with the address it | 
|  | guessed (correctly) the user would want to use in its prompt, | 
|  | tempting the user to say "y". But the response was taken as "No, | 
|  | please use 'y' as the e-mail address instead", which is most | 
|  | certainly not what the user meant. | 
|  |  | 
|  | * "gitweb" when used with PATH_INFO failed to notice directories with | 
|  | SP (and other characters that need URL-style quoting) in them. | 
|  |  | 
|  | * When the user gives an argument that can be taken as both a | 
|  | revision name and a pathname without disambiguating with "--", we | 
|  | used to give a help message "Use '--' to separate".  The message | 
|  | has been clarified to show where that '--' goes on the command | 
|  | line. | 
|  |  | 
|  | * When the user exports a non-default IFS without HT, scripts that | 
|  | rely on being able to parse "ls-files -s | while read a b c..." | 
|  | started to fail.  Protect them from such a misconfiguration. | 
|  |  | 
|  | * The attribute system may be asked for a path that itself or its | 
|  | leading directories no longer exists in the working tree, and it is | 
|  | fine if we cannot open .gitattribute file in such a case.  Failure | 
|  | to open per-directory .gitattributes with error status other than | 
|  | ENOENT and ENOTDIR should be diagnosed, but it wasn't. | 
|  |  | 
|  | * After "gitk" showed the contents of a tag, neither "Reread | 
|  | references" nor "Reload" did not update what is shown as the | 
|  | contents of it, when the user overwrote the tag with "git tag -f". | 
|  |  | 
|  | * "ciabot" script (in contrib/) has been updated with extensive | 
|  | documentation. | 
|  |  | 
|  | * "git-jump" script (in contrib/) did not work well when | 
|  | diff.noprefix or diff.mnemonicprefix is in effect. | 
|  |  | 
|  | * Older parts of the documentation described as if having a regular | 
|  | file in .git/refs/ hierarchy were the only way to have branches and | 
|  | tags, which is not true for quite some time. | 
|  |  | 
|  | * A utility shell function test_seq has been added as a replacement | 
|  | for the 'seq' utility found on some platforms. | 
|  |  | 
|  | * Compatibility wrapper to learn the maximum number of file | 
|  | descriptors we can open around sysconf(_SC_OPEN_MAX) and | 
|  | getrlimit(RLIMIT_NO_FILE) has been introduced for portability. | 
|  |  | 
|  | * We used curl_easy_strerror() without checking version of cURL, | 
|  | breaking the build for versions before curl 7.12.0. | 
|  |  | 
|  | * Code to work around MacOS X UTF-8 gotcha has been cleaned up. | 
|  |  | 
|  | * Fallback 'getpass' implementation made unportable use of stdio API. | 
|  |  | 
|  | * The "--rebase" option to "git pull" can be abbreviated to "-r", | 
|  | but we didn't document it. | 
|  |  | 
|  | * It was generally understood that "--long-option"s to many of our | 
|  | subcommands can be abbreviated to the unique prefix, but it was not | 
|  | easy to find it described for new readers of the documentation set. | 
|  |  | 
|  | * The synopsis said "checkout [-B branch]" to make it clear the | 
|  | branch name is a parameter to the option, but the heading for the | 
|  | option description was "-B::", not "-B branch::", making the | 
|  | documentation misleading. | 
|  |  | 
|  | Also contains numerous documentation updates. |