与 cl-annot (cl-syntax, jonathan) 和 pythonic-string-reader 的可读冲突

Readtable conflicts with cl-annot (cl-syntax, jonathan) and pythonic-string-reader

我喜欢 pythonic-string-reader 启用 python-esque 三引号:

(defun hello ()
  """docstring"""
  :hello)

使用它:

(ql:quickload "pythonic-string-reader")
(pythonic-string-reader:enable-pythonic-string-syntax)

它也适用于

(named-readtables:in-readtable pythonic-string-reader:pythonic-string-syntax)

但是后来我想加载 Jonathan 库,但我遇到了冲突:

(ql:quickload "jonathan")
=>
Reader macro conflict while trying to merge the macro character
#\" from #<NAMED-READTABLE CL-ANNOT::SYNTAX {1001CC18C3}> into
#<NAMED-READTABLE :CURRENT {1009474833}>.
   [Condition of type EDITOR-HINTS.NAMED-READTABLES:READER-MACRO-CONFLICT]


Backtrace:
  0: (EDITOR-HINTS.NAMED-READTABLES:MERGE-READTABLES-INTO #<NAMED-READTABLE :CURRENT {1009474833}> #<NAMED-READTABLE CL-ANNOT::SYNTAX {1001CC18C3}>)
      Locals:
        CHAR = #\"
        DISP? = NIL
        FROM = #<NAMED-READTABLE CL-ANNOT::SYNTAX {1001CC18C3}>
        NAMED-READTABLES = (#<NAMED-READTABLE CL-ANNOT::SYNTAX {1001CC18C3}>)
        READER-FN = #<FUNCTION SB-IMPL::READ-STRING>
        RESULT-READTABLE = #<NAMED-READTABLE :CURRENT {1009474833}>
        RESULT-TABLE = #<NAMED-READTABLE :CURRENT {1009474833}>
        TABLE = NIL
  1: (CL-SYNTAX::%USE-SYNTAX (:CL-ANNOT))
      Locals:
        NAMES = (:CL-ANNOT)

这是不对的,因为我不是要使用另一个可读表。 Jonathan 仅在内部使用 cl-annot。

它是谁的错误(cl-syntax?)以及如何解决它?


首先加载 Jonathan,然后启用 pythonic 字符串语法。然而,这不是一个可接受的解决方法(我想定义一个用户包,并启用语法,用户可以在其中加载任何其他库)。


查看cl-syntax行错误它想合并可读表(merge-readtables-into *readtable* syntax) ),同时它似乎正确使用copy-readtable:

(defun %use-syntax (names)
  (declare (type (or syntax-designator
                     (proper-list syntax-designator))
                 names))
  (unless (listp names)
    (setq names (list names)))
  (setq *readtable* (copy-readtable))
  (loop for name in names
        for syntax = (find-syntax name)
        for options = (get-options name)
        if (assoc :fuze (if (consp (car options)) options (cdr options))) do
          (handler-bind ((named-readtables:reader-macro-conflict
                            (lambda (_) (declare (ignore _))
                              (invoke-restart 'continue))))
             (merge-readtables-into *readtable* syntax) )
        else do
          (merge-readtables-into *readtable* syntax) )
  (when (find-package :swank)
    (named-readtables::%frob-swank-readtable-alist *package* *readtable*)))

有什么想法吗?谢谢。

正在评估

(cl-syntax::get-options :CL-ANNOT)

给予

((:MERGE :STANDARD)
 (:MACRO-CHAR #\@ #'CL-ANNOT.SYNTAX:ANNOTATION-SYNTAX-READER))

看起来语法应该合并 :standard 可读表,而不是当前的。我怀疑 (copy-readtable nil) 在您描述的函数中会是更好的选择。