[functional-tests/regex] pull out a swap macro
This commit is contained in:
parent
b2b8d2b3c7
commit
ca6a036697
@ -193,6 +193,13 @@
|
||||
((_ (var str) body ...)
|
||||
(string-for-each (lambda (var) body ...) str))))
|
||||
|
||||
(define-syntax swap
|
||||
(syntax-rules ()
|
||||
((_ x y)
|
||||
(let ((tmp x))
|
||||
(set! x y)
|
||||
(set! y tmp)))))
|
||||
|
||||
(define (match-rx code txt)
|
||||
(fmt #t (dsp "running ") (pretty code) nl)
|
||||
(call/cc
|
||||
@ -201,12 +208,6 @@
|
||||
(let ((threads (mk-thread-set code-len))
|
||||
(next-threads (mk-thread-set code-len)))
|
||||
|
||||
(define (swap-ts)
|
||||
(let ((tmp threads))
|
||||
(set! threads next-threads)
|
||||
(clear-thread-set! tmp)
|
||||
(set! next-threads tmp)))
|
||||
|
||||
(add-thread! threads 0)
|
||||
(string-iter (in-c txt)
|
||||
(fmt #t (dsp "processing: ") (wrt in-c) nl)
|
||||
@ -226,7 +227,9 @@
|
||||
(add-thread! threads l2)))))
|
||||
(if (no-threads? next-threads)
|
||||
(k #f)
|
||||
(swap-ts)))
|
||||
(begin
|
||||
(swap threads next-threads)
|
||||
(clear-thread-set! next-threads))))
|
||||
(any-matches? threads code))))))
|
||||
|
||||
)
|
||||
|
Loading…
x
Reference in New Issue
Block a user