diff options
author | Pavel Machek <pavel@ucw.cz> | 2000-06-01 10:32:49 +0200 |
---|---|---|
committer | Pavel Machek <pavel@ucw.cz> | 2000-06-01 10:32:49 +0200 |
commit | 1895e81e0532f732f501036402bbdd1825885cfd (patch) | |
tree | 8f2c9e7b8bfb5b1b2e76657289a91af0146c9dd0 /filter/filter.c | |
parent | 42542c56c23174bfaefb1b949b90ed72afbea8fd (diff) | |
download | bird-1895e81e0532f732f501036402bbdd1825885cfd.tar bird-1895e81e0532f732f501036402bbdd1825885cfd.zip |
Allow matching on enums:
if !(scope ~ [ SCOPE_HOST, SCOPE_SITE ]) then {
print "Failed in test";
quitbird;
}
Diffstat (limited to 'filter/filter.c')
-rw-r--r-- | filter/filter.c | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/filter/filter.c b/filter/filter.c index f1a8f8f..c6d7e4f 100644 --- a/filter/filter.c +++ b/filter/filter.c @@ -143,14 +143,21 @@ val_in_range(struct f_val v1, struct f_val v2) if (res != CMP_ERROR) return res; - - if (((v1.type == T_INT) || ((v1.type == T_IP) || (v1.type == T_PREFIX)) && (v2.type == T_SET))) { - struct f_tree *n; - n = find_tree(v2.val.t, v1); - if (!n) - return 0; - return !! (val_simple_in_range(v1, n->from)); /* We turn CMP_ERROR into compared ok, and that's fine */ - } + + if (v2.type == T_SET) + switch (v1.type) { + case T_ENUM: + case T_INT: + case T_IP: + case T_PREFIX: + { + struct f_tree *n; + n = find_tree(v2.val.t, v1); + if (!n) + return 0; + return !! (val_simple_in_range(v1, n->from)); /* We turn CMP_ERROR into compared ok, and that's fine */ + } + } return CMP_ERROR; } |