_由:mfikes_ 发布的评论
最小重演,没有到项目链接
将以下内容放入 {{src/repro/a_namespace.cljs}}
(ns repro.a-namespace
(:require [cljs.spec.alpha :as s]))
并编译
Clojure -Sdeps '{:deps {org.clojurescript {:git/url "
https://github.com/clojure/clojurescript :sha "7c754fbb9ffb9da790f21776d53a3b83deef922b"}}}' -m cljs.main -O simple -t node -c repro.a-namespace
这将正确编译。
然后修改源文件,在 {{ns}} 形式中添加 {{:reload-all}}。
(ns repro.a-namespace
(:require [cljs.spec.alpha :as s] :reload-all))
再尝试同样的编译
$$ clojure -Sdeps '{:deps {org.clojurescript {:git/url "
https://github.com/clojure/clojurescript :sha "7c754fbb9ffb9da790f21776d53a3b83deef922b"}}}' -m cljs.main -O simple -t node -c repro.a-namespace
主线程中出现异常 clojure.lang.ExceptionInfo: 编译文件失败:file:/Users/mfikes/Desktop/src/repro/a_namespace.cljs {:file #object[java.io.File 0x2904bb45 "/Users/mfikes/Desktop/src/repro/a_namespace.cljs"]}
at clojure.core$ex_info.invokeStatic(core.clj:4739)
at clojure.core$ex_info.invoke(core.clj:4739)
在 cljs.compiler$compile_file$fn__4619.invoke(compiler.cljc:1567)
在 cljs.compiler$compile_file.invokeStatic(compiler.cljc:1528)
在 cljs.compiler$compile_file.invoke(compiler.cljc:1504)
在 cljs.closure$compile_file.invokeStatic(closure.clj:558)
在 cljs.closure$compile_file.invoke(closure.clj:549)
在 cljs.closure$eval6938$fn__6939.invoke(closure.clj:627)
在 cljs.closure$eval6874$fn__6875$G__6863__6882.invoke(closure.clj:511)
在 cljs.closure$compile_sources$iter__7062__7066$fn__7067.invoke(closure.clj:972)
at clojure.lang.LazySeq.sval(LazySeq.java:40)
at clojure.lang.LazySeq.seq(LazySeq.java:49)
在 clojure.lang.Cons.next(Cons.java:39)
在 clojure.lang.RT.next(RT.java:706)
在 clojure.core$next__5108.invokeStatic(core.clj:64)
在 clojure.core$dorun.invokeStatic(core.clj:3134)
在 clojure.core$doall.invokeStatic(core.clj:3140)
在 clojure.core$doall.invoke(core.clj:3140)
在 cljs.closure$compile_sources.invokeStatic(closure.clj:968)
在 cljs.closure$compile_sources.invoke(closure.clj:957)
在 cljs.closure$build.invokeStatic(closure.clj:2756)
在 cljs.closure$build.invoke(closure.clj:2662)
在 cljs.build.api$build.invokeStatic(api.clj:205)
在 cljs.build.api$build.invoke(api.clj:189)
在 cljs.build.api$build.invokeStatic(api.clj:192)
在 cljs.build.api$build.invoke(api.clj:189)
在 cljs.cli$default_compile.invokeStatic(cli.clj:299)
在 cljs.cli$default_compile.invoke(cli.clj:274)
在 cljs.cli$compile_opt.invokeStatic(cli.clj:305)
在 cljs.cli$compile_opt.invoke(cli.clj:303)
在 cljs.cli$main.invokeStatic(cli.clj:427)
在 cljs.cli$main.doInvoke(cli.clj:416)
在 clojure.lang.RestFn.applyTo(RestFn.java:139)
在 clojure.core$apply.invokeStatic(core.clj:659)
在 clojure.core$apply.invoke(core.clj:652)
在 cljs.main$_main.invokeStatic(main.clj:60)
在 cljs.main$_main.doInvoke(main.clj:52)
在 clojure.lang.RestFn.applyTo(RestFn.java:137)
在 clojure.lang.Var.applyTo(Var.java:702)
在 clojure.core$apply.invokeStatic(core.clj:657)
在 clojure.main$main_opt.invokeStatic(main.clj:317)
在 clojure.main$main_opt.invoke(main.clj:313)
在 clojure.main$main.invokeStatic(main.clj:424)
在 clojure.main$main.doInvoke(main.clj:387)
在 clojure.lang.RestFn.applyTo(RestFn.java:137)
在 clojure.lang.Var.applyTo(Var.java:702)
在 clojure.main.main(main.java:37)
原因:clojure.lang.ExceptionInfo:对于 class:clojure.tools.reader.reader_types.IndexingPushbackReader {:type :reader-exception},找不到协议:#'clojure.tools.reader.reader-types/Reader 的方法::read-char
at clojure.core$ex_info.invokeStatic(core.clj:4739)
at clojure.core$ex_info.invoke(core.clj:4739)
at clojure.tools.reader$read_STAR_.invokeStatic(reader.clj:941)
at clojure.tools.reader$read_STAR_.invoke(reader.clj:905)
at clojure.tools.reader$read.invokeStatic(reader.clj:972)
at clojure.tools.reader$read.invoke(reader.clj:949)
在 cljs.analyzer$forms_seq_STAR_$forms_seq___3329$fn__3330$fn__3331.invoke(analyzer.cljc:3676)
在 cljs.analyzer$forms_seq_STAR_$forms_seq___3329$fn__3330.invoke(analyzer.cljc:3669)
at clojure.lang.LazySeq.sval(LazySeq.java:40)
at clojure.lang.LazySeq.seq(LazySeq.java:49)
at clojure.lang.RT.seq(RT.java:528)
at clojure.core$seq__5124.invokeStatic(core.clj:137)
at clojure.core$seq__5124.invoke(core.clj:137)
at cljs.compiler$emit_source.invokeStatic(compiler.cljc:1389)
at cljs.compiler$emit_source.invoke(compiler.cljc:1370)
在 cljs.compiler$compile_file_STAR_$fn__4588.invoke(compiler.cljc:1471)
at cljs.compiler$with_core_cljs.invokeStatic(compiler.cljc:1285)
at cljs.compiler$with_core_cljs.invoke(compiler.cljc:1274)
at cljs.compiler$compile_file_STAR_.invokeStatic(compiler.cljc:1456)
at cljs.compiler$compile_file_STAR_.invoke(compiler.cljc:1449)
在 cljs.compiler$compile_file$fn__4619.invoke(compiler.cljc:1553)
... 44 more
原因:java.lang.IllegalArgumentException: 未找到协议:clojure.tools.reader.reader-types/Reader 方法的实现::read-char,对于类 clojure.tools.reader.reader_types.IndexingPushbackReader
在 clojure.core$_cache_protocol_fn.invokeStatic(core_deftype.clj:583)
在 clojure.core$_cache_protocol_fn.invoke(core_deftype.clj:575)
在 clojure.tools.reader.reader_types$eval19106$fn__19118$G__19095__19123.invoke(reader_types.clj:24)
在 clojure.tools.reader$read_STAR_.invokeStatic(reader.clj:916)
... 62 more