Skip to end of metadata
Go to start of metadata

Problems

  1. It's very easy to accidentally print invalid EDN
    1. eg when doing host interop
    2. Workaround: (assert (= (clojure.edn/read-string (pr-str value)) value))
  2. There is no standard in-memory representation for tagged literals
    1. This is a problem for tools that want to analyze code
    2. Workaround: (defrecord TaggedLiteral [tag value]), *default-data-reader-fn*
      1. Fails when tools want to collaborate: differing representations
  3. extending print-method is a bad model
    1. Exposes mutable printer
    2. Requires each tagged-literal provider to implement the same printing logic
    3. Allows printing of unreadable forms

Potential Solution

  1. (defrecord TaggedLiteral [tag value])
    1. Has a print-method which does the #tagged/literal "thing"
  2. (defprotocol ILiteral (-literal [this]))
    1. Converts an object into a valid EDN structure
  3. Add pr, prn, pr-str, and prn-str to clojure.edn
    1. Implements closed set of print methods for each EDN type
    2. Calls -literal on every object recursively
    3. Throws if any object isn't one of the EDN types
  • Protocols are problematic for types with potentially differing representations and for non-owned types.
    • Reading tagged literals is configured via two dynamic vars: 1) a map of symbols to readers and 2) a fallback function.
    • Writing tagged literals could similarly be configured by a map of types to writers and a fallback function.
    • That would allow for custom types to have multiple tagged literal representations depending on need.
Labels: