summaryrefslogtreecommitdiffstats
path: root/test-dump-cache-tree.c
diff options
context:
space:
mode:
authorJeff King <peff@peff.net>2015-09-24 23:06:03 +0200
committerJunio C Hamano <gitster@pobox.com>2015-09-25 19:18:18 +0200
commit04724222d5aad4da48674e69aab715273f05dded (patch)
treecd8923223008e3c6a652d5b6f8bb393fef7956ce /test-dump-cache-tree.c
parentprogress: store throughput display in a strbuf (diff)
downloadgit-04724222d5aad4da48674e69aab715273f05dded.tar.xz
git-04724222d5aad4da48674e69aab715273f05dded.zip
test-dump-cache-tree: avoid overflow of cache-tree name
When dumping a cache-tree, we sprintf sub-tree names directly into a fixed-size buffer, which can overflow. We can trivially fix this by converting to xsnprintf to at least notice and die. This probably should handle arbitrary-sized names, but there's not much point. It's used only by the test scripts, so the trivial fix is enough. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'test-dump-cache-tree.c')
-rw-r--r--test-dump-cache-tree.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/test-dump-cache-tree.c b/test-dump-cache-tree.c
index 54c0872fcb..bb53c0aa65 100644
--- a/test-dump-cache-tree.c
+++ b/test-dump-cache-tree.c
@@ -47,7 +47,7 @@ static int dump_cache_tree(struct cache_tree *it,
struct cache_tree_sub *rdwn;
rdwn = cache_tree_sub(ref, down->name);
- sprintf(path, "%s%.*s/", pfx, down->namelen, down->name);
+ xsnprintf(path, sizeof(path), "%s%.*s/", pfx, down->namelen, down->name);
if (dump_cache_tree(down->cache_tree, rdwn->cache_tree, path))
errs = 1;
}