PageRenderTime 41ms CodeModel.GetById 17ms RepoModel.GetById 0ms app.codeStats 0ms

/trunk/Examples/test-suite/schemerunme/list_vector.scm

#
Lisp | 26 lines | 22 code | 4 blank | 0 comment | 0 complexity | ec78df46b96fda6314e958d423af3ed9 MD5 | raw file
Possible License(s): LGPL-2.1, Cube, GPL-3.0, 0BSD, GPL-2.0
  1. (define-macro (check-equality form1 form2)
  2. `(let ((result1 ,form1)
  3. (result2 ,form2))
  4. (if (not (equal? result1 result2))
  5. (error "Check failed:"
  6. (list 'equal? ',form1 ',form2)
  7. result1 result2))))
  8. (check-equality (sum-list '(1 3 4 6 7)) 21.0)
  9. (check-equality (sum-vector #(2 4 6 7 9)) 28.0)
  10. (check-equality (one-to-seven-list) '(1 2 3 4 5 6 7))
  11. (check-equality (one-to-seven-vector) #(1 2 3 4 5 6 7))
  12. (check-equality (sum-list2 '(1 3 4 6 7)) 21.0)
  13. (check-equality (sum-vector2 #(2 4 6 7 9)) 28.0)
  14. (check-equality (one-to-seven-list2) '(1 2 3 4 5 6 7))
  15. (check-equality (one-to-seven-vector2) #(1 2 3 4 5 6 7))
  16. (check-equality (sum-lists '(1 2 3) '(4 5 6) '(7 8 9)) 45.0)
  17. (check-equality (sum-lists2 '(1 2 3) '(4 5 6) '(7 8 9)) 45.0)
  18. (check-equality (call-with-values produce-lists list)
  19. '(#(0 1 2 3 4)
  20. #(0 1 4 9 16)
  21. #(0.0 1.5 3.0 4.5 6.0)))
  22. (exit 0)