command: don't clobber next list value when preparsing
This only breaks "update" under list command mode and no other commands. This can be done more optimally without the extra heap allocation via xstrdup(); but is uncommon enough to not matter.
This commit is contained in:
parent
11245dc119
commit
5f0ed72c48
@ -1422,16 +1422,19 @@ static CommandEntry *getCommandEntryAndCheckArgcAndPermission(struct client *cli
|
|||||||
|
|
||||||
static CommandEntry *getCommandEntryFromString(char *string, int permission)
|
static CommandEntry *getCommandEntryFromString(char *string, int permission)
|
||||||
{
|
{
|
||||||
CommandEntry *cmd;
|
CommandEntry *cmd = NULL;
|
||||||
char *argv[COMMAND_ARGV_MAX] = { NULL };
|
char *argv[COMMAND_ARGV_MAX] = { NULL };
|
||||||
int argc = buffer2array(string, argv, COMMAND_ARGV_MAX);
|
char *duplicated = xstrdup(string);
|
||||||
|
int argc = buffer2array(duplicated, argv, COMMAND_ARGV_MAX);
|
||||||
|
|
||||||
if (0 == argc)
|
if (0 == argc)
|
||||||
return NULL;
|
goto out;
|
||||||
|
|
||||||
cmd = getCommandEntryAndCheckArgcAndPermission(0, permission,
|
cmd = getCommandEntryAndCheckArgcAndPermission(0, permission,
|
||||||
argc, argv);
|
argc, argv);
|
||||||
|
|
||||||
|
out:
|
||||||
|
free(duplicated);
|
||||||
return cmd;
|
return cmd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user