From 1895e81e0532f732f501036402bbdd1825885cfd Mon Sep 17 00:00:00 2001 From: Pavel Machek Date: Thu, 1 Jun 2000 08:32:49 +0000 Subject: [PATCH] Allow matching on enums: if !(scope ~ [ SCOPE_HOST, SCOPE_SITE ]) then { print "Failed in test"; quitbird; } --- filter/config.Y | 1 + filter/filter.c | 23 +++++++++++++++-------- filter/test.conf2 | 4 ++++ 3 files changed, 20 insertions(+), 8 deletions(-) diff --git a/filter/config.Y b/filter/config.Y index 9d5dc43a..69454bc3 100644 --- a/filter/config.Y +++ b/filter/config.Y @@ -226,6 +226,7 @@ set_atom: | pair { $$.type = T_PAIR; $$.val.i = $1; } | fipa { $$ = $1; } | fprefix { $$ = $1; } + | ENUM { $$.type = $1 >> 16; $$.val.i = $1 & 0xffff; } ; set_item: diff --git a/filter/filter.c b/filter/filter.c index f1a8f8fa..c6d7e4f1 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; } diff --git a/filter/test.conf2 b/filter/test.conf2 index 055e49a5..60bdd965 100644 --- a/filter/test.conf2 +++ b/filter/test.conf2 @@ -36,6 +36,10 @@ protocol static { print scope; scope = SCOPE_HOST; print scope; + if !(scope ~ [ SCOPE_HOST, SCOPE_SITE ]) then { + print "Failed in test"; + quitbird; + } preference = 15; print preference;