相关疑难解决方法(0)

常见的lisp:宏如何用编程生成的名称定义其他方法/宏?

我意识到我的代码的某一部分由看起来相似的方法组组成(比如我有多个三重奏:一个辅助函数,它被另外两个函数调用给程序员).我正在尝试编写一个宏来为我定义这三个函数,所以我需要做的就是调用宏.但是我的尝试导致defuns和函数调用引用字符串而不是生成的名称作为新符号.我究竟做错了什么?

示例(错误的代码)

(defmacro def-trio (base-name)
  (let 
    ((helper-name (format nil "helper-~a" base-name))
     (method-1 (format nil "~a-1" base-name))
     (method-2 (format nil "~a-2" base-name)))
    `(progn 
          (defun ,helper-name () 'helper-called)
          (defun ,method-1 () (,helper-name) '1-called)
          (defun ,method-2 () (,helper-name) '2-called))))
Run Code Online (Sandbox Code Playgroud)

现在发生以下情况:

(def-trio my-trio)
Run Code Online (Sandbox Code Playgroud)

==>

(PROGN (DEFUN "helper-MY-TRIO" () 'HELPER-CALLED)
       (DEFUN "MY-TRIO-1" () ("helper-MY-TRIO") '1-CALLED)
       (DEFUN "MY-TRIO-2" () ("helper-MY-TRIO") '2-CALLED))
Run Code Online (Sandbox Code Playgroud)

另外,在我学会了如何使这个工作后,如果我有这个宏定义其他宏而不是其他函数,还有任何额外的问题吗?我读过如何在常见的lisp中编写一个宏定义宏,但我认为我的问题有点不同,因为我问的是编程生成的符号/名称.我很乐意接受纠正:)谢谢!

lisp macros common-lisp

13
推荐指数
2
解决办法
1574
查看次数

标签 统计

common-lisp ×1

lisp ×1

macros ×1