lein ring server with nrepl不支持cider-nrepl。

5

当我使用 lein ring server 启动我的当前项目并尝试通过cider从Emacs连接到它时,我收到以下警告:

; CIDER 0.8.2 (Java 1.7.0_51, Clojure 1.6.0, nREPL 0.2.6)
WARNING: The following required nREPL ops are not supported: 
apropos classpath complete eldoc info inspect-start inspect-refresh inspect-pop inspect-push inspect-reset macroexpand ns-list ns-vars resource stacktrace toggle-trace-var toggle-trace-ns undef
Please, install (or update) cider-nrepl 0.8.2 and restart CIDER
user> 

然而,在我的project.clj中,我确实有一个依赖项[cider/cider-nrepl "0.8.2"]。 当我运行lein repl时,这个依赖项可以正常工作,并且我可以从cider成功连接到它:

; CIDER 0.8.2 (Java 1.7.0_51, Clojure 1.6.0, nREPL 0.2.6)
swedishchef.handler>

我发现使用Leiningen启动nREPL时会得到两种不同的消息:

[sugarcube->swedishchef]lein ring server
See https://github.com/technomancy/leiningen/wiki/Repeatability)
Started nREPL server on port 44231

这是使用工作中的cider-nrepl连接所得到的输出结果:
[sugarcube->swedishchef]lein repl
See https://github.com/technomancy/leiningen/wiki/Repeatability)
nREPL server started on port 38024 on host 127.0.0.1 - nrepl://127.0.0.1:38024
REPL-y 0.3.5, nREPL 0.2.6

lein deps :tree的输出来看,我没有发现任何问题。所以,我的第一个问题是这是否应该起作用,即cider-nrepl是否应该覆盖lein ring关于nrepl启动的行为?如果是这样,是否有人能给出进一步排除故障的建议?

1个回答

6

请使用最新的lein-ring插件版本0.9.2,并在project.clj中添加包含nrepl中间件向量的:nrepl-middleware:repl-options中。

例如,我通过lein new compojure-app my-app创建项目。然后,我通过在~/.lein/profiles.clj中创建一个空的leiningen配置文件 ex. {:yolo {}} 并使用lein with-profile yolo,dev ring server启动ring服务器来测试它。

(defproject my-app "0.1.0-SNAPSHOT"
  :description "FIXME: write description"
  :url "http://example.com/FIXME"
  :dependencies [[org.clojure/clojure "1.6.0"]
                 [compojure "1.1.6"]
                 [hiccup "1.0.5"]
                 [ring-server "0.3.1"]
                 [cider/cider-nrepl "0.8.2"]]
  :plugins [[lein-ring "0.9.2"]]
  :ring {:handler my-app.handler/app
         :init my-app.handler/init
         :destroy my-app.handler/destroy
         :nrepl {:start? true}}
  :repl-options {:nrepl-middleware
                 [cider.nrepl.middleware.apropos/wrap-apropos
                  cider.nrepl.middleware.classpath/wrap-classpath
                  cider.nrepl.middleware.complete/wrap-complete
                  cider.nrepl.middleware.info/wrap-info
                  cider.nrepl.middleware.inspect/wrap-inspect
                  cider.nrepl.middleware.macroexpand/wrap-macroexpand
                  cider.nrepl.middleware.ns/wrap-ns
                  cider.nrepl.middleware.resource/wrap-resource
                  cider.nrepl.middleware.stacktrace/wrap-stacktrace
                  cider.nrepl.middleware.test/wrap-test
                  cider.nrepl.middleware.trace/wrap-trace
                  cider.nrepl.middleware.undef/wrap-undef]}
  :profiles
  {:uberjar {:aot :all}
   :production
   {:ring
    {:open-browser? false, :stacktraces? false, :auto-reload? false}}
   :dev
   {:dependencies [[ring-mock "0.1.5"] [ring/ring-devel "1.3.1"]]}})

1
我开始显式添加nrepl-middleware,但最初没有得到预期的结果,因为我没有更新lein-ring。查看lein-ring的更改日志,很明显这是最近的更改。谢谢! - schaueho

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接