improve command prohibition error report

Ensures that the correct information gets displayed, depending on the
mode of the command being denied.  Fixes misreporting all commands as
needing to run "before 'init'".
This commit is contained in:
Zachary T Welch 2009-11-28 16:29:41 -08:00
parent 892604bc7e
commit 330733eadf
1 changed files with 10 additions and 2 deletions

View File

@ -565,8 +565,16 @@ static int run_command(struct command_context *context,
{
if (!command_can_run(context, c))
{
/* Config commands can not run after the config stage */
LOG_ERROR("The '%s' command must be used before 'init'.", c->name);
/* Many commands may be run only before/after 'init' */
const char *when;
switch (c->mode) {
case COMMAND_CONFIG: when = "before"; break;
case COMMAND_EXEC: when = "after"; break;
// handle the impossible with humor; it guarantees a bug report!
default: when = "if Cthulhu is summoned by"; break;
}
LOG_ERROR("The '%s' command must be used %s 'init'.",
c->name, when);
return ERROR_FAIL;
}