(defmethod print-object ((entry method-entry) stream)
(maybe-print-unreadable-object (entry stream :type t)
- (format stream "~A:~A"
+ (format stream "~A:~A~@[ ~S~]"
(method-entry-effective-method entry)
- (sod-class-nickname (method-entry-chain-head entry)))))
+ (sod-class-nickname (method-entry-chain-head entry))
+ (method-entry-role entry))))
(defmethod compute-sod-effective-method
((message sod-message) (class sod-class))
(defmethod slot-unbound
(clos-class (class sod-class) (slot-name (eql 'effective-methods)))
+ (declare (ignore clos-class))
(setf (slot-value class 'effective-methods)
(compute-effective-methods class)))
(defmethod slot-unbound
(clos-class (class sod-class) (slot-name (eql 'ilayout)))
+ (declare (ignore clos-class))
(setf (slot-value class 'ilayout)
(compute-ilayout class)))
(subclass sod-class)
(chain-head sod-class)
(chain-tail sod-class))
- (flet ((make-entry (message)
+ (flet ((make-entries (message)
(let ((method (find message
(sod-class-effective-methods subclass)
:key #'effective-method-message)))
- (make-method-entry method chain-head chain-tail))))
+ (make-method-entries method chain-head chain-tail))))
(make-instance 'vtmsgs
:class class
:subclass subclass
:chain-head chain-head
:chain-tail chain-tail
- :entries (mapcar #'make-entry
+ :entries (mapcan #'make-entries
(sod-class-messages class)))))
;;; class-pointer
(defmethod slot-unbound
(clos-class (class sod-class) (slot-name (eql 'vtables)))
+ (declare (ignore clos-class))
(setf (slot-value class 'vtables)
(compute-vtables class)))