summaryrefslogtreecommitdiffstats
path: root/convert.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2019-04-09 19:14:22 +0200
committerJunio C Hamano <gitster@pobox.com>2019-04-09 19:14:22 +0200
commit1828e52efcffe75707b88345f025c3ee4114864a (patch)
treebf5635815ead7340d26ab8f6a35063a81945fd1a /convert.c
parentMerge branch 'dl/ignore-docs' (diff)
parentconvert: avoid malloc of original file size (diff)
downloadgit-1828e52efcffe75707b88345f025c3ee4114864a.tar.xz
git-1828e52efcffe75707b88345f025c3ee4114864a.zip
Merge branch 'jh/resize-convert-scratch-buffer'
When the "clean" filter can reduce the size of a huge file in the working tree down to a small "token" (a la Git LFS), there is no point in allocating a huge scratch area upfront, but the buffer is sized based on the original file size. The convert mechanism now allocates very minimum and reallocates as it receives the output from the clean filter process. * jh/resize-convert-scratch-buffer: convert: avoid malloc of original file size
Diffstat (limited to 'convert.c')
-rw-r--r--convert.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/convert.c b/convert.c
index 5d0307fc10..94ff837649 100644
--- a/convert.c
+++ b/convert.c
@@ -731,7 +731,7 @@ static int apply_single_file_filter(const char *path, const char *src, size_t le
if (start_async(&async))
return 0; /* error was already reported */
- if (strbuf_read(&nbuf, async.out, len) < 0) {
+ if (strbuf_read(&nbuf, async.out, 0) < 0) {
err = error(_("read from external filter '%s' failed"), cmd);
}
if (close(async.out)) {