X-Git-Url: https://git.distorted.org.uk/~mdw/sod/blobdiff_plain/aa14a4cddcb96b681d5c19a2ec8bad382f43b264..4ac20e3bbed1cba5c16d4573431db20a84d5e28b:/src/class-make-impl.lisp diff --git a/src/class-make-impl.lisp b/src/class-make-impl.lisp index 4470416..09ce441 100644 --- a/src/class-make-impl.lisp +++ b/src/class-make-impl.lisp @@ -87,8 +87,7 @@ :location (file-location location) :pset pset))) (with-slots (slots) class - (setf slots (append slots (list slot)))) - (check-unused-properties pset)))) + (setf slots (append slots (list slot))))))) (defmethod shared-initialize :after ((slot sod-slot) slot-names &key pset) "This method does nothing. @@ -112,8 +111,7 @@ (file-location location)))) (with-slots (instance-initializers) class (setf instance-initializers - (append instance-initializers (list initializer)))) - (check-unused-properties pset)))) + (append instance-initializers (list initializer))))))) (defmethod make-sod-class-initializer ((class sod-class) nick name value-kind value-form pset @@ -126,8 +124,7 @@ (file-location location)))) (with-slots (class-initializers) class (setf class-initializers - (append class-initializers (list initializer)))) - (check-unused-properties pset)))) + (append class-initializers (list initializer))))))) (defmethod make-sod-initializer-using-slot ((class sod-class) (slot sod-slot) @@ -163,8 +160,7 @@ :location (file-location location) :pset pset))) (with-slots (messages) class - (setf messages (append messages (list message)))) - (check-unused-properties pset)))) + (setf messages (append messages (list message))))))) (defmethod shared-initialize :after ((message sod-message) slot-names &key pset) @@ -189,8 +185,7 @@ type body pset (file-location location)))) (with-slots (methods) class - (setf methods (append methods (list method))))) - (check-unused-properties pset))) + (setf methods (append methods (list method))))))) (defmethod make-sod-method-using-message ((message sod-message) (class sod-class) type body pset location) @@ -215,7 +210,10 @@ ;; Check that the arguments are named if we have a method body. (with-slots (body type) method (unless (or (not body) - (every #'argument-name (c-function-arguments type))) + (every (lambda (arg) + (or (argument-name arg) + (eq (argument-type arg) (c-type void)))) + (c-function-arguments type))) (error "Abstract declarators not permitted in method definitions"))) ;; Check the method type.