|  | Git v2.19.2 Release Notes | 
|  | ========================= | 
|  |  | 
|  | Fixes since v2.19.1 | 
|  | ------------------- | 
|  |  | 
|  | * "git interpret-trailers" and its underlying machinery had a buggy | 
|  | code that attempted to ignore patch text after commit log message, | 
|  | which triggered in various codepaths that will always get the log | 
|  | message alone and never get such an input. | 
|  |  | 
|  | * "git rebase -i" did not clear the state files correctly when a run | 
|  | of "squash/fixup" is aborted and then the user manually amended the | 
|  | commit instead, which has been corrected. | 
|  |  | 
|  | * When fsmonitor is in use, after operation on submodules updates | 
|  | .gitmodules, we lost track of the fact that we did so and relied on | 
|  | stale fsmonitor data. | 
|  |  | 
|  | * Fix for a long-standing bug that leaves the index file corrupt when | 
|  | it shrinks during a partial commit. | 
|  |  | 
|  | * Further fix for O_APPEND emulation on Windows | 
|  |  | 
|  | * A corner case bugfix in "git rerere" code. | 
|  |  | 
|  | * "git add ':(attr:foo)'" is not supported and is supposed to be | 
|  | rejected while the command line arguments are parsed, but we fail | 
|  | to reject such a command line upfront. | 
|  |  | 
|  | * "git rebase" etc. in Git 2.19 fails to abort when given an empty | 
|  | commit log message as result of editing, which has been corrected. | 
|  |  | 
|  | * The code to backfill objects in lazily cloned repository did not | 
|  | work correctly, which has been corrected. | 
|  |  | 
|  | * Update error messages given by "git remote" and make them consistent. | 
|  |  | 
|  | * "git update-ref" learned to make both "--no-deref" and "--stdin" | 
|  | work at the same time. | 
|  |  | 
|  | * Recently added "range-diff" had a corner-case bug to cause it | 
|  | segfault, which has been corrected. | 
|  |  | 
|  | * The recently introduced commit-graph auxiliary data is incompatible | 
|  | with mechanisms such as replace & grafts that "breaks" immutable | 
|  | nature of the object reference relationship.  Disable optimizations | 
|  | based on its use (and updating existing commit-graph) when these | 
|  | incompatible features are in use in the repository. | 
|  |  | 
|  | * The mailmap file update. | 
|  |  | 
|  | * The code in "git status" sometimes hit an assertion failure.  This | 
|  | was caused by a structure that was reused without cleaning the data | 
|  | used for the first run, which has been corrected. | 
|  |  | 
|  | * A corner-case bugfix. | 
|  |  | 
|  | * A partial clone that is configured to lazily fetch missing objects | 
|  | will on-demand issue a "git fetch" request to the originating | 
|  | repository to fill not-yet-obtained objects.  The request has been | 
|  | optimized for requesting a tree object (and not the leaf blob | 
|  | objects contained in it) by telling the originating repository that | 
|  | no blobs are needed. | 
|  |  | 
|  | * The codepath to support the experimental split-index mode had | 
|  | remaining "racily clean" issues fixed. | 
|  |  | 
|  | * "git log --graph" showing an octopus merge sometimes miscounted the | 
|  | number of display columns it is consuming to show the merge and its | 
|  | parent commits, which has been corrected. | 
|  |  | 
|  | * The implementation of run_command() API on the UNIX platforms had a | 
|  | bug that caused a command not on $PATH to be found in the current | 
|  | directory. | 
|  |  | 
|  | * A mutex used in "git pack-objects" were not correctly initialized | 
|  | and this caused "git repack" to dump core on Windows. | 
|  |  | 
|  | * Under certain circumstances, "git diff D:/a/b/c D:/a/b/d" on | 
|  | Windows would strip initial parts from the paths because they | 
|  | were not recognized as absolute, which has been corrected. | 
|  |  | 
|  | * The receive.denyCurrentBranch=updateInstead codepath kicked in even | 
|  | when the push should have been rejected due to other reasons, such | 
|  | as it does not fast-forward or the update-hook rejects it, which | 
|  | has been corrected. | 
|  |  | 
|  | * "git repack" in a shallow clone did not correctly update the | 
|  | shallow points in the repository, leading to a repository that | 
|  | does not pass fsck. | 
|  |  | 
|  | * Operations on promisor objects make sense in the context of only a | 
|  | small subset of the commands that internally use the revisions | 
|  | machinery, but the "--exclude-promisor-objects" option were taken | 
|  | and led to nonsense results by commands like "log", to which it | 
|  | didn't make much sense.  This has been corrected. | 
|  |  | 
|  | * The "container" mode of TravisCI is going away.  Our .travis.yml | 
|  | file is getting prepared for the transition. | 
|  |  | 
|  | * Our test scripts can now take the '-V' option as a synonym for the | 
|  | '--verbose-log' option. | 
|  |  | 
|  | * A regression in Git 2.12 era made "git fsck" fall into an infinite | 
|  | loop while processing truncated loose objects. | 
|  |  | 
|  | Also contains various documentation updates and code clean-ups. |