/* GNU Mailutils -- a suite of utilities for electronic mail Copyright (C) 2003-2019 Free Software Foundation, Inc. This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library. If not, see . */ #ifdef HAVE_CONFIG_H # include #endif #include #include #include #define CAT2(a,b) a##b #define CAT3(a,b,c) a##b##c #define DCL(name,op)\ static int CAT2(op_,name) (int num, int lim) { return num op lim; }\ static int CAT3(op_,name,_size_t) (size_t num, size_t lim) { return num op lim; } DCL(eq,==) DCL(ne,!=) DCL(gt,>) DCL(ge,>=) DCL(lt,<) DCL(le,<=) static struct reltest_tab { char *name; mu_sieve_relcmp_t test; mu_sieve_relcmpn_t stest; } testtab[] = { #define DEF(name) { #name, CAT2(op_,name), CAT3(op_,name,_size_t) } DEF(eq), DEF(ne), DEF(gt), DEF(ge), DEF(lt), DEF(le) }; static struct reltest_tab * _relcmp_lookup (const char *str) { int i; for (i = 0; i < sizeof(testtab) / sizeof(testtab[0]); i++) if (strcmp (testtab[i].name, str) == 0) return &testtab[i]; return 0; } int mu_sieve_str_to_relcmp (const char *str, mu_sieve_relcmp_t *test, mu_sieve_relcmpn_t *stest) { struct reltest_tab *t = _relcmp_lookup (str); if (t) { if (test) *test = t->test; if (stest) *stest = t->stest; return 0; } return 1; } mu_sieve_relcmp_t mu_sieve_get_relcmp (mu_sieve_machine_t mach) { char *str; mu_sieve_relcmp_t test = NULL; if (mu_sieve_get_tag (mach, "value", SVT_STRING, &str) == 0) return op_ne; mu_sieve_str_to_relcmp (str, &test, NULL); return test; } int mu_sieve_require_relational (mu_sieve_machine_t mach, const char *name) { /* noop */ return 0; }