summaryrefslogtreecommitdiffstats
path: root/generic
diff options
context:
space:
mode:
authordgp <dgp@users.sourceforge.net>2017-05-08 16:07:58 (GMT)
committerdgp <dgp@users.sourceforge.net>2017-05-08 16:07:58 (GMT)
commitc9d16daf31e8306b115e3415f1ef5c6f9097ee2f (patch)
tree06be1b318fcd237abc980b74082a6a8bed04175a /generic
parent1dd9e5410409e738a9965f15b8d2bbe397438345 (diff)
parent509ac989d9ace73fcc8da899b7ea70fc3bd8c1d7 (diff)
downloadtcl-c9d16daf31e8306b115e3415f1ef5c6f9097ee2f.zip
tcl-c9d16daf31e8306b115e3415f1ef5c6f9097ee2f.tar.gz
tcl-c9d16daf31e8306b115e3415f1ef5c6f9097ee2f.tar.bz2
Merge 8.6; update changes.
Diffstat (limited to 'generic')
-rw-r--r--generic/tclBinary.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/generic/tclBinary.c b/generic/tclBinary.c
index 981f174..2a4fd84 100644
--- a/generic/tclBinary.c
+++ b/generic/tclBinary.c
@@ -1653,7 +1653,15 @@ GetFormatSpec(
(*formatPtr)++;
*countPtr = BINARY_ALL;
} else if (isdigit(UCHAR(**formatPtr))) { /* INTL: digit */
- *countPtr = strtoul(*formatPtr, (char **) formatPtr, 10);
+ unsigned long int count;
+
+ errno = 0;
+ count = strtoul(*formatPtr, (char **) formatPtr, 10);
+ if (errno || (count > (unsigned long) INT_MAX)) {
+ *countPtr = INT_MAX;
+ } else {
+ *countPtr = (int) count;
+ }
} else {
*countPtr = BINARY_NOCOUNT;
}