monitor: print the invalid char in error message
It's more friendly to print which char is invalid to user, especially when user tries to input a float value and expect the monitor to round it to int. Since we don't round float number when we look for a integer, telling which char is invalid is less confusing. Signed-off-by: Fam Zheng <famz@redhat.com> Reviewed-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
This commit is contained in:
parent
3953e3a5d3
commit
277acfe8b3
10
monitor.c
10
monitor.c
@ -3171,9 +3171,13 @@ static const MonitorDef monitor_defs[] = {
|
|||||||
{ NULL },
|
{ NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
static void expr_error(Monitor *mon, const char *msg)
|
static void expr_error(Monitor *mon, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
monitor_printf(mon, "%s\n", msg);
|
va_list ap;
|
||||||
|
va_start(ap, fmt);
|
||||||
|
monitor_vprintf(mon, fmt, ap);
|
||||||
|
monitor_printf(mon, "\n");
|
||||||
|
va_end(ap);
|
||||||
siglongjmp(expr_env, 1);
|
siglongjmp(expr_env, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3291,7 +3295,7 @@ static int64_t expr_unary(Monitor *mon)
|
|||||||
expr_error(mon, "number too large");
|
expr_error(mon, "number too large");
|
||||||
}
|
}
|
||||||
if (pch == p) {
|
if (pch == p) {
|
||||||
expr_error(mon, "invalid char in expression");
|
expr_error(mon, "invalid char '%c' in expression", *p);
|
||||||
}
|
}
|
||||||
pch = p;
|
pch = p;
|
||||||
while (qemu_isspace(*pch))
|
while (qemu_isspace(*pch))
|
||||||
|
Loading…
Reference in New Issue
Block a user