git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@5979 626c5289-ae23-0410-ae9c-e8d60b6d4f22
26 lines
879 B
Scheme
26 lines
879 B
Scheme
(define-macro (check-equality form1 form2)
|
|
`(let ((result1 ,form1)
|
|
(result2 ,form2))
|
|
(if (not (equal? result1 result2))
|
|
(error "Check failed:"
|
|
(list 'equal? ',form1 ',form2)
|
|
result1 result2))))
|
|
|
|
(check-equality (sum-list '(1 3 4 6 7)) 21.0)
|
|
(check-equality (sum-vector #(2 4 6 7 9)) 28.0)
|
|
(check-equality (one-to-seven-list) '(1 2 3 4 5 6 7))
|
|
(check-equality (one-to-seven-vector) #(1 2 3 4 5 6 7))
|
|
|
|
(check-equality (sum-list2 '(1 3 4 6 7)) 21.0)
|
|
(check-equality (sum-vector2 #(2 4 6 7 9)) 28.0)
|
|
(check-equality (one-to-seven-list2) '(1 2 3 4 5 6 7))
|
|
(check-equality (one-to-seven-vector2) #(1 2 3 4 5 6 7))
|
|
|
|
(check-equality (sum-lists '(1 2 3) '(4 5 6) '(7 8 9)) 45.0)
|
|
(check-equality (sum-lists2 '(1 2 3) '(4 5 6) '(7 8 9)) 45.0)
|
|
(check-equality (call-with-values produce-lists list)
|
|
'(#(0 1 2 3 4)
|
|
#(0 1 4 9 16)
|
|
#(0.0 1.5 3.0 4.5 6.0)))
|
|
|
|
(exit 0)
|