summaryrefslogtreecommitdiffstats
path: root/iptables.c
diff options
context:
space:
mode:
authorrusty <rusty>2000-08-26 04:44:39 +0000
committerrusty <rusty>2000-08-26 04:44:39 +0000
commit004af5d645f5ac1454c296008a26ab23f463724e (patch)
tree57e16c85f86f2b9e6acb0ec99bdfaa3e2351eb90 /iptables.c
parentf008cc3b2fac5eef063ae1f82d21a8369e0f693c (diff)
Jan Echternach's patch for bignums
Diffstat (limited to 'iptables.c')
-rw-r--r--iptables.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/iptables.c b/iptables.c
index 4dfa7d0..92f0175 100644
--- a/iptables.c
+++ b/iptables.c
@@ -820,14 +820,15 @@ mask_to_dotted(const struct in_addr *mask)
int
string_to_number(const char *s, int min, int max)
{
- int number;
+ long number;
char *end;
/* Handle hex, octal, etc. */
- number = (int)strtol(s, &end, 0);
+ errno = 0;
+ number = strtol(s, &end, 0);
if (*end == '\0' && end != s) {
/* we parsed a number, let's see if we want this */
- if (min <= number && number <= max)
+ if (errno != ERANGE && min <= number && number <= max)
return number;
}
return -1;
@@ -894,7 +895,7 @@ find_target(const char *name, enum ipt_tryload tryload)
}
static struct option *
-merge_options(struct option *oldopts, struct option *newopts,
+merge_options(struct option *oldopts, const struct option *newopts,
unsigned int *option_offset)
{
unsigned int num_old, num_new, i;