]> git.ipfire.org Git - thirdparty/git.git/commitdiff
dir: fix malloc of root untracked_cache_dir
authorJeff Hostetler <jeffhost@microsoft.com>
Wed, 24 Feb 2021 14:31:57 +0000 (14:31 +0000)
committerJunio C Hamano <gitster@pobox.com>
Wed, 24 Feb 2021 20:09:10 +0000 (12:09 -0800)
Use FLEX_ALLOC_STR() to allocate the `struct untracked_cache_dir`
for the root directory.  Get rid of unsafe code that might fail to
initialize the `name` field (if FLEX_ARRAY is not 1).  This will
make it clear that we intend to have a structure with an empty
string following it.

A problem was observed on Windows where the length of the memset() was
too short, so the first byte of the name field was not zeroed.  This
resulted in the name field having garbage from a previous use of that
area of memory.

The record for the root directory was then written to the untracked-cache
extension in the index.  This garbage would then be visible to future
commands when they reloaded the untracked-cache extension.

Since the directory record for the root directory had garbage in the
`name` field, the `t/helper/test-tool dump-untracked-cache` tool
printed this garbage as the path prefix (rather than '/') for each
directory in the untracked cache as it recursed.

Signed-off-by: Jeff Hostetler <jeffhost@microsoft.com>
Reviewed-by: Taylor Blau <me@ttaylorr.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
dir.c

diff --git a/dir.c b/dir.c
index d637461da5cb9a03f86fe06d7524b756045755ac..188d9d220b7796e1cc0ec4656e282d957a953c59 100644 (file)
--- a/dir.c
+++ b/dir.c
@@ -2730,11 +2730,8 @@ static struct untracked_cache_dir *validate_untracked_cache(struct dir_struct *d
                return NULL;
        }
 
-       if (!dir->untracked->root) {
-               const int len = sizeof(*dir->untracked->root);
-               dir->untracked->root = xmalloc(len);
-               memset(dir->untracked->root, 0, len);
-       }
+       if (!dir->untracked->root)
+               FLEX_ALLOC_STR(dir->untracked->root, name, "");
 
        /* Validate $GIT_DIR/info/exclude and core.excludesfile */
        root = dir->untracked->root;