147 lines
5.1 KiB
Scheme
147 lines
5.1 KiB
Scheme
(load-relative "loadtest.ss")
|
|
|
|
(require syntax/boundmap)
|
|
|
|
(Section 'boundmap)
|
|
|
|
(test #t bound-identifier-mapping? (make-bound-identifier-mapping))
|
|
|
|
(let ()
|
|
;; contains-same? : (listof x) (listof x) -> boolean
|
|
(define (contains-same? l1 l2)
|
|
(and (andmap (lambda (x) (member x l2)) l1)
|
|
(andmap (lambda (x) (member x l1)) l2)
|
|
#t))
|
|
|
|
(let-values ([(x1 x2 x3 x4)
|
|
(syntax-case (expand #'((lambda (x) x) (lambda (x) x))) ()
|
|
[(x (a (x1) x2) (c (x3) x4))
|
|
(values (syntax x1)
|
|
(syntax x2)
|
|
(syntax x3)
|
|
(syntax x4))])])
|
|
|
|
(let ([check (lambda (=?)
|
|
(test #t =? x1 x2)
|
|
(test #t =? x3 x4)
|
|
(when (=? x1 x3)
|
|
((current-print) "huh!?"))
|
|
(test #f =? x1 x3)
|
|
(test #f =? x1 x4)
|
|
(test #f =? x2 x3)
|
|
(test #f =? x2 x4))])
|
|
(check bound-identifier=?)
|
|
(check free-identifier=?))
|
|
|
|
(let ([mapping (make-bound-identifier-mapping)])
|
|
(bound-identifier-mapping-put! mapping x1 #f)
|
|
(test #f bound-identifier-mapping-get mapping x1)
|
|
|
|
(bound-identifier-mapping-put! mapping x1 1)
|
|
(bound-identifier-mapping-put! mapping x2 2)
|
|
(bound-identifier-mapping-put! mapping x3 3)
|
|
(bound-identifier-mapping-put! mapping x4 4)
|
|
(test 2 bound-identifier-mapping-get mapping x1)
|
|
(test 2 bound-identifier-mapping-get mapping x2)
|
|
(test 4 bound-identifier-mapping-get mapping x3)
|
|
(test 4 bound-identifier-mapping-get mapping x4)
|
|
(test #t
|
|
contains-same?
|
|
(list 2 4)
|
|
(bound-identifier-mapping-map mapping (lambda (x y) y)))
|
|
|
|
(test #t
|
|
contains-same?
|
|
(list 2 4)
|
|
(let ([l '()])
|
|
(bound-identifier-mapping-for-each
|
|
mapping
|
|
(lambda (x y)
|
|
(set! l (cons y l))))
|
|
l)))
|
|
|
|
(let ([mapping (make-module-identifier-mapping)])
|
|
(module-identifier-mapping-put! mapping x1 1)
|
|
(module-identifier-mapping-put! mapping x2 2)
|
|
(module-identifier-mapping-put! mapping x3 3)
|
|
(module-identifier-mapping-put! mapping x4 4)
|
|
(test 2 module-identifier-mapping-get mapping x1)
|
|
(test 2 module-identifier-mapping-get mapping x2)
|
|
(test 4 module-identifier-mapping-get mapping x3)
|
|
(test 4 module-identifier-mapping-get mapping x4)
|
|
(test #t
|
|
contains-same?
|
|
(list 2 4)
|
|
(module-identifier-mapping-map mapping (lambda (x y) y)))
|
|
|
|
(test #t
|
|
contains-same?
|
|
(list 2 4)
|
|
(let ([l '()])
|
|
(module-identifier-mapping-for-each
|
|
mapping
|
|
(lambda (x y)
|
|
(set! l (cons y l))))
|
|
l))))
|
|
|
|
(let-values ([(y1 y2 y3 y4)
|
|
(syntax-case (expand #'(module m mzscheme (require (prefix x: mzscheme)) + x:+ - x:-)) ()
|
|
[(a b c (d e f y1 y2 y3 y4))
|
|
(values (syntax y1)
|
|
(syntax y2)
|
|
(syntax y3)
|
|
(syntax y4))])])
|
|
|
|
(let ([mapping (make-bound-identifier-mapping)])
|
|
(bound-identifier-mapping-put! mapping y1 1)
|
|
(bound-identifier-mapping-put! mapping y2 2)
|
|
(bound-identifier-mapping-put! mapping y3 3)
|
|
(bound-identifier-mapping-put! mapping y4 4)
|
|
(test 1 bound-identifier-mapping-get mapping y1)
|
|
(test 2 bound-identifier-mapping-get mapping y2)
|
|
(test 3 bound-identifier-mapping-get mapping y3)
|
|
(test 4 bound-identifier-mapping-get mapping y4)
|
|
(test #t
|
|
contains-same?
|
|
(list 1 2 3 4)
|
|
(bound-identifier-mapping-map mapping (lambda (x y) y)))
|
|
|
|
(test #t
|
|
contains-same?
|
|
(list 1 2 3 4)
|
|
(let ([l '()])
|
|
(bound-identifier-mapping-for-each
|
|
mapping
|
|
(lambda (x y)
|
|
(set! l (cons y l))))
|
|
l)))
|
|
|
|
(let ([mapping (make-module-identifier-mapping)])
|
|
(module-identifier-mapping-put! mapping y1 #f)
|
|
(test #f module-identifier-mapping-get mapping y1)
|
|
|
|
(module-identifier-mapping-put! mapping y1 1)
|
|
(module-identifier-mapping-put! mapping y2 2)
|
|
(module-identifier-mapping-put! mapping y3 3)
|
|
(module-identifier-mapping-put! mapping y4 4)
|
|
(test 2 module-identifier-mapping-get mapping y1)
|
|
(test 2 module-identifier-mapping-get mapping y2)
|
|
(test 4 module-identifier-mapping-get mapping y3)
|
|
(test 4 module-identifier-mapping-get mapping y4)
|
|
(test #t
|
|
contains-same?
|
|
(list 2 4)
|
|
(module-identifier-mapping-map mapping (lambda (x y) y)))
|
|
|
|
(test #t
|
|
contains-same?
|
|
(list 2 4)
|
|
(let ([l '()])
|
|
(module-identifier-mapping-for-each
|
|
mapping
|
|
(lambda (x y)
|
|
(set! l (cons y l))))
|
|
l)))))
|
|
|
|
(report-errs)
|