X-Git-Url: https://www.tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Ftincctl.c;h=12cffebc1251015f0eb387e2a2dfee8a3dffb325;hb=b22499668a7aa63c619cb8fa8535282a38841ce9;hp=6227750ce73ed2c9b9139bfd69115a953a283170;hpb=5ffdff685a0e7d25f7c016f3a6cd89bb82fed71c;p=tinc diff --git a/src/tincctl.c b/src/tincctl.c index 6227750c..12cffebc 100644 --- a/src/tincctl.c +++ b/src/tincctl.c @@ -810,7 +810,19 @@ static int cmd_start(int argc, char *argv[]) { int nargc = 0; char **nargv = xzalloc((optind + argc) * sizeof *nargv); - nargv[nargc++] = c; + char *arg0 = c; +#ifdef HAVE_MINGW + /* + Windows has no real concept of an "argv array". A command line is just one string. + The CRT of the new process will decode the command line string to generate argv before calling main(), and (by convention) + it uses quotes to handle spaces in arguments. + Therefore we need to quote all arguments that might contain spaces. No, execvp() won't do that for us (see MSDN). + If we don't do that, then execvp() will run fine but any spaces in the filename contained in arg0 will bleed + into the next arguments when the spawned process' CRT parses its command line, resulting in chaos. + */ + xasprintf(&arg0, "\"%s\"", arg0); +#endif + nargv[nargc++] = arg0; for(int i = 1; i < optind; i++) nargv[nargc++] = orig_argv[i]; for(int i = 1; i < argc; i++)