pprint
のドキュメントは一種のレンガの壁です。地図を印刷すると、次のように1行で表示されます{:a "b", :b "c", :d "e"}
。代わりに、オプションでコンマを使用して、次のように印刷したいと思います。
{:a "b"
:b "c"
:d "e"}
pprintでそれをどのように行うでしょうか?
*print-right-margin*
バインディングを設定できます。
Clojure=> (binding [*print-right-margin* 7] (pprint {:a 1 :b 2 :c 3}))
{:a 1,
:b 2,
:c 3}
探しているものとは異なりますが、それで十分かもしれません。
ところで、これを理解するための最良の方法、または少なくとも私が取ったアプローチは、を使用することです
Clojure=> (use 'clojure.contrib.repl-utils)
Clojure=> (source pprint)
(defn pprint
"Pretty print object to the optional output writer. If the writer is not provided,
print the object to the currently bound value of *out*."
([object] (pprint object *out*))
([object writer]
(with-pretty-writer writer
(binding [*print-pretty* true]
(write-out object))
(if (not (= 0 (.getColumn #^PrettyWriter *out*)))
(.write *out* (int \newline))))))
nil
うーん、うーん..何with-pretty-writer
をするの*out*
?
Clojure=> (source clojure.contrib.pprint/with-pretty-writer)
(defmacro #^{:private true} with-pretty-writer [base-writer & body]
`(let [new-writer# (not (pretty-writer? ~base-writer))]
(binding [*out* (if new-writer#
(make-pretty-writer ~base-writer *print-right-margin* *print-miser-width*)
~base-writer)]
~@body
(if new-writer# (.flush *out*)))))
nil
さて、*print-right-margin*
有望に聞こえます...
Clojure=> (source clojure.contrib.pprint/make-pretty-writer)
(defn- make-pretty-writer
"Wrap base-writer in a PrettyWriter with the specified right-margin and miser-width"
[base-writer right-margin miser-width]
(PrettyWriter. base-writer right-margin miser-width))
nil
また、これはかなり有益です:
Clojure=> (doc *print-right-margin*)
-------------------------
clojure.contrib.pprint/*print-right-margin*
nil
Pretty printing will try to avoid anything going beyond this column.
Set it to nil to have pprint let the line be arbitrarily long. This will ignore all
non-mandatory newlines.
nil
とにかく—そしておそらくあなたはすでにこれさえ知っていました—本当に動作する方法をカスタマイズしたいのなら、それをにバインドすることによってそれを渡すことpprint
ができます。PrettyWriterクラスはかなり大きくて威圧的であるため、これが元々の「レンガの壁」のコメントの意味であったかどうかはわかりません。proxy
clojure.contrib.pprint.PrettyWriter
*out*
私はあなたがそれをすることができないと思います、あなたはおそらくあなた自身を書く必要があるでしょう、次のようなもの。
(defn pprint-map [m]
(print "{")
(doall (for [[k v] m] (println k v)))
(print "}"))