尝试做一个简单的clojure程序,不包括在另一个文件中定义的函数。它无法在同一目录中找到该文件。
helloInclude
src
main.clj
importer.clj
main.clj
(ns main
(:gen-class)
(:require [importer]))
(defn -main
[& args]
(println "Hello, World!"))
(-main)
(println (func 5 6))
importer.clj
(ns importer
(:gen-class))
(defn func
[a b]
(+ a b 1))
从src
目录中执行:
java -jar "Path\To\Clojure\clojure-1.8.0\clojure-1.8.0.jar" -i main.clj
返回错误:
Exception in thread "main" java.io.FileNotFoundException: Could not locate importer__init.class or importer.clj on classpath., compiling:(C:\Users\jamesjenkinson\Clojure\helloInclude\src\main.clj:1:1)
at clojure.lang.Compiler.load(Compiler.java:7391)
at clojure.lang.Compiler.loadFile(Compiler.java:7317)
at clojure.main$load_script.invokeStatic(main.clj:275)
at clojure.main$init_opt.invokeStatic(main.clj:277)
at clojure.main$init_opt.invoke(main.clj:277)
at clojure.main$initialize.invokeStatic(main.clj:308)
at clojure.main$null_opt.invokeStatic(main.clj:342)
at clojure.main$null_opt.invoke(main.clj:339)
at clojure.main$main.invokeStatic(main.clj:421)
at clojure.main$main.doInvoke(main.clj:384)
at clojure.lang.RestFn.invoke(RestFn.java:421)
at clojure.lang.Var.invoke(Var.java:383)
at clojure.lang.AFn.applyToHelper(AFn.java:156)
at clojure.lang.Var.applyTo(Var.java:700)
at clojure.main.main(main.java:37)
Caused by: java.io.FileNotFoundException: Could not locate import__init.class or import.clj on classpath.
at clojure.lang.RT.load(RT.java:456)
at clojure.lang.RT.load(RT.java:419)
at clojure.core$load$fn__5677.invoke(core.clj:5893)
at clojure.core$load.invokeStatic(core.clj:5892)
at clojure.core$load.doInvoke(core.clj:5876)
at clojure.lang.RestFn.invoke(RestFn.java:408)
at clojure.core$load_one.invokeStatic(core.clj:5697)
at clojure.core$load_one.invoke(core.clj:5692)
at clojure.core$load_lib$fn__5626.invoke(core.clj:5737)
at clojure.core$load_lib.invokeStatic(core.clj:5736)
at clojure.core$load_lib.doInvoke(core.clj:5717)
at clojure.lang.RestFn.applyTo(RestFn.java:142)
at clojure.core$apply.invokeStatic(core.clj:648)
at clojure.core$load_libs.invokeStatic(core.clj:5774)
at clojure.core$load_libs.doInvoke(core.clj:5758)
at clojure.lang.RestFn.applyTo(RestFn.java:137)
at clojure.core$apply.invokeStatic(core.clj:648)
at clojure.core$require.invokeStatic(core.clj:5796)
at clojure.core$require.doInvoke(core.clj:5796)
at clojure.lang.RestFn.invoke(RestFn.java:408)
at src.main$eval3$loading__5569__auto____4.invoke(main.clj:1)
at src.main$eval3.invokeStatic(main.clj:1)
at src.main$eval3.invoke(main.clj:1)
at clojure.lang.Compiler.eval(Compiler.java:6927)
at clojure.lang.Compiler.eval(Compiler.java:6916)
at clojure.lang.Compiler.load(Compiler.java:7379)
... 14 more
还尝试显式调用classpath作为当前目录:
java -classpath . -jar "Path\To\Clojure\clojure-1.8.0\clojure-1.8.0.jar" -i main.clj
我无法使用Leiningen。我该如何正确引用该文件?
修改 将名称空间更改为顶级。
答案 0 :(得分:1)
我希望我能正确找到您,我们也遇到了类似的问题,我似乎已经解决了。我当前的目录结构是(原谅事物的幽默性质):
.
├── chikaka
│ ├── main.clj
│ └── tools
│ └── dog.clj
├── core.clj
└── deps.edn
对我来说,关键是deps.edn
文件,该文件具有以下内容:
{:paths ["."]}
来源:https://clojure.org/reference/deps_and_cli#_paths
将paths
添加到deps文件中时,每个都添加到Java非常喜欢的光荣的CLASSPATH中。然后您将需要像这样的要求,例如:
(ns chikaka.main
(:require [chikaka.tools.dog :refer [bark]]))
答案 1 :(得分:0)
require
仅查找类路径下的文件。如果您希望能够使用require,则代码相对于类路径的路径必须与命名空间的包和名称相匹配。 java的-cp
arg可以将目录添加到类路径中,当前目录在类路径中隐式地 。
如果文件只是import
,则它必须直接位于顶层目录中,并且必须更改其包,因此它是顶级命名空间。要使用其当前位置和套餐,您必须使用src.import
代替import
。
此外,不建议使用顶级命名空间。
最后,运行-main
的正确选项是-m
。
+$ ls
import.clj main.clj
+$ cat import.clj
(ns import)
(defn foo
[]
(println "hello"))
+$ cat main.clj
(ns main
(:require [import])
(:gen-class))
(defn -main
[& args]
(import/foo))
:$ java -cp ~/bin/clojure.jar:. clojure.main -m main
hello