From 90b8db84a48ca9ea1311abd202a546a4f697f4e6 Mon Sep 17 00:00:00 2001 From: Bruce Hill Date: Mon, 28 Sep 2020 18:08:23 -0700 Subject: Moved */+ back to prefix, and dropped ? --- compiler.c | 34 +++++++++++++++++----------------- 1 file changed, 17 insertions(+), 17 deletions(-) (limited to 'compiler.c') diff --git a/compiler.c b/compiler.c index 39a12b1..b7a2458 100644 --- a/compiler.c +++ b/compiler.c @@ -269,6 +269,22 @@ vm_op_t *bpeg_simplepattern(file_t *f, const char *str) set_range(op, 0, 1, pat, NULL); break; } + // Repeating + case '*': case '+': { + ssize_t min = c == '*' ? 0 : 1; + vm_op_t *pat = bpeg_simplepattern(f, str); + check(pat, "Expected pattern after '%c'", *str); + str = pat->end; + str = after_spaces(str); + vm_op_t *sep = NULL; + if (matchchar(&str, '%')) { + sep = bpeg_simplepattern(f, str); + check(sep, "Expected pattern for separator after '%%'"); + str = sep->end; + } + set_range(op, min, -1, pat, sep); + break; + } // Capture case '@': { op->op = VM_CAPTURE; @@ -373,23 +389,7 @@ vm_op_t *bpeg_simplepattern(file_t *f, const char *str) postfix: if (f ? str >= f->end : !*str) return op; str = after_spaces(str); - if (*str == '*' || *str == '+' || *str == '?') { // Repetitions: *, +, ? - char operator = *str; - ++str; - vm_op_t *pat = op; - vm_op_t *sep = NULL; - if (operator != '?' && matchchar(&str, '%')) { - sep = bpeg_simplepattern(f, str); - check(sep, "Expected pattern for separator after '%%'"); - str = sep->end; - } - op = calloc(sizeof(vm_op_t), 1); - set_range(op, operator == '+' ? 1 : 0, operator == '?' ? 1 : -1, pat, sep); - op->start = pat->start; - op->end = str; - op->len = -1; - goto postfix; - } else if ((str[0] == '=' || str[0] == '!') && str[1] == '=') { // Equality == and inequality != + if ((str[0] == '=' || str[0] == '!') && str[1] == '=') { // Equality == and inequality != int equal = str[0] == '='; str = after_spaces(str+2); vm_op_t *first = op; -- cgit v1.2.3