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:
parent
3346b4b83f
commit
397d75648d
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user