我安装了boot-clj,并希望能够在外部编辑器中编辑.clj文件,并单独运行命令行REPL,我可以从中调用我在.clj文件中更改的函数。不需要特殊的重新加载命令。
另一件事是我不想手动输入命令来包含命名空间 - 我想只运行一个脚本将我带入命名空间,所以我可以立即调用现有函数。
档案名称:
C:\dev\my-project\src\my_project\utils.clj
文件中的内容:
(ns my-project.utils
(:require
[clojure.string :as s]))
(defn my-range [start end]
(take (- end start) (iterate inc start)))
我想直接进入REPL并转到(my-range 0 3)
并查看它是否产生了我想要的结果。
这是什么设置?我需要运行的脚本文件是什么样的?
我目前的理解是答案看起来像这样:
(deftask dev-repl
(set-env! …)
(repl))
答案 0 :(得分:9)
您可以在命令行中在某种程度上实现此目的,而无需创建build.boot
文件:
在C:\ dev \ my_project :
boot -r src repl -n my-project.utils
boot -r src
:在“资源路径”上开始使用src
启动,这是可在JVM中访问的目录集。repl -n my-project.utils
启动REPL,需要您的命名空间,然后输入它。当REPL正在运行时,在您编辑C:\dev\my_project\src\my_project\utils.clj
之后,您可以在REPL上重新加载它,如下所示:
my-project.utils=> (require 'my-project.utils :reload)
nil
build.boot
或者,您可以使用以下内容创建文件C:\dev\my_project\build.boot
:
(set-env! :resource-paths #{"src"})
(deftask dev
"Run a development REPL"
[]
(repl :init-ns 'my-project.utils))
然后,在C:\dev\my_project
:
boot dev
这也将在您的命名空间中启动REPL,但由于我们已在build.boot
中执行了boot
将自动评估的配置,因此需要更少的命令行配置。
注意:在Clojure REPL中,无论构建工具如何,您都可以使用
require
函数要求任何命名空间(只要它在JVM的类路径上)并使用in-ns
函数输入它
最后,可以结合Boot的功能来实现围绕自动重新加载代码的开发工作流程。
在C:\dev\my_project\build.boot
:
(set-env! :resource-paths #{"src"})
(require '[boot.core :as core]
'[boot.pod :as pod])
(deftask load-ns
"Loads the my-project.utils namespace in a fresh pod."
[]
(let [pods (pod/pod-pool (core/get-env))]
(core/with-pre-wrap [fileset]
(pod/with-eval-in (pods :refresh)
;; We require indirectly here so that errors from my-project.utils have
;; proper line and column information.
(require 'my-project.load-impl))
fileset)))
(deftask dev
"Watches source code and loads my-project/utils every time code changes."
[]
(comp (watch)
(load-ns)))
在C:\dev\my_project\src\my_project\load_impl.clj
:
(ns my-project.load-impl)
(require 'my-project.utils)
在C:\dev\my_project\src\my_project\utils.clj
:
(ns my-project.utils
(:require
[clojure.string :as s]))
(defn my-range [start end]
(take (- end start) (iterate inc start)))
(println "In the code!")
(println "(my-range 0 10) = " (my-range 10 20))
返回命令提示符,键入boot dev
。您应该看到一些println
输出,每次编辑和保存文件时,您都应该再次看到它,反映您所做的任何更改。