Class TextBuilder
java.lang.Object
com.fasterxml.aalto.util.TextBuilder
Class conceptually similar to
StringBuilder, but
that allows for bit more efficient building, using segmented internal
buffers, and direct access to these buffers.-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intstatic final int -
Method Summary
Modifier and TypeMethodDescriptionvoidappend(char c) voidappend(char[] c, int start, int len) voidvoidappendSurrogate(int surr) char[]intcontentsToArray(int srcStart, char[] dst, int dstStart, int len) static TextBuilderintdecodeElements(org.codehaus.stax2.typed.TypedArrayDecoder tad, boolean reset) Method called by the stream reader to decode space-separated tokens that are part of the current text event (contents of which are stored within this buffer), using given decoder.booleanequalsString(String str) Note: it is assumed that this method is not used often enough to be a bottleneck, or for long segments.char[]voidThis is a specialized "accessor" method, which is basically to fire SAX characters() events in an optimal way, based on which internal buffers are being usedvoidvoidchar[]intchar[]booleanintMethod that will stream contents of this buffer into specified Writer.voidrecycle(boolean force) Method called to indicate that the underlying buffers should now be recycled if they haven't yet been recycled.voidresetForBinaryDecode(org.codehaus.stax2.typed.Base64Variant v, org.codehaus.stax2.ri.typed.CharArrayBase64Decoder dec, boolean firstChunk) Method called to initialize given base64 decoder with data contained in this text buffer (for the current event).voidresetWithChar(char c) Method called to initialize the buffer with just a single charchar[]Method called to clear out any content text buffer may have, and initializes and returns the first segment to add characters to.voidresetWithIndentation(int indCharCount, char indChar) voidresetWithSurrogate(int c) voidsetCurrentLength(int len) intsize()toString()Note: calling this method may not be as efficient as callingcontentsAsString(), since it is guaranteed that resulting String is NOT cached (to ensure we see no stale data)
-
Field Details
-
MAX_INDENT_SPACES
public static final int MAX_INDENT_SPACES- See Also:
-
MAX_INDENT_TABS
public static final int MAX_INDENT_TABS- See Also:
-
-
Method Details
-
createRecyclableBuffer
-
recycle
public void recycle(boolean force) Method called to indicate that the underlying buffers should now be recycled if they haven't yet been recycled. Although caller can still use this text buffer, it is not advisable to call this method if that is likely, since next time a buffer is needed, buffers need to reallocated. Note: calling this method automatically also clears contents of the buffer. -
resetWithEmpty
public char[] resetWithEmpty()Method called to clear out any content text buffer may have, and initializes and returns the first segment to add characters to. -
resetWithIndentation
public void resetWithIndentation(int indCharCount, char indChar) -
resetWithChar
public void resetWithChar(char c) Method called to initialize the buffer with just a single char -
resetWithSurrogate
public void resetWithSurrogate(int c) -
getBufferWithoutReset
public char[] getBufferWithoutReset() -
size
public int size()- Returns:
- Number of characters currently stored by this collector
-
getTextBuffer
public char[] getTextBuffer() -
contentsAsString
-
contentsAsArray
public char[] contentsAsArray() -
contentsToArray
public int contentsToArray(int srcStart, char[] dst, int dstStart, int len) -
rawContentsTo
Method that will stream contents of this buffer into specified Writer.- Throws:
IOException
-
isAllWhitespace
public boolean isAllWhitespace() -
equalsString
Note: it is assumed that this method is not used often enough to be a bottleneck, or for long segments. Based on this, it is optimized for common simple cases where there is only one single character segment to use; fallback for other cases is to create such segment. -
fireSaxCharacterEvents
This is a specialized "accessor" method, which is basically to fire SAX characters() events in an optimal way, based on which internal buffers are being used- Throws:
SAXException
-
fireSaxSpaceEvents
- Throws:
SAXException
-
fireSaxCommentEvent
- Throws:
SAXException
-
append
public void append(char c) -
appendSurrogate
public void appendSurrogate(int surr) -
append
public void append(char[] c, int start, int len) -
append
-
getCurrentLength
public int getCurrentLength() -
setCurrentLength
public void setCurrentLength(int len) -
finishCurrentSegment
public char[] finishCurrentSegment() -
decodeElements
public int decodeElements(org.codehaus.stax2.typed.TypedArrayDecoder tad, boolean reset) throws org.codehaus.stax2.typed.TypedXMLStreamException Method called by the stream reader to decode space-separated tokens that are part of the current text event (contents of which are stored within this buffer), using given decoder.- Throws:
org.codehaus.stax2.typed.TypedXMLStreamException
-
resetForBinaryDecode
public void resetForBinaryDecode(org.codehaus.stax2.typed.Base64Variant v, org.codehaus.stax2.ri.typed.CharArrayBase64Decoder dec, boolean firstChunk) Method called to initialize given base64 decoder with data contained in this text buffer (for the current event). -
toString
Note: calling this method may not be as efficient as callingcontentsAsString(), since it is guaranteed that resulting String is NOT cached (to ensure we see no stale data)
-