; Copyright (c) 1993, 1994 Richard Kelsey and Jonathan Rees. See file COPYING. ; ((method () 1)) => 1 ; ((method () 1) 2) => error ; ((method (x) 1) 2) => 1 ; ((method ((x )) 1) 2) => error ; ((method ((x )) 1) 'foo) => 1 ; ((method ((x )) (next-method)) 'foo) => error (define-generic-function elt ((s ))) (define-method elt ((x ) y) (vector-ref x y)) ; (elt '#(a b c) 1) => b (define-method elt ((x ) y) (string-ref x y)) (define-method elt ((x ) y) (list-ref x y)) ; Setters (define-generic-function (setter elt) (thing index new-value)) (define-method (setter elt) ((x ) i z) (vector-set! x i z)) ; (let ((v (vector 1 2 3))) (set (elt v 1) 'foo) v) => '#(1 foo 3) ; Classes (define-class () a b) ; (a (make )) => '*uninitialized* ; (let ((m (make ))) (set (a m) 'foo) (a m)) => 'foo (define-method initialize ((m ) z) (set (a m) z)) ; (a (make 3)) => 3