Funcallable AMOP
Posted on
July
22, 2023
Using macrolet
to allow a funcallable-standard-class
to be invoked without
using funcall
directly, and let the macroexpansion do that instead:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#!/usr/bin/env li
(asdf:load-system :closer-mop)
(defclass constructor ()
((name :initarg :name :accessor constructor-name))
(:metaclass closer-mop:funcallable-standard-class))
(defmethod initialize-instance :after ((c constructor) &key)
(with-slots (name) c
(closer-mop:set-funcallable-instance-function
c
(lambda (x)
(format t "~s: ~s - ~s~%" name :funcalled x)))))
(let ((c (make-instance 'constructor :name "the-name")))
(funcall c 1))
(let ((c (make-instance 'constructor :name "the-name")))
(macrolet ((c (&body body)
`(funcall c ,@body)))
(funcall c 2)
(c 3)))