Skip to content

Commit ced621b

Browse files
René Scharfegitster
authored andcommitted
merge-recursive: use strbuf_expand() instead of interpolate()
Signed-off-by: Rene Scharfe <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 9b864e7 commit ced621b

File tree

2 files changed

+9
-13
lines changed

2 files changed

+9
-13
lines changed

ll-merge.c

Lines changed: 9 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,6 @@
88
#include "attr.h"
99
#include "xdiff-interface.h"
1010
#include "run-command.h"
11-
#include "interpolate.h"
1211
#include "ll-merge.h"
1312

1413
struct ll_merge_driver;
@@ -169,11 +168,12 @@ static int ll_ext_merge(const struct ll_merge_driver *fn,
169168
int virtual_ancestor)
170169
{
171170
char temp[3][50];
172-
char cmdbuf[2048];
173-
struct interp table[] = {
174-
{ "%O" },
175-
{ "%A" },
176-
{ "%B" },
171+
struct strbuf cmd = STRBUF_INIT;
172+
struct strbuf_expand_dict_entry dict[] = {
173+
{ "O", temp[0] },
174+
{ "A", temp[1] },
175+
{ "B", temp[2] },
176+
{ NULL }
177177
};
178178
struct child_process child;
179179
const char *args[20];
@@ -189,17 +189,13 @@ static int ll_ext_merge(const struct ll_merge_driver *fn,
189189
create_temp(src1, temp[1]);
190190
create_temp(src2, temp[2]);
191191

192-
interp_set_entry(table, 0, temp[0]);
193-
interp_set_entry(table, 1, temp[1]);
194-
interp_set_entry(table, 2, temp[2]);
195-
196-
interpolate(cmdbuf, sizeof(cmdbuf), fn->cmdline, table, 3);
192+
strbuf_expand(&cmd, fn->cmdline, strbuf_expand_dict_cb, &dict);
197193

198194
memset(&child, 0, sizeof(child));
199195
child.argv = args;
200196
args[0] = "sh";
201197
args[1] = "-c";
202-
args[2] = cmdbuf;
198+
args[2] = cmd.buf;
203199
args[3] = NULL;
204200

205201
status = run_command(&child);
@@ -224,6 +220,7 @@ static int ll_ext_merge(const struct ll_merge_driver *fn,
224220
bad:
225221
for (i = 0; i < 3; i++)
226222
unlink(temp[i]);
223+
strbuf_release(&cmd);
227224
return status;
228225
}
229226

merge-recursive.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,6 @@
1616
#include "string-list.h"
1717
#include "xdiff-interface.h"
1818
#include "ll-merge.h"
19-
#include "interpolate.h"
2019
#include "attr.h"
2120
#include "merge-recursive.h"
2221
#include "dir.h"

0 commit comments

Comments
 (0)