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

欢迎!请查看 关于 页面以了解更多关于这个站点如何运作的信息。

0
ClojureScript

(def a 3)

`
$ clj -Srepro -m cljs.main
java.lang.IllegalArgumentException: /var/folders/gx/nymj3l7x4zq3gxb97v2zwzb40000gn/T/out6255758032123683761473031144485066/cljs/user/userAE725FA.js 不是相对路径

at clojure.java.io$as_relative_path.invokeStatic(io.clj:414)
at clojure.java.io$file.invokeStatic(io.clj:426)
at clojure.java.io$file.invoke(io.clj:418)
at cljs.closure$compile_file.invokeStatic(closure.clj:633)
at cljs.closure$compile_file.invoke(closure.clj:625)
at cljs.closure$fn__5175.invokeStatic(closure.clj:721)
at cljs.closure$fn__5175.invoke(closure.clj:715)
at cljs.closure$fn__5088$G__5081__5095.invoke(closure.clj:543)
at cljs.closure$compile.invokeStatic(closure.clj:595)
at cljs.closure$compile.invoke(closure.clj:592)
at cljs.repl$load_file$fn__6454.invoke(repl.cljc:601)
at cljs.repl$load_file.invokeStatic(repl.cljc:600)
at cljs.repl$load_file.invoke(repl.cljc:592)
at cljs.repl$repl_STAR_$maybe_load_user_file__6612.invoke(repl.cljc:958)
at cljs.repl$repl_STAR_$fn__6621$fn__6622.invoke(repl.cljc:989)
at cljs.repl$repl_STAR_$fn__6621.invoke(repl.cljc:982)
at cljs.compiler$with_core_cljs.invokeStatic(compiler.cljc:1289)
at cljs.compiler$with_core_cljs.invoke(compiler.cljc:1278)
at cljs.repl$repl_STAR_.invokeStatic(repl.cljc:979)
at cljs.repl$repl_STAR_.invoke(repl.cljc:855)
at cljs.cli$repl_opt.invokeStatic(cli.clj:305)
at cljs.cli$repl_opt.invoke(cli.clj:292)
at cljs.cli$main.invokeStatic(cli.clj:638)
at cljs.cli$main.doInvoke(cli.clj:625)
at clojure.lang.RestFn.invoke(RestFn.java:410)
at clojure.lang.AFn.applyToHelper(AFn.java:154)
at clojure.lang.RestFn.applyTo(RestFn.java:132)
at clojure.core$apply.invokeStatic(core.clj:659)
at clojure.core$apply.invoke(core.clj:652)
at cljs.main$_main.invokeStatic(main.clj:61)
at cljs.main$_main.doInvoke(main.clj:52)
at clojure.lang.RestFn.invoke(RestFn.java:397)
at clojure.lang.AFn.applyToHelper(AFn.java:152)
at clojure.lang.RestFn.applyTo(RestFn.java:132)
at clojure.lang.Var.applyTo(Var.java:702)
at clojure.core$apply.invokeStatic(core.clj:657)
at clojure.main$main_opt.invokeStatic(main.clj:317)
at clojure.main$main_opt.invoke(main.clj:313)
at clojure.main$main.invokeStatic(main.clj:424)
at clojure.main$main.doInvoke(main.clj:387)
at clojure.lang.RestFn.applyTo(RestFn.java:137)
at clojure.lang.Var.applyTo(Var.java:702)
at clojure.main.main(main.java:37)

ClojureScript 1.10.339
cljs.user=>
`

如果您指定了一个输出目录(通过 {{-d}}),则一切正常。

7 答案

0

评论者:uosl

错误发生是因为在未指定临时输出目录的情况下,使用了具有绝对路径的 File 作为输出文件传递给 cljs.closure/compile-file。compile-file 仅适用于 output-file 是相对路径字符串或 File 的情况,因此我将它修改为也支持绝对路径的 File。这样,您可以结合使用 cljs.closure/src-file->target-file。

0

评论者:mfikes

注意,通过私人 Slack 消息,Herald 告知我已经签署了 CA。

0
_评论者:mfikes_

如果您使用默认浏览器 REPL,则该补丁对票据描述有效,但在 macOS 上,如果您指定了 Node REPL,您将看到与临时目录路径规范化相关的失败。


