зеркало из https://github.com/microsoft/git.git
mingw: special-case index entries for symlinks with buggy size
In https://github.com/git-for-windows/git/pull/2637, we fixed a bug where symbolic links' target path sizes were recorded incorrectly in the index. The downside of this fix was that every user with tracked symbolic links in their checkouts would see them as modified in `git status`, but not in `git diff`, and only a `git add <path>` (or `git add -u`) would "fix" this. Let's do better than that: we can detect that situation and simply pretend that a symbolic link with a known bad size (or a size that just happens to be that bad size, a _very_ unlikely scenario because it would overflow our buffers due to the trailing NUL byte) means that it needs to be re-checked as if we had just checked it out. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
This commit is contained in:
Родитель
5bb4c64115
Коммит
c7cf66a40a
11
read-cache.c
11
read-cache.c
|
@ -479,6 +479,17 @@ int ie_modified(struct index_state *istate,
|
|||
* then we know it is.
|
||||
*/
|
||||
if ((changed & DATA_CHANGED) &&
|
||||
#ifdef GIT_WINDOWS_NATIVE
|
||||
/*
|
||||
* Work around Git for Windows v2.27.0 fixing a bug where symlinks'
|
||||
* target path lengths were not read at all, and instead recorded
|
||||
* as 4096: now, all symlinks would appear as modified.
|
||||
*
|
||||
* So let's just special-case symlinks with a target path length
|
||||
* (i.e. `sd_size`) of 4096 and force them to be re-checked.
|
||||
*/
|
||||
(!S_ISLNK(st->st_mode) || ce->ce_stat_data.sd_size != MAX_LONG_PATH) &&
|
||||
#endif
|
||||
(S_ISGITLINK(ce->ce_mode) || ce->ce_stat_data.sd_size != 0))
|
||||
return changed;
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче