aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristoph Mallon2011-06-23 16:34:31 +0200
committerAlyssa Milburn2011-06-23 17:17:11 +0200
commit52ebc0da38856c3105d58920ced048e024fda1d7 (patch)
treec4709ad5f7da925aef6775145d5f2110154d7d46
parent712af61f76148095cd3b8762eeb2b2b10502df1f (diff)
downloadscummvm-rg350-52ebc0da38856c3105d58920ced048e024fda1d7.tar.gz
scummvm-rg350-52ebc0da38856c3105d58920ced048e024fda1d7.tar.bz2
scummvm-rg350-52ebc0da38856c3105d58920ced048e024fda1d7.zip
BASE: Correct usage of strtol().
- endptr needs not be initialised before calling strtol(), it is always set by strtol(). - endptr is never a null pointer after calling strtol(). - There is no need to rely on strtol() setting EINVAL (which is not guaranteed). Testing whether strtol() parsed till the end of the string is sufficient (it is guaranteed that the string is not empty at this point). - It is sufficient to just test for ERANGE without inspecting the return value, because a successful call to strtol() does not change errno. Signed-off-by: Alyssa Milburn <fuzzie@fuzzie.org>
-rw-r--r--base/commandLine.cpp7
1 files changed, 3 insertions, 4 deletions
diff --git a/base/commandLine.cpp b/base/commandLine.cpp
index 2620d69ba2..543511696f 100644
--- a/base/commandLine.cpp
+++ b/base/commandLine.cpp
@@ -26,7 +26,6 @@
#define FORBIDDEN_SYMBOL_EXCEPTION_exit
#include <errno.h>
-#include <limits.h>
#include "engines/metaengine.h"
#include "base/commandLine.h"
@@ -269,10 +268,10 @@ void registerDefaults() {
// Use this for options which have a required integer value
#define DO_OPTION_INT(shortCmd, longCmd) \
DO_OPTION(shortCmd, longCmd) \
- char *endptr = 0; \
+ char *endptr; \
errno = 0; \
- long int retval = strtol(option, &endptr, 0); \
- if (endptr == NULL || *endptr != 0 || (errno != 0 && retval == 0) || (errno == ERANGE && (retval == LONG_MAX || retval == LONG_MIN))) \
+ strtol(option, &endptr, 0); \
+ if (*endptr != '\0' || errno == ERANGE) \
usage("--%s: Invalid number '%s'", longCmd, option);
// Use this for boolean options; this distinguishes between "-x" and "-X",