summaryrefslogtreecommitdiffstats
path: root/extensions
diff options
context:
space:
mode:
authorkaber <kaber>2004-09-21 10:43:45 +0000
committerkaber <kaber>2004-09-21 10:43:45 +0000
commita63ae0d061b1eb4189ba4f98d35fa3dd8f47d0c9 (patch)
tree75a2dc336d305c6bd2928fa23cf15c40cd7e7671 /extensions
parent4789fa36300b7253d09aea7150c8870556cb1639 (diff)
[PATCH] limit match does not support invert, warn about it. Closes bugzilla #95 (Phil Oester)
Diffstat (limited to 'extensions')
-rw-r--r--extensions/libipt_limit.c13
1 files changed, 6 insertions, 7 deletions
diff --git a/extensions/libipt_limit.c b/extensions/libipt_limit.c
index 4d52040..2b15580 100644
--- a/extensions/libipt_limit.c
+++ b/extensions/libipt_limit.c
@@ -104,19 +104,14 @@ parse(int c, char **argv, int invert, unsigned int *flags,
switch(c) {
case '%':
- if (check_inverse(optarg, &invert, NULL, 0))
- exit_error(PARAMETER_PROBLEM,
- "Unexpected `!' after --limit");
+ if (check_inverse(argv[optind-1], &invert, &optind, 0)) break;
if (!parse_rate(optarg, &r->avg))
exit_error(PARAMETER_PROBLEM,
"bad rate `%s'", optarg);
break;
case '$':
- if (check_inverse(optarg, &invert, NULL, 0))
- exit_error(PARAMETER_PROBLEM,
- "Unexpected `!' after --limit-burst");
-
+ if (check_inverse(argv[optind-1], &invert, &optind, 0)) break;
if (string_to_number(optarg, 0, 10000, &num) == -1)
exit_error(PARAMETER_PROBLEM,
"bad --limit-burst `%s'", optarg);
@@ -127,6 +122,10 @@ parse(int c, char **argv, int invert, unsigned int *flags,
return 0;
}
+ if (invert)
+ exit_error(PARAMETER_PROBLEM,
+ "limit does not support invert");
+
return 1;
}