From 3983b3fc81926a56dc26b91978bb113556516500 Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Wed, 7 Aug 2002 17:29:28 +0000 Subject: [PATCH] Clean up the argv splitter, and in particular stop it from bombing out ignominiously when given no arguments :-) [originally from svn r1815] --- winutils.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/winutils.c b/winutils.c index 9d707ff1..00d35dfb 100644 --- a/winutils.c +++ b/winutils.c @@ -11,6 +11,8 @@ #ifdef TESTMODE /* Definitions to allow this module to be compiled standalone for testing. */ #define smalloc malloc +#define srealloc realloc +#define sfree free #endif /* @@ -130,6 +132,18 @@ void split_into_argv(char *cmdline, int *argc, char ***argv, * produce a literal quote. */ + /* + * First deal with the simplest of all special cases: if there + * aren't any arguments, return 0,NULL,NULL. + */ + while (*cmdline && isspace(*cmdline)) cmdline++; + if (!*cmdline) { + if (argc) *argc = 0; + if (argv) *argv = NULL; + if (argstart) *argstart = NULL; + return; + } + /* * This will guaranteeably be big enough; we can realloc it * down later. @@ -446,4 +460,4 @@ int main(int argc, char **argv) return 0; } -#endif \ No newline at end of file +#endif