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

欢迎!请查看关于页面以获得更多关于如何使用本网站的信息。

+1 投票
ClojureScript
编辑

你好!一如既往地,我们对 cljs 非常感激——它是我们努力的巨大乘数,并且随着我们每天全天候地使用它,我们依然非常喜欢它。

在升级 clojurescript 版本后,我们开始收到一个奇怪的与 read-string 相关的错误:“没有为 tag uuid 提供读取函数”。

cljs repl

ClojureScript 1.10.238
app:cljs.user=> (cljs.tools.reader.edn/read-string "#uuid \"eed86fd1-4110-44d8-8f41-27473029cc6a\"")
#error {:message "No reader function for tag uuid.", :data {:type :reader-exception, :ex-kind :reader-error}}
   new (jar:file:/home/harold/.m2/repository/org/clojure/clojurescript/1.10.238/clojurescript-1.10.238.jar!/cljs/core.cljs:11123:11)
   Function.cljs$core$IFn$_invoke$arity$3 (jar:file:/home/harold/.m2/repository/org/clojure/clojurescript/1.10.238/clojurescript-1.10.238.jar!/cljs/core.cljs:11155:5)
   Function.cljs$core$IFn$_invoke$arity$2 (jar:file:/home/harold/.m2/repository/org/clojure/clojurescript/1.10.238/clojurescript-1.10.238.jar!/cljs/core.cljs:11153:16)
   cljs.core/ex-info (jar:file:/home/harold/.m2/repository/org/clojure/clojurescript/1.10.238/clojurescript-1.10.238.jar!/cljs/core.cljs:11150:1)
   Function.cljs$core$IFn$_invoke$arity$variadic (jar:file:/home/harold/.m2/repository/org/clojure/tools.reader/1.3.3/tools.reader-1.3.3.jar!/cljs/tools/reader/impl/errors.cljs:37:13)
   cljs.tools.reader.impl.errors/throw-ex (jar:file:/home/harold/.m2/repository/org/clojure/tools.reader/1.3.3/tools.reader-1.3.3.jar!/cljs/tools/reader/impl/errors.cljs:26:1)
   Function.cljs$core$IFn$_invoke$arity$variadic (jar:file:/home/harold/.m2/repository/org/clojure/tools.reader/1.3.3/tools.reader-1.3.3.jar!/cljs/tools/reader/impl/errors.cljs:43:4)
   cljs.tools.reader.impl.errors/reader-error (jar:file:/home/harold/.m2/repository/org/clojure/tools.reader/1.3.3/tools.reader-1.3.3.jar!/cljs/tools/reader/impl/errors.cljs:39:1)
   cljs.tools.reader.impl.errors/throw-unknown-reader-tag (jar:file:/home/harold/.m2/repository/org/clojure/tools.reader/1.3.3/tools.reader-1.3.3.jar!/cljs/tools/reader/impl/errors.cljs:221:4)
   cljs$tools$reader$edn$read_tagged (jar:file:/home/harold/.m2/repository/org/clojure/tools.reader/1.3.3/tools.reader-1.3.3.jar!/cljs/tools/reader/edn.cljs:372:10)

app:cljs.user=> (cljs.tools.reader.edn/read-string {:readers {'uuid uuid}} "#uuid \"eed86fd1-4110-44d8-8f41-27473029cc6a\"")
#uuid "eed86fd1-4110-44d8-8f41-27473029cc6a"

clj repl

> (clojure.edn/read-string "#uuid \"eed86fd1-4110-44d8-8f41-27473029cc6a\"")
#uuid "eed86fd1-4110-44d8-8f41-27473029cc6a"

以前,在 cljs 和 clj 中阅读 edn 的行为更为相似。我在查看 tools.reader 中的测试时发现了一种解决方法,即将映射作为第一个参数传递。

这是预期的吗?

感谢您的时间和考虑。

2 个答案

0 投票
 
最佳答案

解决方案是使用 clojure.edn 而不是 cljs.tools.reader.edn

$ clojure -Srepro -Sdeps '{:deps {org.clojure/clojurescript {:mvn/version "1.10.844"}}}' -M -m cljs.main
ClojureScript 1.10.844
cljs.user=> (require 'clojure.edn)
nil
cljs.user=> (clojure.edn/read-string "#uuid \"eed86fd1-4110-44d8-8f41-27473029cc6a\"")
#uuid "eed86fd1-4110-44d8-8f41-27473029cc6a"

我学到了很多。谢谢!

更多信息请在此 gist 中查看:https://gist.github.com/harold/10dd1ba54332992b4eeab72aa88ef2bd

+1 投票

这里的情况有点难以理解。看起来你使用了两个不同的ClojureScript旧版本?注意REPL报告的版本以及堆栈跟踪报告的版本。

嗨!是的,这很奇怪。我从头开始,现在已将正确的cljs输出生成到问题中。很抱歉造成混淆。行为是一样的。我相信我们得到了从reagent 1.0来的这个版本的cljs。是否更高版本的cljs会表现得不同?
这个问题在您的项目外部似乎很容易复现。您能确认在最新版本`1.10.844`中此问题仍然存在吗。

编辑
这是个好主意,看起来最新版本的cls行为也是一样的:[点击查看](https://gist.github.com/harold/10dd1ba54332992b4eeab72aa88ef2bd)
...