【发布时间】:2011-12-13 11:02:49
【问题描述】:
短版:使用 lein swank 启动 swank 服务器时,运行 M-x slime-connect 或 M-x clojure-jack-in 时出错。
我在 Ubuntu 10.10 上使用 emacs 24.0.50.1。我在 ELPA 的 emacs 中安装了以下软件包:clojure-mode、paredit、slime、slime-repl
我从 github 安装了 leiningen 并将其添加到类路径中,然后运行
lein plugin install swank-clojure 1.3.3。
之后,我创建了一个新目录 ~/tmp/,cd 进入它并运行:
lein new test-project 似乎一切正常。然后我在emacs中打开/tmp/new-project/project.clj,改成:
(defproject test-project "1.0.0-SNAPSHOT"
:description "Test Project"
:dependencies [[org.clojure/clojure "1.2.1"]
[org.clojure/clojure-contrib "1.2.0"]]
:dev-dependencies [[swank-clojure "1.3.3"]])
之后我回到 /tmp/new-project 文件夹并运行 lein deps 然后运行 lein swank 以下载依赖项并启动提供输出的 swank 服务器:
Connection opened on local port 4005.
回到 emacs 是我在连接到 swank 服务器时遇到的问题。我已经尝试打开 core.clj 文件并运行 M-x slime-connect,它给出了错误:
Symbol's function definition is void: define-slime-contrib
这让我觉得它要么没有看到 swank 服务器正在运行,要么需要进行一些配置才能看到服务器。我也尝试过(打开相同的文件并打开 project.clj)M-x clojure-jack-in我假设尝试在项目文件夹中启动 clojure REPL,但这给出了以下内容:
Debugger entered--Lisp error: (error "Could not start swank server: sh: lein: not found
")
signal(error ("Could not start swank server: sh: lein: not found\n"))
error("Could not start swank server: %s" "sh: lein: not found\n")
clojure-jack-in-sentinel(#<process swank> "exited abnormally with code 127\n")
我按照 http://matthias-schneider.org/docs/clojure-setup/ 的指示进行 emacs 包和 lein 设置,然后开始按照 http://riddell.us/ClojureSwankLeiningenWithEmacsOnLinux.html 的测试配置说明进行操作,因为我无法让 M-x slime-connect 打开 REPL。
更新:
删除 ~/tmp/test-project,卸载 emacs 和 /.emacs.d/elpa/ 包,重新安装 emacs,重新安装 clojure-mode 和 paredit 包,将 ~/.lein 复制到 /bin 以确保没有路径问题(不确定 /.lein 或 /.lein/bin 是否需要在路径中)。跑/.lein/bin/swank-clojure,然后打开emacs,打开project.clj,尝试M-x slime-connect,它现在要求我提供主机(本地默认),端口(默认4005),说连接到swank,给出关于swank的消息和粘液版本不同(y 或 n)y,然后 minibuffers 给出error in process filter: Lisp connection closed unexpectedly。在我运行 /.lein/bin/swank-clojure 的终端中,弹出以下 java 错误:
exception in read loop
java.lang.NumberFormatException: For input string: " a6"
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
at java.lang.Integer.parseInt(Integer.java:470)
at swank.core.protocol$read_swank_message.invoke(protocol.clj:41)
at swank.core.connection$read_from_connection.invoke(connection.clj:59)
at swank.core$read_loop.invoke(core.clj:337)
at swank.swank$connection_serve$fn__1486$fn__1487.invoke(swank.clj:32)
at clojure.lang.AFn.applyToHelper(AFn.java:159)
at clojure.lang.AFn.applyTo(AFn.java:151)
at clojure.core$apply.invoke(core.clj:540)
at swank.swank$connection_serve$fn__1486.doInvoke(swank.clj:29)
at clojure.lang.RestFn.invoke(RestFn.java:397)
at clojure.lang.AFn.run(AFn.java:24)
at java.lang.Thread.run(Thread.java:636)
更新:
解决了,我需要卸载 emacs 并删除所有 /.emacs.d/,而不仅仅是 /elpa/ 中的包。重新安装后,我只得到了 clojure-mode 包,而不是 slime 或 slime-repl。现在可以与M-x clojure-jack-in 联系并准备好做一些工作了!
【问题讨论】:
标签: emacs clojure slime swank leiningen