В качестве упражнения я пытаюсь реализовать небольшую объектно-ориентированную программу с двумя классами:
point1d: 1 attribute (x), getter and setter
point2d: inherits from point1d, add a new attribute (y) and its getter and setter
Я реализовал каждый класс как замыкание. Это код для первого:
(define (point1d xx)
(let ((x xx))
(define (get-x)
x)
(define (set-x xx)
(set! x xx))
(lambda (f . args)
(apply
(case f
((get-x) get-x)
((set-x) set-x))
args))))
и для второго:
(define (point2d xx yy)
(let ((p1d (point1d xx))
(y yy))
(define (get-y)
y)
(define (set-y yy)
(set! y yy))
(lambda (f . args)
(case f
((get-y) (get-y))
((set-y) (apply set-y args))
(else (p1d f args))))))
У меня есть некоторые проблемы со вторым определением; в последней строке я пытаюсь вызвать метод родителей, но, поскольку args
- это список, он не работает.
Что я могу сделать?