(define-macro (check test) `(if (not ,test) (error "Error in test" ',test))) (define b (make )) (check (= (bar b) 1)) (define f (make )) (check (= (foo f) 2)) (define fb (make )) (check (= (bar fb) 1)) (check (= (foo fb) 2)) (check (= (fooBar fb) 3)) (define id1 (make )) (check (= (bar id1) 1)) (check (= (ignorederived1 id1) 7)) (define id2 (make )) (check (= (bar id2) 1)) (check (= (ignorederived2 id2) 8)) (define id3 (make )) (check (= (bar id3) 1)) (check (= (ignorederived3 id3) 9)) (define id4 (make )) (check (= (bar id4) 1)) (check (= (ignorederived4 id4) 10)) (exit 0)