2019-03-16 21:57:29 +02:00
|
|
|
#ifdef INTFILTER
|
|
|
|
|
2020-11-21 11:34:25 +00:00
|
|
|
static inline size_t S(filter_len)(size_t i)
|
2019-03-16 21:57:29 +02:00
|
|
|
{
|
|
|
|
# ifndef OMITMASK
|
|
|
|
const u8 *m = (const u8 *)&VEC_BUF(filters,i).m;
|
|
|
|
# else // OMITMASK
|
2021-03-21 16:52:15 +00:00
|
|
|
(void) i;
|
2019-03-16 21:57:29 +02:00
|
|
|
const u8 *m = (const u8 *)&ifiltermask;
|
|
|
|
# endif // OMITMASK
|
|
|
|
size_t c = 0;
|
|
|
|
for (size_t j = 0;;) {
|
|
|
|
u8 v = m[j];
|
|
|
|
for (size_t k = 0;;) {
|
|
|
|
if (!v)
|
|
|
|
return c;
|
|
|
|
++c;
|
|
|
|
if (++k >= 8)
|
|
|
|
break;
|
|
|
|
v <<= 1;
|
|
|
|
}
|
|
|
|
if (++j >= sizeof(IFT))
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return c;
|
|
|
|
}
|
2020-11-21 11:34:25 +00:00
|
|
|
#define filter_len S(filter_len)
|
2019-03-16 21:57:29 +02:00
|
|
|
|
|
|
|
#endif // INTFILTER
|
|
|
|
|
|
|
|
#ifdef BINFILTER
|
|
|
|
|
2020-11-21 11:34:25 +00:00
|
|
|
static inline size_t S(filter_len)(size_t i)
|
2019-03-16 21:57:29 +02:00
|
|
|
{
|
|
|
|
size_t c = VEC_BUF(filters,i).len * 8;
|
|
|
|
u8 v = VEC_BUF(filters,i).mask;
|
|
|
|
for (size_t k = 0;;) {
|
|
|
|
if (!v)
|
|
|
|
return c;
|
|
|
|
++c;
|
|
|
|
if (++k >= 8)
|
|
|
|
return c;
|
|
|
|
v <<= 1;
|
|
|
|
}
|
|
|
|
}
|
2020-11-21 11:34:25 +00:00
|
|
|
#define filter_len S(filter_len)
|
2019-03-16 21:57:29 +02:00
|
|
|
|
|
|
|
#endif // BINFILTER
|
|
|
|
|
|
|
|
#ifdef PCRE2FILTER
|
|
|
|
|
|
|
|
#define filter_len(i) ((pcre2ovector[1] - pcre2ovector[0]) * 5)
|
|
|
|
|
|
|
|
#endif // PCRE2FILTER
|