diff options
author | Junio C Hamano <gitster@pobox.com> | 2015-09-09 14:30:35 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2015-09-09 14:30:35 -0700 |
commit | f0bc85462332644ecd2386e0f4fdc9948b9f47dc (patch) | |
tree | 6ee0f442ec888c33a25e825a4e451b921c0701ff /unpack-trees.c | |
parent | 7a2c4af7a82eebf2ed0e60a2b36c31e70c619264 (diff) | |
parent | 27ea6f85beff1173ec74349fa35c45951feee570 (diff) | |
download | git-f0bc85462332644ecd2386e0f4fdc9948b9f47dc.tar.gz |
Sync with 2.5.2
Diffstat (limited to 'unpack-trees.c')
-rw-r--r-- | unpack-trees.c | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/unpack-trees.c b/unpack-trees.c index bb09b1ed27..f932e80e86 100644 --- a/unpack-trees.c +++ b/unpack-trees.c @@ -1451,15 +1451,18 @@ static int verify_absent_1(const struct cache_entry *ce, if (!len) return 0; else if (len > 0) { - char path[PATH_MAX + 1]; - memcpy(path, ce->name, len); - path[len] = 0; + char *path; + int ret; + + path = xmemdupz(ce->name, len); if (lstat(path, &st)) - return error("cannot stat '%s': %s", path, + ret = error("cannot stat '%s': %s", path, strerror(errno)); - - return check_ok_to_remove(path, len, DT_UNKNOWN, NULL, &st, - error_type, o); + else + ret = check_ok_to_remove(path, len, DT_UNKNOWN, NULL, + &st, error_type, o); + free(path); + return ret; } else if (lstat(ce->name, &st)) { if (errno != ENOENT) return error("cannot stat '%s': %s", ce->name, |