[functional-tests/regex] add comment for regex grammar.
This commit is contained in:
parent
150f38cf83
commit
08ce1967ae
@ -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.
|
||||||
)
|
)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user