2024 Clojure 状态调查! 中分享您的想法。

欢迎!请参阅 关于 页面了解更多信息。

0
ClojureScript
以下情况似乎会出现错误


(ns repro.a-namespace
  (:require [cljs.spec.alpha :as s] :reload-all))


这里是重现问题的一个示例: https://github.com/arichiardi/cljs-reload-all-repro

堆栈很大,所以我附了一个文件,但关键是在这里


原因: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)
    at cljs.analyzer$forms_seq_STAR_$forms_seq___3119$fn__3120$fn__3121.invoke(analyzer.cljc:3676)
    at cljs.analyzer$forms_seq_STAR_$forms_seq___3119$fn__3120.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)
    at cljs.compiler$compile_file_STAR_$fn__4580.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)
    at cljs.compiler$compile_file$fn__4611.invoke(compiler.cljc:1553)
    ... 37 more

2 个回答

0
_由: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
0
参考:[https://clojure.atlassian.net/browse/CLJS-2543](https://clojure.atlassian.net/browse/CLJS-2543)(由 arichiardi 汇报)
...