我有一个 lein 项目(使用 cascalog——但这并不是特别重要)。我正在尝试将诸如文件路径之类的属性外部化,因此最终得到的代码如下所示:
(defn output-tap [path] (hfs-textline (str (get-prop :output-path-prefix) path) :sinkmode :replace))
(def some-cascalog-query
(<- [?f1 ?f2 ?f3]
((output-tap (get-prop :output-path)) ?line)
(tab-split ?line :> ?f1 ?f2 ?f3)))
在上面的例子中,假设函数get-prop
存在;它只是使用标准 java 来读取属性值(基于此示例:在 clojure 中加载配置文件作为数据结构)。
现在我有一个加载属性值的主要方法,例如:
(defn -main [& args] (do (load-props (first args)) (do-cascalog-stuff)))
但是当我lein uberjar
得到一个编译时错误说:
Caused by: java.lang.IllegalArgumentException: Can not create a Path from an empty string
at org.apache.hadoop.fs.Path.checkPathArg(Path.java:82)
at org.apache.hadoop.fs.Path.<init>(Path.java:90)
at cascading.tap.hadoop.Hfs.getPath(Hfs.java:343)
defs 是否总是在编译时评估(而不是运行时评估)?还是我误解了这个错误?