[functional-tests/regex] add comment for regex grammar.

This commit is contained in:
Joe Thornber 2017-08-20 13:35:40 +01:00
parent 150f38cf83
commit 08ce1967ae

View File

@ -149,7 +149,6 @@
;; current threads. Note there cannot be more threads than instructions, so ;; current threads. Note there cannot be more threads than instructions, so
;; a yarn is represented as a vector the same length as the instructions. ;; a yarn is represented as a vector the same length as the instructions.
;; Threads are run in lock step, all taking the same input. ;; Threads are run in lock step, all taking the same input.
(define-record-type yarn (define-record-type yarn
(fields (mutable size) (fields (mutable size)
(mutable stack) (mutable stack)
@ -219,7 +218,7 @@
(add-thread! threads l1) (add-thread! threads l1)
(add-thread! threads l2))))) (add-thread! threads l2)))))
;; compile to thunks to avoid calling match in the loop. ;; compile to closures to avoid calling match in the loop.
(let ((code (vector-copy code))) (let ((code (vector-copy code)))
(define (step in-c) (define (step in-c)
@ -248,4 +247,28 @@
(c-loop (+ 1 c-index))))) (c-loop (+ 1 c-index)))))
(any-matches? threads code)))))))))) (any-matches? threads code))))))))))
;;;--------------------------------------------------------
;;; Parser
;; <RE> ::= <union> | <simple-RE>
;; <union> ::= <RE> "|" <simple-RE>
;; <simple-RE> ::= <concatenation> | <basic-RE>
;; <concatenation> ::= <simple-RE> <basic-RE>
;; <basic-RE> ::= <star> | <plus> | <elementary-RE>
;; <star> ::= <elementary-RE> "*"
;; <plus> ::= <elementary-RE> "+"
;; <elementary-RE> ::= <group> | <any> | <eos> | <char> | <set>
;; <group> ::= "(" <RE> ")"
;; <any> ::= "."
;; <eos> ::= "$"
;; <char> ::= any non metacharacter | "\" metacharacter
;; <set> ::= <positive-set> | <negative-set>
;; <positive-set> ::= "[" <set-items> "]"
;; <negative-set> ::= "[^" <set-items> "]"
;; <set-items> ::= <set-item> | <set-item> <set-items>
;; <set-items> ::= <range> | <char>
;; <range> ::= <char> "-" <char>
;; I don't care about parse performance so we'll use a simple recursive
;; decent parser.
) )