зеркало из https://github.com/microsoft/git.git
Fix is_gitfile() for files too small or larger than PATH_MAX to be a gitfile
The logic to check whether a file is a gitfile used the heuristics that a gitfile cannot be larger than PATH_MAX or smaller than 10 bytes (as its contents is "gitdir: " followed by a path) and returned early. But it returned with a wrong value. It should have said "this cannot possibly be a gitfile" by returning 0, but it returned 1 instead. Our test cases do not cover this, as the bundle files produced are smaller than PATH_MAX, except on Windows. While at it, fix the faulty logic that the path stored in a gitfile cannot be larger than PATH_MAX-sizeof("gitdir: "). Problem identified by running the test suite in msysGit, offending commit identified by Jörg Rosenkranz. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
0c80fdb342
Коммит
3ac6437016
|
@ -875,8 +875,8 @@ static int is_gitfile(const char *url)
|
||||||
return 0;
|
return 0;
|
||||||
if (!S_ISREG(st.st_mode))
|
if (!S_ISREG(st.st_mode))
|
||||||
return 0;
|
return 0;
|
||||||
if (st.st_size < 10 || st.st_size > PATH_MAX)
|
if (st.st_size < 10 || st.st_size > 9 + PATH_MAX)
|
||||||
return 1;
|
return 0;
|
||||||
|
|
||||||
fd = open(url, O_RDONLY);
|
fd = open(url, O_RDONLY);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
|
|
Загрузка…
Ссылка в новой задаче