While most functions or macros will format well without special processing,
some functions are more clearly comprehended when processed specially.
There is a part of the options map which maps function names into
a function "type" for formatting. This is the :fn-map
.
Generally, if a function call fits on the current
line, none of these classifications matter. These only come into play
when the function call doesn't fit on the current line.
(Though you can configure a particular function type to always create
multi-line output.)
You can add additional function name -> function type mappings to
the :fn-map
, or you can change the existing :fn-map
mapping to
be one more to your liking.
You can also "alias" one function to another, so that the aliased function will be formatted like the one to which it is aliased.
This simple approach will let you define some function as formatting identically to some other function:
The options map to do this is: {:fn-map {"mydefn" "defn"}}
. This,
for example, will alias "mydefn" to be formatted like "defn". If the
formatting for "defn" is changed by a :style
, then the formatting
for "mydefn" will change as well. The alias lookup is performed when
"mydefn" is encountered for formatting.
If this simple aliasing will work for you, you don't have figure out
anything else about the :fn-map
.
A function type can be:
- a simple keyword, for example:
:arg1
- a vector which starts with a keyword function type and
contains an option map to be used only when formatting this particular
function, for example:
[:arg2-pair {:vector {:wrap? false}}]
If you want to add a function name -> function type (or change an existing mapping), you have two approaches you can use to determine the function type that you would like to use:
-
Find an existing function that formats the way that you want, determine its function type, and use that. You can find the function type of an existing function by entering
(czprint nil :explain)
at the REPL, and looking at the list of functions under the key:fn-map
in the output. -
Look through the list of possible function types, and figure out which one best matches what you want.
You can also change an existing function name -> function type mapping to
have a function type of :none
, if you wish to remove an existing mapping
and, essentially, cause zprint to not recognize a particular function name
as requiring special processing.
For example, if you have a function which takes three arguments, and the first argument is distinguished from the second and third in some way, and you would like it to appear on the line with the function name, thus:
(myfn one
two
three)
Then you would use an options map:
{:fn-map {"myfn" :arg1}}
This options map can appear
anywhere an options map is accepted.
It could be associated with this project,
in a project oriented ./zprintrc
file, or it could be associated
with this person by appearing in their ~/.zprintrc
file. It could
also appear in a command line options map (to test out the concept
to see if it works), or in an options map in an actual call to
zprint at the REPL.
You can add a key-value pair to the :fn-map
where the key
is :default
, and the value will be used for any function which does
not appear in the :fn-map
, or which does appear in the :fn-map
but
whose value is :none
.
You can add a key-value pair to the :fn-map
where the key
is :default-not-none
, and the value will be used for any function which does
not appear in the :fn-map
. Note that if a function does appear in the
function map and has a value of :none
, the value of :default-not-none
will not be used!
There is an entry in the :fn-map
for :quote
which will cause quoted
lists to be formatted assuming that their contents do not contain functions.
In particular, their first elements will not be looked up in the :fn-map
.
If you change the value of the key :quote
in the :fn-map
to be :none
,
then quoted lists will be handled as any other lists, and will not be
processed specially.
The default for quoted lists will format them on a single line if possible, and will format them without a hang if multiple lines are necessary.
Some examples:
; The current default
% (zprint q {:parse-string? true})
'(redis
service
http-client
postgres
cassandra
mongo
jdbc
graphql
service
sql
graalvm
postgres
rules
spec)
; No special processing for quoted lists
% (zprint q {:parse-string? true :fn-map {:quote :none}})
'(redis service
http-client
postgres
cassandra
mongo
jdbc
graphql
service
sql
graalvm
postgres
rules
spec)
; If you want quoted lists wrapped like vectors are wrapped
% (zprint q {:parse-string? true :fn-map {:quote [:wrap {:list {:indent 1} :next-inner {:indent 2}}]}})
'(redis service http-client postgres cassandra mongo jdbc graphql service sql
graalvm postgres rules spec)