We shall want this more later.
method-keyword-argument-lists generic
primary-method-class generic
simple-method-body generic
+ sod-message-applicable-methods generic
sod-message-argument-tail generic
sod-message-effective-method-class generic
sod-method-description generic
sod-initializer
sod-initializer-value
sod-initializer
+sod-message-applicable-methods
+ sod-message sod-class
sod-message-argument-tail
basic-message
sod-message-class
\dhead{gf}{effective-method-keywords @<method> @> @<list>}}
\end{describe*}
+\begin{describe}{gf}
+ {sod-message-applicable-methods @<message> @<class> @> list}
+\end{describe}
+
\begin{describe}{gf}
{sod-message-effective-method-class @<message> @> @<class>}
\end{describe}
(sod-class-nickname (method-entry-chain-head entry))
(method-entry-role entry))))
+(defmethod sod-message-applicable-methods
+ ((message sod-message) (class sod-class))
+ (mappend (lambda (super)
+ (remove message
+ (sod-class-methods super)
+ :key #'sod-method-message
+ :test-not #'eql))
+ (sod-class-precedence-list class)))
+
(defmethod compute-sod-effective-method
((message sod-message) (class sod-class))
- (let ((direct-methods (mappend (lambda (super)
- (remove message
- (sod-class-methods super)
- :key #'sod-method-message
- :test-not #'eql))
- (sod-class-precedence-list class))))
+ (let ((direct-methods (sod-message-applicable-methods message class)))
(make-instance (sod-message-effective-method-class message)
:message message
:class class
will be a list of applicable methods sorted in most-to-least specific
order."))
+(export 'sod-message-applicable-methods)
+(defgeneric sod-message-applicable-methods (message class)
+ (:documentation
+ "Return a list of applicable methods for a MESSAGE.
+
+ The list contains all methods applicable for MESSAGE when sent to an
+ instance of CLASS, most specific first."))
+
(export 'sod-message-effective-method-class)
(defgeneric sod-message-effective-method-class (message)
(:documentation