Class GeneratorBase
- All Implemented Interfaces:
Versioned,Closeable,Flushable,AutoCloseable
- Direct Known Subclasses:
JsonGeneratorImpl,ToXmlGenerator
-
Nested Class Summary
Nested classes/interfaces inherited from class com.fasterxml.jackson.core.JsonGenerator
JsonGenerator.Feature -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intstatic final intstatic final intstatic final int -
Method Summary
Modifier and TypeMethodDescriptionvoidHelper method, usually equivalent to:getOutputContext().setCurrentValue(v);voidclose()Method called to close this generator, so that no more content can be written.Helper method, usually equivalent to:getOutputContext().getCurrentValue();Method for disabling specified feature (checkJsonGenerator.Featurefor list of features)Method for enabling specified generator feature: checkJsonGenerator.Featurefor list of available features.abstract voidflush()Method called to flush any buffered content to the underlying target (output stream, writer), and to flush the target itself as well.getCodec()Method for accessing the object used for writing Java object as JSON content (using methodJsonGenerator.writeObject(java.lang.Object)).intBulk access method for getting state of all standard (non-dataformat-specific)JsonGenerator.Features.Note: type was co-variant until Jackson 2.7; reverted back to base type in 2.8 to allow for overriding by subtypes that use custom context type.Accessor for use byjackson-coreitself (tests in particular).booleanisClosed()Method that can be called to determine whether this generator is closed or not.final booleanMethod for checking whether given feature is enabled.overrideStdFeatures(int values, int mask) Bulk set method for (re)setting states of features specified bymask.setCodec(ObjectCodec oc) Method that can be called to set or reset the object to use for writing Java objects as JsonContent (using methodJsonGenerator.writeObject(java.lang.Object)).setFeatureMask(int newMask) Deprecated.Convenience method for enabling pretty-printing using the default pretty printer (DefaultPrettyPrinter).version()Implemented with standard version number detection algorithm, typically using a simple generated class, with information extracted from Maven project file during build.intwriteBinary(Base64Variant b64variant, InputStream data, int dataLength) Method similar toJsonGenerator.writeBinary(Base64Variant,byte[],int,int), but where input is provided through a stream, allowing for incremental writes without holding the whole input in memory.voidMethod similar toJsonGenerator.writeFieldName(String), main difference being that it may perform better as some of processing (such as quoting of certain characters, or encoding into external encoding if supported by generator) can be done just once and reused for later calls.voidwriteObject(Object value) Older alias forJsonGenerator.writePOJO(Object)voidwriteRawValue(char[] text, int offset, int len) voidMethod similar toJsonGenerator.writeRawValue(String), but potentially more efficient as it may be able to use pre-encoded content (similar toJsonGenerator.writeRaw(SerializableString).voidwriteRawValue(String text) Method that will force generator to copy input text verbatim without any modifications, but assuming it must constitute a single legal JSON value (number, string, boolean, null, Array or List).voidwriteRawValue(String text, int offset, int len) voidwriteStartObject(Object forValue) Method for writing starting marker of an Object value to represent the given Java Object value.voidMethod similar toJsonGenerator.writeString(String), but that takesSerializableStringwhich can make this potentially more efficient to call as generator may be able to reuse quoted and/or encoded representation.voidMethod for writing given JSON tree (expressed as a tree where given JsonNode is the root) using this generator.Methods inherited from class com.fasterxml.jackson.core.JsonGenerator
canOmitFields, canUseSchema, canWriteBinaryNatively, canWriteFormattedNumbers, canWriteObjectId, canWriteTypeId, configure, copyCurrentEvent, copyCurrentEventExact, copyCurrentStructure, getCharacterEscapes, getCurrentValue, getFormatFeatures, getHighestEscapedChar, getOutputBuffered, getOutputTarget, getPrettyPrinter, getSchema, getWriteCapabilities, isEnabled, overrideFormatFeatures, setCharacterEscapes, setCurrentValue, setHighestNonEscapedChar, setPrettyPrinter, setRootValueSeparator, setSchema, streamWriteConstraints, writeArray, writeArray, writeArray, writeArray, writeArrayFieldStart, writeBinary, writeBinary, writeBinary, writeBinary, writeBinaryField, writeBoolean, writeBooleanField, writeEmbeddedObject, writeEndArray, writeEndObject, writeFieldId, writeFieldName, writeNull, writeNullField, writeNumber, writeNumber, writeNumber, writeNumber, writeNumber, writeNumber, writeNumber, writeNumber, writeNumber, writeNumberField, writeNumberField, writeNumberField, writeNumberField, writeNumberField, writeNumberField, writeNumberField, writeObjectField, writeObjectFieldStart, writeObjectId, writeObjectRef, writeOmittedField, writePOJO, writePOJOField, writeRaw, writeRaw, writeRaw, writeRaw, writeRaw, writeRawUTF8String, writeStartArray, writeStartArray, writeStartArray, writeStartArray, writeStartObject, writeStartObject, writeString, writeString, writeString, writeStringField, writeTypeId, writeTypePrefix, writeTypeSuffix, writeUTF8String
-
Field Details
-
SURR1_FIRST
public static final int SURR1_FIRST- See Also:
-
SURR1_LAST
public static final int SURR1_LAST- See Also:
-
SURR2_FIRST
public static final int SURR2_FIRST- See Also:
-
SURR2_LAST
public static final int SURR2_LAST- See Also:
-
-
Method Details
-
version
Implemented with standard version number detection algorithm, typically using a simple generated class, with information extracted from Maven project file during build.- Specified by:
versionin interfaceVersioned- Specified by:
versionin classJsonGenerator- Returns:
- Version number of the generator (version of the jar that contains generator implementation class)
-
currentValue
Description copied from class:JsonGeneratorHelper method, usually equivalent to:getOutputContext().getCurrentValue();Note that "current value" is NOT populated (or used) by Streaming parser or generators; it is only used by higher-level data-binding functionality. The reason it is included here is that it can be stored and accessed hierarchically, and gets passed through data-binding.
- Overrides:
currentValuein classJsonGenerator- Returns:
- "Current value" associated with the current context (state) of this generator
-
assignCurrentValue
Description copied from class:JsonGeneratorHelper method, usually equivalent to:getOutputContext().setCurrentValue(v);- Overrides:
assignCurrentValuein classJsonGenerator- Parameters:
v- Current value to assign for the current context of this generator
-
isEnabled
Description copied from class:JsonGeneratorMethod for checking whether given feature is enabled. CheckJsonGenerator.Featurefor list of available features.- Specified by:
isEnabledin classJsonGenerator- Parameters:
f- Feature to check- Returns:
- True if specified feature is enabled; false if not
-
getFeatureMask
public int getFeatureMask()Description copied from class:JsonGeneratorBulk access method for getting state of all standard (non-dataformat-specific)JsonGenerator.Features.- Specified by:
getFeatureMaskin classJsonGenerator- Returns:
- Bit mask that defines current states of all standard
JsonGenerator.Features.
-
enable
Description copied from class:JsonGeneratorMethod for enabling specified generator feature: checkJsonGenerator.Featurefor list of available features.- Specified by:
enablein classJsonGenerator- Parameters:
f- Feature to enable- Returns:
- This generator, to allow call chaining
-
disable
Description copied from class:JsonGeneratorMethod for disabling specified feature (checkJsonGenerator.Featurefor list of features)- Specified by:
disablein classJsonGenerator- Parameters:
f- Feature to disable- Returns:
- This generator, to allow call chaining
-
setFeatureMask
Deprecated.Description copied from class:JsonGeneratorBulk set method for (re)setting states of all standardJsonGenerator.Features- Specified by:
setFeatureMaskin classJsonGenerator- Parameters:
newMask- Bitmask that defines whichJsonGenerator.Features are enabled and which disabled- Returns:
- This generator, to allow call chaining
-
overrideStdFeatures
Description copied from class:JsonGeneratorBulk set method for (re)setting states of features specified bymask. Functionally equivalent toint oldState = getFeatureMask(); int newState = (oldState & ~mask) | (values & mask); setFeatureMask(newState);but preferred as this lets caller more efficiently specify actual changes made.- Overrides:
overrideStdFeaturesin classJsonGenerator- Parameters:
values- Bit mask of set/clear state for features to changemask- Bit mask of features to change- Returns:
- This generator, to allow call chaining
-
useDefaultPrettyPrinter
Description copied from class:JsonGeneratorConvenience method for enabling pretty-printing using the default pretty printer (DefaultPrettyPrinter).- Specified by:
useDefaultPrettyPrinterin classJsonGenerator- Returns:
- This generator, to allow call chaining
-
setCodec
Description copied from class:JsonGeneratorMethod that can be called to set or reset the object to use for writing Java objects as JsonContent (using methodJsonGenerator.writeObject(java.lang.Object)).- Specified by:
setCodecin classJsonGenerator- Parameters:
oc- Codec to assign, if any;nullif none- Returns:
- This generator, to allow call chaining
-
getCodec
Description copied from class:JsonGeneratorMethod for accessing the object used for writing Java object as JSON content (using methodJsonGenerator.writeObject(java.lang.Object)).- Specified by:
getCodecin classJsonGenerator- Returns:
- Codec assigned to this generator, if any;
nullif none
-
getOutputContext
Note: type was co-variant until Jackson 2.7; reverted back to base type in 2.8 to allow for overriding by subtypes that use custom context type.- Specified by:
getOutputContextin classJsonGenerator- Returns:
- Stream output context (
JsonStreamContext) associated with this generator
-
ioContext
Accessor for use byjackson-coreitself (tests in particular).- Returns:
IOContextin use by this generator- Since:
- 2.17
-
writeStartObject
Description copied from class:JsonGeneratorMethod for writing starting marker of an Object value to represent the given Java Object value. Argument is offered as metadata, but more importantly it should be assigned as the "current value" for the Object content that gets constructed and initialized.Object values can be written in any context where values are allowed: meaning everywhere except for when a field name is expected.
- Overrides:
writeStartObjectin classJsonGenerator- Parameters:
forValue- "Current value" to assign for the Object context being created- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
writeFieldName
Description copied from class:JsonGeneratorMethod similar toJsonGenerator.writeFieldName(String), main difference being that it may perform better as some of processing (such as quoting of certain characters, or encoding into external encoding if supported by generator) can be done just once and reused for later calls.Default implementation simple uses unprocessed name container in serialized String; implementations are strongly encouraged to make use of more efficient methods argument object has.
- Specified by:
writeFieldNamein classJsonGenerator- Parameters:
name- Field name to write- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
writeString
Description copied from class:JsonGeneratorMethod similar toJsonGenerator.writeString(String), but that takesSerializableStringwhich can make this potentially more efficient to call as generator may be able to reuse quoted and/or encoded representation.Default implementation just calls
JsonGenerator.writeString(String); sub-classes should override it with more efficient implementation if possible.- Specified by:
writeStringin classJsonGenerator- Parameters:
text- Pre-encoded String value to write- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
writeRawValue
Description copied from class:JsonGeneratorMethod that will force generator to copy input text verbatim without any modifications, but assuming it must constitute a single legal JSON value (number, string, boolean, null, Array or List). Assuming this, proper separators are added if and as needed (comma or colon), and generator state updated to reflect this.- Specified by:
writeRawValuein classJsonGenerator- Parameters:
text- Textual contents to included in output- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
writeRawValue
- Specified by:
writeRawValuein classJsonGenerator- Throws:
IOException
-
writeRawValue
- Specified by:
writeRawValuein classJsonGenerator- Throws:
IOException
-
writeRawValue
Description copied from class:JsonGeneratorMethod similar toJsonGenerator.writeRawValue(String), but potentially more efficient as it may be able to use pre-encoded content (similar toJsonGenerator.writeRaw(SerializableString).- Overrides:
writeRawValuein classJsonGenerator- Parameters:
text- Pre-encoded textual contents to included in output- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
writeBinary
public int writeBinary(Base64Variant b64variant, InputStream data, int dataLength) throws IOException Description copied from class:JsonGeneratorMethod similar toJsonGenerator.writeBinary(Base64Variant,byte[],int,int), but where input is provided through a stream, allowing for incremental writes without holding the whole input in memory.- Specified by:
writeBinaryin classJsonGenerator- Parameters:
b64variant- Base64 variant to usedata- InputStream to use for reading binary data to write. Will not be closed after successful write operationdataLength- (optional) number of bytes that will be available; or -1 to be indicate it is not known. If a positive length is given,dataMUST provide at least that many bytes: if not, an exception will be thrown. Note that implementations need not support cases where length is not known in advance; this depends on underlying data format: JSON output does NOT require length, other formats may.- Returns:
- Number of bytes read from
dataand written as binary payload - Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
writeObject
Description copied from class:JsonGeneratorOlder alias forJsonGenerator.writePOJO(Object)- Specified by:
writeObjectin classJsonGenerator- Parameters:
value- Java value (usually POJO) to write- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
writeTree
Description copied from class:JsonGeneratorMethod for writing given JSON tree (expressed as a tree where given JsonNode is the root) using this generator. This will generally just callJsonGenerator.writeObject(java.lang.Object)with given node, but is added for convenience and to make code more explicit in cases where it deals specifically with trees.- Specified by:
writeTreein classJsonGenerator- Parameters:
rootNode-TreeNodeto write- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
flush
Description copied from class:JsonGeneratorMethod called to flush any buffered content to the underlying target (output stream, writer), and to flush the target itself as well.- Specified by:
flushin interfaceFlushable- Specified by:
flushin classJsonGenerator- Throws:
IOException- if there is either an underlying I/O problem or encoding issue at format layer
-
close
Description copied from class:JsonGeneratorMethod called to close this generator, so that no more content can be written.Whether the underlying target (stream, writer) gets closed depends on whether this generator either manages the target (i.e. is the only one with access to the target -- case if caller passes a reference to the resource such as File, but not stream); or has feature
JsonGenerator.Feature.AUTO_CLOSE_TARGETenabled. If either of above is true, the target is also closed. Otherwise (not managing, feature not enabled), target is not closed.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein classJsonGenerator- Throws:
IOException- if there is either an underlying I/O problem
-
isClosed
public boolean isClosed()Description copied from class:JsonGeneratorMethod that can be called to determine whether this generator is closed or not. If it is closed, no more output can be done.- Specified by:
isClosedin classJsonGenerator- Returns:
Trueif this generator instance has been closed
-