merge-recursive: use xstrdup() instead of fixed buffer
authorRené Scharfe <l.s.r@web.de>
Sun, 10 Jun 2018 10:56:31 +0000 (12:56 +0200)
committerJunio C Hamano <gitster@pobox.com>
Thu, 14 Jun 2018 15:56:35 +0000 (08:56 -0700)
Paths can be longer than PATH_MAX. Avoid a buffer overrun in
check_dir_renamed() by using xstrdup() to make a private copy safely.

Signed-off-by: Rene Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
merge-recursive.c
index 5f42c677d52bc3ea3ac56efda0fae6cd6d2c4a63..7ea70c4a9d11dea43ebdad1ba8718410793c263a 100644 (file)
@@ -1938,18 +1938,18 @@ static struct hashmap *get_directory_renames(struct diff_queue_struct *pairs,
 static struct dir_rename_entry *check_dir_renamed(const char *path,
                                                  struct hashmap *dir_renames)
 {
-       char temp[PATH_MAX];
+       char *temp = xstrdup(path);
        char *end;
-       struct dir_rename_entry *entry;
+       struct dir_rename_entry *entry = NULL;;
 
-       strcpy(temp, path);
        while ((end = strrchr(temp, '/'))) {
                *end = '\0';
                entry = dir_rename_find_entry(dir_renames, temp);
                if (entry)
-                       return entry;
+                       break;
        }
-       return NULL;
+       free(temp);
+       return entry;
 }
 
 static void compute_collisions(struct hashmap *collisions,