Make the error checking consistent with other strtol() calls. Note that since strtol(nptr, &endptr) sets endptr == nptr if there were no digits, this catches the case where the string was blank, so there's no need to test *value != '\0'.
Signed-off-by: Bryce Harrington <br...@osg.samsung.com> --- shared/option-parser.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/shared/option-parser.c b/shared/option-parser.c index 33355b8..fb4a342 100644 --- a/shared/option-parser.c +++ b/shared/option-parser.c @@ -30,6 +30,7 @@ #include <stdio.h> #include <string.h> #include <assert.h> +#include <errno.h> #include "config-parser.h" @@ -40,11 +41,17 @@ handle_option(const struct weston_option *option, char *value) switch (option->type) { case WESTON_OPTION_INTEGER: + errno = 0; * (int32_t *) option->data = strtol(value, &p, 10); - return *value && !*p; + if (errno != 0 || p == value || *p != '\0') + return 0; + return 1; case WESTON_OPTION_UNSIGNED_INTEGER: + errno = 0; * (uint32_t *) option->data = strtoul(value, &p, 10); - return *value && !*p; + if (errno != 0 || p == value || *p != '\0') + return 0; + return 1; case WESTON_OPTION_STRING: * (char **) option->data = strdup(value); return 1; -- 1.9.1 _______________________________________________ wayland-devel mailing list wayland-devel@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/wayland-devel