diff --git a/src/OpenFOAM/primitives/ints/int32/int32IO.C b/src/OpenFOAM/primitives/ints/int32/int32IO.C index 0b18d97028..d491e236a4 100644 --- a/src/OpenFOAM/primitives/ints/int32/int32IO.C +++ b/src/OpenFOAM/primitives/ints/int32/int32IO.C @@ -28,6 +28,7 @@ License #include "int32.H" #include "IOstreams.H" +#include #include #include @@ -87,9 +88,11 @@ bool Foam::read(const char* buf, int32_t& s) { char *endptr = NULL; errno = 0; - long l = strtol(buf, &endptr, 10); + intmax_t l = strtoimax(buf, &endptr, 10); s = int32_t(l); - return (*endptr == 0) && (errno == 0); + return + (*endptr == 0) && (errno == 0) + && (l >= INT32_MIN) && (l <= INT32_MAX); } diff --git a/src/OpenFOAM/primitives/ints/int64/int64IO.C b/src/OpenFOAM/primitives/ints/int64/int64IO.C index 6cc0b5e097..1cba3d0b53 100644 --- a/src/OpenFOAM/primitives/ints/int64/int64IO.C +++ b/src/OpenFOAM/primitives/ints/int64/int64IO.C @@ -28,6 +28,7 @@ License #include "int64.H" #include "IOstreams.H" +#include #include #include @@ -87,7 +88,7 @@ bool Foam::read(const char* buf, int64_t& s) { char *endptr = NULL; errno = 0; - long l = strtol(buf, &endptr, 10); + intmax_t l = strtoimax(buf, &endptr, 10); s = int64_t(l); return (*endptr == 0) && (errno == 0); }