请在2024年Clojure状态调查!中分享您的看法。

欢迎!请参阅关于页面,了解更多关于如何使用这个网站的信息。

0
ClojureScript
我正在尝试在CLJS代码中(在这种情况下,[date-fns|https://github.com/date-fns/date-fns),并且在我第一次尝试监视时,它正常工作,但之后的监视都失败了,我在控制台中看到以下错误


base.js:1357 Uncaught Error: Undefined nameToPath for date_fns
    at visitNode (base.js:1357)
    at Object.goog.writeScripts_ (base.js:1369)
    at Object.goog.require (base.js:706)
    at index.html:8


为了重现此问题,我创建了一个构建脚本


(require '[cljs.build.api :as b])

(b/watch "src"
  {:main 'npm.core
   :output-to "out/npm.js"
   :output-dir "out"
   :npm-deps {:date-fns "1.29.0"}})


以及一个最小测试文件


(ns npm.core
  (:require [date-fns :as dfn]))

(def now (js/Date.))
(.write js/document "Today is " (dfn/format now "dddd"))


我还测试了使用本地`package.json`文件,而不是使用`install_deps true` - 我的`package.json`(由CLJS生成)看起来像这样


{
  "dependencies": {
    "@cljs-oss/module-deps": "^1.1.1",
    "date-fns": "^1.29.0"
  }
}


当我运行


npm install
java -cp ../clojurescript/target/cljs.jar:src clojure.main watch.clj


时所做的一切都正常,然而,如果我使用CTRL+C终止并再次运行完全相同的命令,我就会得到上面概述的错误。

但是,只有在(且仅当)我删除`out`目录并第三次运行命令之后,它才会再次正常工作。

如果您需要任何其他详细信息,请告知。

5 答案

0

由koz发表的评论

抱歉,似乎我在标题上弄错了,而且无法编辑。标题应该是"使用原生模块重新运行CLJS源代码监视导致JS错误"

0

由koz发表的评论

附加环境信息

npm -v 5.5.1
node -v v8.4.0

0

评论者:andyparsons

注意到这个问题已被切换为优先级4,但此问题阻止了我们完全使用npm依赖。较低的优先级反映了什么?

0

评论者:mfikes

我无法重现。在按下Ctrl+C并重新运行后,我得到以下结果

$ java -cp cljs.jar:src clojure.main watch.clj Building ... ... 完成. 总耗时 3.674686404 秒。监视路径:/Users/mfikes/Desktop/test-cljs-2440/src

这是使用发货的1.9.908 {{cljs.jar}} 和 Node v9.11.1 及 npm 5.6.0。这是

我还确认了使用1.10.238 JAR无法重现。

我还使用提交 {{ebdaf6c06c1112a67ba5a12498801c6d858e5a0a}} 构建了1.9.968 JAR,并尝试重现但未成功。

0
参考: https://clojure.atlassian.net/browse/CLJS-2440 (由 alex+import 报告)
...