如何在clojure中设置和获取多方法元数据?

时间:2016-09-17 08:14:26

标签: clojure metadata multimethod

我正在使用multimethods来解析命令行命令及其参数。

(defmulti run (fn [command args] command))

(defmethod run :default
  [& _]
  ...)

^{:args "[command]"}
(defmethod run "help"
  [_ & [args]]
  "Display command list or help for a given command"
  ...)

^{:args ""}
(defmethod run "version"
  [_ & [args]]
  "Print program's version"
  ...)

(defn -main
  [& args]
  (run (first args)
    (next args)))

当我尝试访问元数据时,对于特定方法,clojure返回nil

(meta ((methods run) "help"))

1 个答案:

答案 0 :(得分:4)

没有这种可能性。第一个原因(直截了当)是defmethod没有提供为特定方法设置元数据的能力(只有defmulti允许这样做,但仅适用于整个多方法)。第二个原因是多方法本质上是一个单一的功能,只有多个"变体"执行,每个都根据传递的参数触发。粗略地说,从来电者的角度来看,下面定义的函数f1f2之间没有特别的区别:

(defmulti f1 (fn [x] x))

(defmethod f1 :foo [x]
  ...)

(defmethod f1 :bar [x]
  ...)

(defmethod f1 :baz [x]
  ...)

(defn f2 [x]
  (case x
    :foo ...
    :bar ...
    :baz ...))

就个人而言,我依赖于特定功能是多方法还是普通功能,因为它依赖于实现细节。此外,如果您需要明确记录multimehod的每个方法,您应该考虑用普通函数替换每个方法,并且根本不使用多方法。