运行以下命令:$ clj -Sdeps '{:deps {org.clojure/clojurescript {:local/root "/Users/mfikes/Projects/clojurescript"}}}' -m cljs.main -re node -r
cljs.user=> 在线程 "main" 中发生异常 java.lang.AssertionError:断言失败:输出文件 /private/tmp/cljs-2917/cljs/core.js 不在输出目录 /var/folders/gx/nymj3l7x4zq3gxb97v2zwzb40000gn/T/out5998260788018592691311499618489419
(string/starts-with? (util/path output-file) out-dir)
在 cljs.closure$compile_file.invokeStatic(closure.clj:636)
在 cljs.closure$compile_file.invoke(closure.clj:625)
在 cljs.closure$eval7272$fn__7273.invoke(closure.clj:730)
在 cljs.closure$eval7175$fn__7176$G__7164__7183.invoke(closure.clj:543)
在 cljs.closure$eval7278$fn__7279.invoke(closure.clj:739)
在 cljs.closure$eval7175$fn__7176$G__7164__7183.invoke(closure.clj:543)
在 cljs.closure$compile.invokeStatic(closure.clj:595)
在 cljs.closure$compile.invoke(closure.clj:592)
在 cljs.repl.node$setup$fn__9880.invoke(node.clj:164)
在 cljs.repl.node$setup.invokeStatic(node.clj:131)
在 cljs.repl.node$setup.invoke(node.clj:124)
在 cljs.repl.node.NodeEnv._setup(node.clj:236)
在 cljs.repl$repl_STAR_$fn__8878.invoke(repl.cljc:951)
在 cljs.compiler$with_core_cljs.invokeStatic(compiler.cljc:1416)
在 cljs.compiler$with_core_cljs.invoke(compiler.cljc:1405)
在 cljs.repl$repl_STAR_.invokeStatic(repl.cljc:949)
在 cljs.repl$repl_STAR_.invoke(repl.cljc:861)
在 cljs.cli$repl_opt.invokeStatic(cli.clj:314)
在 cljs.cli$repl_opt.invoke(cli.clj:301)
在 cljs.cli$main.invokeStatic(cli.clj:646)
在 cljs.cli$main.doInvoke(cli.clj:635)
在 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:61)
在 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)


我认为可以通过断言来修复这个问题


(same-or-subdirectory-of? out-dir output-file)


而不是


(string/starts-with? (util/path output-file) out-dir)


关于这个补丁,我还关心另一个问题,{{output-file}} 可能是一个 _相对_ {{File}},在这种情况下


(io/file out-dir output-file)


是一个有效的结构,代码可能应该处理这个分支。在我看来,只有在 {{out-file}} 是 _绝对_(字符串或 {{File}})的情况下,才应该“原样”处理,而不是相对于 {{out-dir}}。换句话说,条件可能不是它满足 {{util/file?}},而是 {{absolute-path?}}。

如果我们考虑这两个变化(使用 {{absolute-path?}} 触发逻辑和 {{same-or-subdirectory-of?}} 进行断言),这可能涵盖了所有情况。(这两个函数需要作为 {{declare}} d 因为它们发生在 {{compile-file}} 之后。)
0

评论者:uosl

再次感谢,Mike。我设法在 Linux 上重现了您的错误,对逻辑和断言都进行了您建议的更改,并确认已修复。我还将 {{if}} 语句真分支返回的 {{output-file}} 包装在 {{io/file}} 调用中,否则如果提供了绝对路径字符串,我担心它将失败 {{(.exists out-file)}} 表达式进一步。

0

评论者:mfikes

最新的补丁LGTM,表现良好,并通过了持续集成。

0

评论者:uosl

在修复CLJS-2753补丁的过程中,我发现对该错误的修复也解决了这个问题。如果不希望支持compile-file中的绝对路径,则可以取消此补丁,并使用CLJS-2753补丁代替。CLJS-2917.patch中关于{{cljs.repl.rhino...}}的提交信息是不正确的;这些文件从opts中删除:output-dir,因此最终传递给{{cljs.closure/compile-file}}一个相对路径。(这并没有为{{cljs.repl/load-file}}做,导致出现这两个问题)

0
...