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

欢迎!请查看关于页面了解更多关于此作品的信息。

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:没有找到类 clojure.tools.reader.reader_types/Reader 的协议 :read-char 的方法实现:clojure.tools.reader.reader_types.IndexingPushbackReader {:type :reader-exception}
    在 clojure.core$ex_info.invokeStatic(core.clj:4739)
    在 clojure.core$ex_info.invoke(core.clj:4739)
    在 clojure.tools.reader$read_STAR_.invokeStatic(reader.clj:941)
    在 clojure.tools.reader$read_STAR_.invoke(reader.clj:905)
    在 clojure.tools.reader$read.invokeStatic(reader.clj:972)
    在 clojure.tools.reader$read.invoke(reader.clj:949)
    在 cljs.analyzer$forms_seq_STAR_$forms_seq___3119$fn__3120$fn__3121.invoke(analyzer.cljc:3676)
    在 cljs.analyzer$forms_seq_STAR_$forms_seq___3119$fn__3120.invoke(analyzer.cljc:3669)
    在 clojure.lang.LazySeq.sval(LazySeq.java:40)
    在 clojure.lang.LazySeq.seq(LazySeq.java:49)
    在 clojure.lang.RT.seq(RT.java:528)
    在 clojure.core$seq__5124.invokeStatic(core.clj:137)
    在 clojure.core$seq__5124.invoke(core.clj:137)
    在 cljs.compiler$emit_source.invokeStatic(compiler.cljc:1389)
    在 cljs.compiler$emit_source.invoke(compiler.cljc:1370)
    在 cljs.compiler$compile_file_STAR_$fn__4580.invoke(compiler.cljc:1471)
    在 cljs.compiler$with_core_cljs.invokeStatic(compiler.cljc:1285)
    在 cljs.compiler$with_core_cljs.invoke(compiler.cljc:1274)
    在 cljs.compiler$compile_file_STAR_.invokeStatic(compiler.cljc:1456)
    在 cljs.compiler$compile_file_STAR_.invoke(compiler.cljc:1449)
    在 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"]}
    在 clojure.core$ex_info.invokeStatic(core.clj:4739)
    在 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)
    在 clojure.lang.LazySeq.sval(LazySeq.java:40)
    在 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:没有找到类 clojure.tools.reader.reader_types/Reader 的协议 :read-char 的方法实现:clojure.tools.reader.reader_types.IndexingPushbackReader {:type :reader-exception}
    在 clojure.core$ex_info.invokeStatic(core.clj:4739)
    在 clojure.core$ex_info.invoke(core.clj:4739)
    在 clojure.tools.reader$read_STAR_.invokeStatic(reader.clj:941)
    在 clojure.tools.reader$read_STAR_.invoke(reader.clj:905)
    在 clojure.tools.reader$read.invokeStatic(reader.clj:972)
    在 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)
    在 clojure.lang.LazySeq.sval(LazySeq.java:40)
    在 clojure.lang.LazySeq.seq(LazySeq.java:49)
    在 clojure.lang.RT.seq(RT.java:528)
    在 clojure.core$seq__5124.invokeStatic(core.clj:137)
    在 clojure.core$seq__5124.invoke(core.clj:137)
    在 cljs.compiler$emit_source.invokeStatic(compiler.cljc:1389)
    在 cljs.compiler$emit_source.invoke(compiler.cljc:1370)
    在 cljs.compiler$compile_file_STAR_$fn__4588.invoke(compiler.cljc:1471)
    在 cljs.compiler$with_core_cljs.invokeStatic(compiler.cljc:1285)
    在 cljs.compiler$with_core_cljs.invoke(compiler.cljc:1274)
    在 cljs.compiler$compile_file_STAR_.invokeStatic(compiler.cljc:1456)
    在 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.IndexingPushbackReader找到协议clojure.tools.reader.reader-types/Reader的实现方法::read-char。
    在 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 (由arichiardi报告)
...