2014-10-15 02:43:13 +01:00
|
|
|
#include "re1.5.h"
|
|
|
|
|
|
|
|
int _re1_5_classmatch(const char *pc, const char *sp)
|
|
|
|
{
|
|
|
|
// pc points to "cnt" byte after opcode
|
2014-10-16 11:56:13 +01:00
|
|
|
int is_positive = (pc[-1] == Class);
|
2014-10-15 02:43:13 +01:00
|
|
|
int cnt = *pc++;
|
|
|
|
while (cnt--) {
|
2021-10-22 12:23:47 +01:00
|
|
|
if (*pc == RE15_CLASS_NAMED_CLASS_INDICATOR) {
|
|
|
|
if (_re1_5_namedclassmatch(pc + 1, sp)) {
|
|
|
|
return is_positive;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (*sp >= *pc && *sp <= pc[1]) {
|
|
|
|
return is_positive;
|
|
|
|
}
|
|
|
|
}
|
2014-10-16 11:56:13 +01:00
|
|
|
pc += 2;
|
2014-10-15 02:43:13 +01:00
|
|
|
}
|
2014-10-16 11:56:13 +01:00
|
|
|
return !is_positive;
|
|
|
|
}
|
2015-02-21 10:33:20 +00:00
|
|
|
|
|
|
|
int _re1_5_namedclassmatch(const char *pc, const char *sp)
|
|
|
|
{
|
|
|
|
// pc points to name of class
|
|
|
|
int off = (*pc >> 5) & 1;
|
|
|
|
if ((*pc | 0x20) == 'd') {
|
|
|
|
if (!(*sp >= '0' && *sp <= '9')) {
|
|
|
|
off ^= 1;
|
|
|
|
}
|
|
|
|
} else if ((*pc | 0x20) == 's') {
|
|
|
|
if (!(*sp == ' ' || (*sp >= '\t' && *sp <= '\r'))) {
|
|
|
|
off ^= 1;
|
|
|
|
}
|
|
|
|
} else { // w
|
|
|
|
if (!((*sp >= 'A' && *sp <= 'Z') || (*sp >= 'a' && *sp <= 'z') || (*sp >= '0' && *sp <= '9') || *sp == '_')) {
|
|
|
|
off ^= 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return off;
|
|
|
|
}
|