X-Git-Url: https://git.distorted.org.uk/~mdw/sod/blobdiff_plain/3ee33e04477ace9d13587f28253fb8c6d1c7ed6c..e895be217c3be6769708da17c9ae87cb22db040e:/src/method-proto.lisp diff --git a/src/method-proto.lisp b/src/method-proto.lisp index d2ab761..e72044e 100644 --- a/src/method-proto.lisp +++ b/src/method-proto.lisp @@ -49,6 +49,13 @@ will be a list of applicable methods sorted in most-to-least specific order.")) +(export 'sod-message-receiver-type) +(defgeneric sod-message-receiver-type (message class) + (:documentation + "Return the type of the `me' argument in a MESSAGE received by CLASS. + + Typically this will just be `CLASS *' or `const CLASS *'.")) + (export 'sod-message-applicable-methods) (defgeneric sod-message-applicable-methods (message class) (:documentation @@ -288,9 +295,9 @@ (:documentation "Returns true if the effective METHOD is live. - An effective method is `live' if it should actually have proper method entry - functions associated with it and stored in the class vtable. The other - possibility is that the method is `dead', in which case the function + An effective method is `live' if it should actually have proper method + entry functions associated with it and stored in the class vtable. The + other possibility is that the method is `dead', in which case the function pointers in the vtable are left null.")) ;;;-------------------------------------------------------------------------- @@ -478,11 +485,13 @@ ((keyword-message-p message) (cons (make-argument *sod-key-pointer* (c-type (* (void :const)))) - raw-args)))) + raw-args)) + (t raw-args))) (*keyword-struct-disposition* (if (effective-method-keywords method) :pointer :null))) (codegen-push codegen) (ensure-ilayout-var codegen super) + (deliver-call codegen :void "SOD__IGNORE" "sod__obj") (when (keyword-message-p message) (if (eq *keyword-struct-disposition* :null) (deliver-call codegen :void "SOD__IGNORE" *sod-key-pointer*)