From 3a28f456b1dbc6e7cb225378375a598735f35338 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 8 Dec 2014 13:25:00 +0100 Subject: AllCommands: assign current_command early --- src/command/AllCommands.cxx | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/command/AllCommands.cxx b/src/command/AllCommands.cxx index 989418ea5..f740373de 100644 --- a/src/command/AllCommands.cxx +++ b/src/command/AllCommands.cxx @@ -357,11 +357,13 @@ command_process(Client &client, unsigned num, char *line) command_list_num = num; /* get the command name (first word on the line) */ + /* we have to set current_command because command_error() + expects it to be set */ Tokenizer tokenizer(line); char *argv[COMMAND_ARGV_MAX]; - argv[0] = tokenizer.NextWord(error); + current_command = argv[0] = tokenizer.NextWord(error); if (argv[0] == nullptr) { current_command = ""; if (tokenizer.IsEnd()) @@ -387,10 +389,7 @@ command_process(Client &client, unsigned num, char *line) tokenizer.NextParam(error)) != nullptr) ++argc; - /* some error checks; we have to set current_command because - command_error() expects it to be set */ - - current_command = argv[0]; + /* some error checks */ if (argc >= COMMAND_ARGV_MAX) { command_error(client, ACK_ERROR_ARG, "Too many arguments"); -- cgit v1.2.3