summaryrefslogtreecommitdiffstats
path: root/builtin-apply.c
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2007-02-21 09:58:18 +0100
committerJunio C Hamano <junkio@cox.net>2007-02-21 10:14:34 +0100
commit6c912f5b04e3216a5487e03235a8454b754a464e (patch)
tree57b60fea8e5052936cb7a92a0c51b5126dbd68d8 /builtin-apply.c
parentt4119: add test for traditional patch and different p_value (diff)
downloadgit-6c912f5b04e3216a5487e03235a8454b754a464e.tar.xz
git-6c912f5b04e3216a5487e03235a8454b754a464e.zip
Fix botched "leak fix"
When (new_name == old_name), the previous one prefixed old_name alone, leaving new_name untouched, and worse yet, left it dangling pointing at an already freed memory location. Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'builtin-apply.c')
-rw-r--r--builtin-apply.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/builtin-apply.c b/builtin-apply.c
index 2a40af3ff0..1beebe5ff1 100644
--- a/builtin-apply.c
+++ b/builtin-apply.c
@@ -2516,9 +2516,15 @@ static void prefix_patches(struct patch *p)
if (!prefix)
return;
for ( ; p; p = p->next) {
- if (p->new_name != p->old_name)
+ if (p->new_name == p->old_name) {
+ char *prefixed = p->new_name;
+ prefix_one(&prefixed);
+ p->new_name = p->old_name = prefixed;
+ }
+ else {
prefix_one(&p->new_name);
- prefix_one(&p->old_name);
+ prefix_one(&p->old_name);
+ }
}
}