X-Git-Url: https://git.distorted.org.uk/~mdw/clg/blobdiff_plain/2bd78f93f681c3afb5b555265ae3831fbe3ba017..09d572a55408ef07badf9760fcd5c17ca3d93b6a:/gffi/virtual-slots.lisp diff --git a/gffi/virtual-slots.lisp b/gffi/virtual-slots.lisp index 6551210..21af52d 100644 --- a/gffi/virtual-slots.lisp +++ b/gffi/virtual-slots.lisp @@ -20,7 +20,7 @@ ;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE ;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -;; $Id: virtual-slots.lisp,v 1.3 2006-08-16 12:09:03 espen Exp $ +;; $Id: virtual-slots.lisp,v 1.5 2006-09-13 10:52:16 espen Exp $ (in-package "GFFI") @@ -112,7 +112,7 @@ (error 'unreadable-slot :name (slot-definition-name slotd) :instance object)) (let ((reader-function (call-next-method))) (cond - ;; Don't create an wrapper to signal unbound value + ;; Don't create wrapper to signal unbound value ((not signal-unbound-p) reader-function) ;; An explicit boundp function has been supplied @@ -143,7 +143,12 @@ (defmethod compute-slot-reader-function ((slotd effective-virtual-slot-definition) &optional signal-unbound-p) (declare (ignore signal-unbound-p)) - (slot-value slotd 'getter)) + (let ((getter (slot-value slotd 'getter))) + #-sbcl getter + #+sbcl + (etypecase getter + (symbol #'(lambda (object) (funcall getter object))) + (function getter)))) (defmethod compute-slot-boundp-function ((slotd effective-virtual-slot-definition)) (cond @@ -152,8 +157,14 @@ #'(lambda (object) (declare (ignore object)) nil)) ;; An explicit boundp function has been supplied - ((slot-boundp slotd 'boundp) (slot-value slotd 'boundp)) - + ((slot-boundp slotd 'boundp) + (let ((boundp (slot-value slotd 'boundp))) + #-sbcl boundp + #+sbcl + (etypecase boundp + (symbol #'(lambda (object) (funcall boundp object))) + (function boundp)))) + ;; An unbound value has been supplied ((slot-boundp slotd 'unbound) (let ((reader-function (compute-slot-reader-function slotd nil)) @@ -191,7 +202,12 @@ (call-next-method))) (defmethod compute-slot-writer-function ((slotd effective-virtual-slot-definition)) - (slot-value slotd 'setter)) + (let ((setter (slot-value slotd 'setter))) + #-sbcl setter + #+sbcl + (etypecase setter + (symbol #'(lambda (object value) (funcall setter object value))) + (function setter)))) (define-condition slot-can-not-be-unbound (cell-error) ((instance :reader slot-can-not-be-unbound-instance :initarg :instance)) @@ -205,7 +221,13 @@ ((not (slot-writable-p slotd)) #'(lambda (object) (error 'unwritable-slot :name (slot-definition-name slotd) :instance object))) - ((slot-boundp slotd 'makunbound) (slot-value slotd 'makunbound)) + ((slot-boundp slotd 'makunbound) + (let ((makunbound (slot-value slotd 'makunbound))) + #-sbcl makunbound + #+sbcl + (etypecase makunbound + (symbol #'(lambda (object) (funcall makunbound object))) + (function makunbound)))) ((slot-boundp slotd 'unbound) #'(lambda (object) (funcall (slot-value slotd 'writer-function) (slot-value slotd 'unbound) object))) @@ -291,7 +313,7 @@ ;; In CLISP and SBCL (0.9.15 or newler) a class may not have been ;; finalized when update-slots are called. So to avoid the possibility -;; of finalize-instance beeing called recursivly we have to delay the +;; of finalize-instance being called recursivly we have to delay the ;; initialization of slot functions until after an instance has been ;; created. #?(or (sbcl>= 0 9 15) (featurep :clisp)) @@ -326,7 +348,7 @@ ;;; To determine if a slot should be initialized with the initform, ;;; CLISP checks whether it is unbound or not. This doesn't work with -;;; virtual slots which does not have an unbound state, so we have to +;;; virtual slots that does not have an unbound state, so we have to ;;; implement initform initialization in a way similar to how it is ;;; done in PCL. #+clisp