summaryrefslogtreecommitdiffstats
path: root/builtin-archive.c
diff options
context:
space:
mode:
authorRené Scharfe <rene.scharfe@lsrfire.ath.cx>2007-09-14 00:13:06 +0200
committerJunio C Hamano <gitster@pobox.com>2007-09-14 08:20:47 +0200
commit760da9607ee08e9dd495dee993262bb857694ac9 (patch)
treecbfc4a1e45f8ce0af0a472eea4fac4ab9af53bdd /builtin-archive.c
parentReplace all read_fd use with strbuf_read, and get rid of it. (diff)
downloadgit-760da9607ee08e9dd495dee993262bb857694ac9.tar.xz
git-760da9607ee08e9dd495dee993262bb857694ac9.zip
archive: fix subst file generation
Before the strbuf conversion, result was a char pointer. The if statement checked for it being not NULL, which meant that no "$Format:...$" string had been found and no replacement had to be made. format_subst() returned NULL in that case -- the caller then simply kept the original file content, as it was unaffected by the expansion. The length of the string being 0 is not the same as the string being NULL (expansion to an empty string vs. no expansion at all), so checking result.len != 0 is not a full replacement for the old NULL check. However, I doubt the subtle optimization explained above resulted in a notable speed-up anyway. Simplify the code and add the tail of the file to the expanded string unconditionally. [jc: added a test to expose the breakage this fixes] Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin-archive.c')
-rw-r--r--builtin-archive.c4
1 files changed, 1 insertions, 3 deletions
diff --git a/builtin-archive.c b/builtin-archive.c
index b50d5ad196..6fa424d386 100644
--- a/builtin-archive.c
+++ b/builtin-archive.c
@@ -111,9 +111,7 @@ static void *format_subst(const struct commit *commit, const char *format,
a = c + 1;
}
- if (result.len && len) {
- strbuf_add(&result, a, len);
- }
+ strbuf_add(&result, a, len);
*sizep = result.len;