[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 15/29] qemu-option: parse_option_bool(): use error_s
From: |
Luiz Capitulino |
Subject: |
[Qemu-devel] [PATCH 15/29] qemu-option: parse_option_bool(): use error_set() |
Date: |
Tue, 5 Jun 2012 14:24:54 -0300 |
Note that set_option_parameter() callers still expect automatic error
reporting with QError, so set_option_parameter() calls
qerror_report_err() to keep the same semantics.
Signed-off-by: Luiz Capitulino <address@hidden>
Reviewed-By: Laszlo Ersek <address@hidden>
---
qemu-option.c | 24 ++++++++++++++++--------
1 file changed, 16 insertions(+), 8 deletions(-)
diff --git a/qemu-option.c b/qemu-option.c
index 72dcb56..b5da116 100644
--- a/qemu-option.c
+++ b/qemu-option.c
@@ -169,7 +169,8 @@ QEMUOptionParameter
*get_option_parameter(QEMUOptionParameter *list,
return NULL;
}
-static int parse_option_bool(const char *name, const char *value, bool *ret)
+static void parse_option_bool(const char *name, const char *value, bool *ret,
+ Error **errp)
{
if (value != NULL) {
if (!strcmp(value, "on")) {
@@ -177,13 +178,11 @@ static int parse_option_bool(const char *name, const char
*value, bool *ret)
} else if (!strcmp(value, "off")) {
*ret = 0;
} else {
- qerror_report(QERR_INVALID_PARAMETER_VALUE, name, "'on' or 'off'");
- return -1;
+ error_set(errp,QERR_INVALID_PARAMETER_VALUE, name, "'on' or
'off'");
}
} else {
*ret = 1;
}
- return 0;
}
static void parse_option_number(const char *name, const char *value,
@@ -263,6 +262,7 @@ int set_option_parameter(QEMUOptionParameter *list, const
char *name,
const char *value)
{
bool flag;
+ Error *local_err = NULL;
// Find a matching parameter
list = get_option_parameter(list, name);
@@ -274,9 +274,10 @@ int set_option_parameter(QEMUOptionParameter *list, const
char *name,
// Process parameter
switch (list->type) {
case OPT_FLAG:
- if (parse_option_bool(name, value, &flag) == -1)
- return -1;
- list->value.n = flag;
+ parse_option_bool(name, value, &flag, &local_err);
+ if (!error_is_set(&local_err)) {
+ list->value.n = flag;
+ }
break;
case OPT_STRING:
@@ -298,6 +299,12 @@ int set_option_parameter(QEMUOptionParameter *list, const
char *name,
return -1;
}
+ if (error_is_set(&local_err)) {
+ qerror_report_err(local_err);
+ error_free(local_err);
+ return -1;
+ }
+
return 0;
}
@@ -588,7 +595,8 @@ static int qemu_opt_parse(QemuOpt *opt)
/* nothing */
return 0;
case QEMU_OPT_BOOL:
- return parse_option_bool(opt->name, opt->str, &opt->value.boolean);
+ parse_option_bool(opt->name, opt->str, &opt->value.boolean,
&local_err);
+ break;
case QEMU_OPT_NUMBER:
parse_option_number(opt->name, opt->str, &opt->value.uint,
&local_err);
--
1.7.10.2.565.gbd578b5
- [Qemu-devel] [PATCH 10/29] target-i386: Add API to get note's size, (continued)
- [Qemu-devel] [PATCH 10/29] target-i386: Add API to get note's size, Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 18/29] qemu-option: qemu_opts_validate(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 16/29] qemu-option: parse_option_size(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 20/29] qemu-option: introduce qemu_opt_set_err(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 25/29] net: purge the monitor object from all init functions, Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 22/29] qerror: introduce QERR_INVALID_OPTION_GROUP, Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 24/29] qemu-config: introduce qemu_find_opts_err(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 29/29] Add 'query-events' command to QMP to query async events, Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 28/29] qapi: convert netdev_del, Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 27/29] qapi: convert netdev_add, Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 15/29] qemu-option: parse_option_bool(): use error_set(),
Luiz Capitulino <=
- [Qemu-devel] [PATCH 23/29] qemu-config: find_list(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 19/29] qemu-option: opt_set(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 17/29] qemu-option: qemu_opt_parse(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 21/29] qemu-option: qemu_opts_from_qdict(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 14/29] qemu-option: parse_option_number(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 12/29] introduce a new monitor command 'dump-guest-memory' to dump guest's memory, Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 26/29] net: net_client_init(): use error_set(), Luiz Capitulino, 2012/06/05
- [Qemu-devel] [PATCH 13/29] qemu-option: qemu_opts_create(): use error_set(), Luiz Capitulino, 2012/06/05
- Re: [Qemu-devel] [PULL 00/29]: QMP queue, Anthony Liguori, 2012/06/06