- All Implemented Interfaces:
Serializable,PrettyPrinter,Instantiatable<DefaultPrettyPrinter>
PrettyPrinter implementation that uses 2-space
indentation with platform-default linefeeds.
Usually this class is not instantiated directly, but instead
instantiated by JsonFactory or databind level mapper.
If you override this class, take note of Instantiatable,
as subclasses will still create an instance of DefaultPrettyPrinter.
This class is designed for the JSON data format. It works on other formats
with same logical model (such as binary CBOR and Smile formats),
but may not work as-is for other data formats, most notably XML.
It may be necessary to use format-specific PrettyPrinter
implementation specific to that format.
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classThis is a very simple indenter that only adds a single space for indentation.static interfaceInterface that defines objects that can produce indentation used to separate object entries and array values.static classDummy implementation that adds no indentation whatsoever -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final StringSeparator between Array elements, including possible before/after spaces.protected final StringString to use in empty Array to separate start and end markers.protected DefaultPrettyPrinter.IndenterBy default, let's use only spaces to separate array values.protected intNumber of open levels of nesting.protected final StringString to use in empty Object to separate start and end markers.protected final StringSeparator between Object property entries, including possible before/after spaces.protected DefaultPrettyPrinter.IndenterBy default, let's use linefeed-adding indenter for separate object entries.protected final StringSeparator between Object property names and values, including possible before/after spaces.protected final SerializableStringString printed between root-level values, if any.protected final SeparatorsFields inherited from interface tools.jackson.core.PrettyPrinter
DEFAULT_ROOT_VALUE_SEPARATOR, DEFAULT_SEPARATORS -
Constructor Summary
ConstructorsConstructorDescriptionDefault constructor for "vanilla" instance with default settings.Copy constructor.DefaultPrettyPrinter(DefaultPrettyPrinter base, Separators separators) Copy constructor with overrideDefaultPrettyPrinter(Separators separators) Default constructor for "vanilla" instance with default settings, except forSeparatorsoverrides. -
Method Summary
Modifier and TypeMethodDescriptionprotected DefaultPrettyPrinter_withSpaces(boolean state) voidMethod called after array start marker has been output, and right before the first value is to be output.voidMethod called after object start marker has been output, and right before the Name of the first property is to be output.Method called to ensure that we have a non-blueprint object to use; it is either this object (if stateless), or a newly created object with separate state.voidvoidwithSeparators(Separators separators) Method for configuring separators for this pretty-printer to usevoidMethod called after an array value has been completely output, and before another value is to be output.voidwriteEndArray(JsonGenerator g, int nrOfValues) Method called after an Array value has been completely output (minus closing bracket).voidwriteEndObject(JsonGenerator g, int nrOfEntries) Method called after an Object value has been completely output (minus closing curly bracket).voidMethod called after an object entry (field:value) has been completely output, and before another value is to be output.voidMethod called after the object property name has been output, but before the value is output.voidMethod called after a root-level value has been completely output, and before another value is to be output.voidMethod called when an Array value is to be output, before any member/child values are output.voidMethod called when an Object value is to be output, before any fields are output.
-
Field Details
-
_arrayIndenter
By default, let's use only spaces to separate array values. -
_objectIndenter
By default, let's use linefeed-adding indenter for separate object entries. We'll further configure indenter to use system-specific linefeeds, and 2 spaces per level (as opposed to, say, single tabs) -
_rootValueSeparator
String printed between root-level values, if any. -
_nesting
protected transient int _nestingNumber of open levels of nesting. Used to determine amount of indentation to use. -
_separators
-
_objectNameValueSeparator
Separator between Object property names and values, including possible before/after spaces. -
_objectEntrySeparator
Separator between Object property entries, including possible before/after spaces. -
_objectEmptySeparator
String to use in empty Object to separate start and end markers. Default is single space, resulting in output of{ }. -
_arrayElementSeparator
Separator between Array elements, including possible before/after spaces. -
_arrayEmptySeparator
String to use in empty Array to separate start and end markers. Default is single space, resulting in output of[ ].
-
-
Constructor Details
-
DefaultPrettyPrinter
public DefaultPrettyPrinter()Default constructor for "vanilla" instance with default settings. -
DefaultPrettyPrinter
Default constructor for "vanilla" instance with default settings, except forSeparatorsoverrides.- Parameters:
separators- Custom separator definition over defaults.
-
DefaultPrettyPrinter
Copy constructor.- Parameters:
base- DefaultPrettyPrinter being copied
-
DefaultPrettyPrinter
Copy constructor with override- Parameters:
base- DefaultPrettyPrinter being copiedseparators- Separators to use instead of onesbasehad
-
-
Method Details
-
indentArraysWith
-
indentObjectsWith
-
withArrayIndenter
-
withObjectIndenter
-
_withSpaces
-
withSeparators
Method for configuring separators for this pretty-printer to use- Parameters:
separators- Separator definitions to use- Returns:
- This pretty-printer instance (for call chaining)
-
createInstance
Description copied from interface:InstantiatableMethod called to ensure that we have a non-blueprint object to use; it is either this object (if stateless), or a newly created object with separate state.- Specified by:
createInstancein interfaceInstantiatable<DefaultPrettyPrinter>- Returns:
- Actual instance to use
-
writeRootValueSeparator
Description copied from interface:PrettyPrinterMethod called after a root-level value has been completely output, and before another value is to be output.Default handling (without pretty-printing) will output a space, to allow values to be parsed correctly. Pretty-printer is to output some other suitable and nice-looking separator (tab(s), space(s), linefeed(s) or any combination thereof).
- Specified by:
writeRootValueSeparatorin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
writeStartObject
Description copied from interface:PrettyPrinterMethod called when an Object value is to be output, before any fields are output.Default handling (without pretty-printing) will output the opening curly bracket. Pretty-printer is to output a curly bracket as well, but can surround that with other (white-space) decoration.
- Specified by:
writeStartObjectin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
beforeObjectEntries
Description copied from interface:PrettyPrinterMethod called after object start marker has been output, and right before the Name of the first property is to be output. It is not called for objects without properties.Default handling does not output anything, but pretty-printer is free to add any white space decoration.
- Specified by:
beforeObjectEntriesin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
writeObjectNameValueSeparator
Method called after the object property name has been output, but before the value is output.Default handling (without pretty-printing) will output a single colon to separate the two. Pretty-printer is to output a colon as well, but can surround that with other (white-space) decoration.
- Specified by:
writeObjectNameValueSeparatorin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
writeObjectEntrySeparator
Method called after an object entry (field:value) has been completely output, and before another value is to be output.Default handling (without pretty-printing) will output a single comma to separate the two. Pretty-printer is to output a comma as well, but can surround that with other (white-space) decoration.
- Specified by:
writeObjectEntrySeparatorin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
writeEndObject
Description copied from interface:PrettyPrinterMethod called after an Object value has been completely output (minus closing curly bracket).Default handling (without pretty-printing) will output the closing curly bracket. Pretty-printer is to output a curly bracket as well, but can surround that with other (white-space) decoration.
- Specified by:
writeEndObjectin interfacePrettyPrinter- Parameters:
g- Generator used for outputnrOfEntries- Number of direct members of the Object that have been output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
writeStartArray
Description copied from interface:PrettyPrinterMethod called when an Array value is to be output, before any member/child values are output.Default handling (without pretty-printing) will output the opening bracket. Pretty-printer is to output a bracket as well, but can surround that with other (white-space) decoration.
- Specified by:
writeStartArrayin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
beforeArrayValues
Description copied from interface:PrettyPrinterMethod called after array start marker has been output, and right before the first value is to be output. It is not called for arrays with no values.Default handling does not output anything, but pretty-printer is free to add any white space decoration.
- Specified by:
beforeArrayValuesin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
writeArrayValueSeparator
Method called after an array value has been completely output, and before another value is to be output.Default handling (without pretty-printing) will output a single comma to separate the two. Pretty-printer is to output a comma as well, but can surround that with other (white-space) decoration.
- Specified by:
writeArrayValueSeparatorin interfacePrettyPrinter- Parameters:
g- Generator used for output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-
writeEndArray
Description copied from interface:PrettyPrinterMethod called after an Array value has been completely output (minus closing bracket).Default handling (without pretty-printing) will output the closing bracket. Pretty-printer is to output a bracket as well, but can surround that with other (white-space) decoration.
- Specified by:
writeEndArrayin interfacePrettyPrinter- Parameters:
g- Generator used for outputnrOfValues- Number of direct members of the array that have been output- Throws:
JacksonIOException- if there is an underlying I/O problemStreamWriteException- for problems in encoding token streamJacksonException
-