1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

test_split_into_argv: fix the generation mode.

Something weird was happening in the string handling which caused the
output to be full of the kind of gibberish you expect to see from
unterminated strings. Rather than debug it in detail, I've taken
advantage of now having the utils library conveniently available, and
simply used a strbuf, which I _know_ works sensibly.
This commit is contained in:
Simon Tatham 2021-04-18 12:08:50 +01:00
parent 3346b4b83f
commit 397d75648d

View File

@ -369,27 +369,29 @@ int main(int argc, char **argv)
} }
if (!strcmp(argv[1], "-split") && argc > 2) { if (!strcmp(argv[1], "-split") && argc > 2) {
char *str = malloc(20 + strlen(argv[0]) + strlen(argv[2])); strbuf *cmdline = strbuf_new();
char *p, *q; char *p;
q = str + sprintf(str, "%s -splat ", argv[0]); strbuf_catf(cmdline, "%s -splat ", argv[0]);
printf(" {\""); printf(" {\"");
for (p = argv[2]; *p; p++, q++) { size_t args_start = cmdline->len;
switch (*p) { for (p = argv[2]; *p; p++) {
case '/': printf("\\\\"); *q = '\\'; break; char c = (*p == '/' ? '\\' :
case '\'': printf("\\\""); *q = '"'; break; *p == '\'' ? '"' :
case '_': printf(" "); *q = ' '; break; *p == '_' ? ' ' :
default: putchar(*p); *q = *p; break; *p);
} put_byte(cmdline, c);
} }
*p = '\0'; write_c_string_literal(stdout, ptrlen_from_asciz(
cmdline->s + args_start));
printf("\", {"); printf("\", {");
fflush(stdout); fflush(stdout);
system(str); system(cmdline->s);
printf("}},\n"); printf("}},\n");
strbuf_free(cmdline);
return 0; return 0;
} }