[functional-tests] move swap! to (utils)

This commit is contained in:
Joe Thornber 2017-08-23 10:49:36 +01:00
parent e3053df850
commit 2fe464a4cf
2 changed files with 12 additions and 10 deletions

View File

@ -6,7 +6,8 @@
(loops) (loops)
(prefix (parser-combinators) p:) (prefix (parser-combinators) p:)
(srfi s8 receive) (srfi s8 receive)
(matchable)) (matchable)
(utils))
;; Simple regex library, because it's friday and I'm bored. ;; Simple regex library, because it's friday and I'm bored.
;; Playing with the ideas in: https://swtch.com/~rsc/regexp/regexp2.html ;; Playing with the ideas in: https://swtch.com/~rsc/regexp/regexp2.html
@ -183,13 +184,6 @@
(define (no-threads? y) (define (no-threads? y)
(zero? (yarn-size y))) (zero? (yarn-size y)))
(define-syntax swap
(syntax-rules ()
((_ x y)
(let ((tmp x))
(set! x y)
(set! y tmp)))))
;; FIXME: hack ;; FIXME: hack
(define end-of-string #\x0) (define end-of-string #\x0)
@ -244,7 +238,7 @@
(if (no-threads? next-threads) (if (no-threads? next-threads)
#f #f
(begin (begin
(swap threads next-threads) (swap! threads next-threads)
(clear-yarn! next-threads) (clear-yarn! next-threads)
(c-loop (+ 1 c-index))))) (c-loop (+ 1 c-index)))))
(eq? 'match (step end-of-string)))))))) (eq? 'match (step end-of-string))))))))

View File

@ -1,7 +1,8 @@
(library (library
(utils) (utils)
(export inc! (export inc!
dec!) dec!
swap!)
(import (rnrs)) (import (rnrs))
(define-syntax inc! (define-syntax inc!
@ -13,4 +14,11 @@
(syntax-rules () (syntax-rules ()
((_ v) (set! v (- v 1))) ((_ v) (set! v (- v 1)))
((_ v n) (set! v (- v n))))) ((_ v n) (set! v (- v n)))))
(define-syntax swap!
(syntax-rules ()
((_ x y)
(let ((tmp x))
(set! x y)
(set! y tmp)))))
) )