com.fasterxml.jackson.core.io.SegmentedStringWriter Maven / Gradle / Ivy
package com.fasterxml.jackson.core.io;
import java.io.*;
import com.fasterxml.jackson.core.util.BufferRecycler;
import com.fasterxml.jackson.core.util.TextBuffer;
/**
* Efficient alternative to {@link StringWriter}, based on using segmented
* internal buffer. Initial input buffer is also recyclable.
*
* This class is most useful when serializing JSON content as a String:
* if so, instance of this class can be given as the writer to
* JsonGenerator
.
*/
public final class SegmentedStringWriter
extends Writer
implements BufferRecycler.Gettable
{
final private TextBuffer _buffer;
public SegmentedStringWriter(BufferRecycler br) {
super();
_buffer = new TextBuffer(br);
}
/*
/**********************************************************************
/* BufferRecycler.Gettable implementation
/**********************************************************************
*/
@Override
public BufferRecycler bufferRecycler() {
return _buffer.bufferRecycler();
}
/*
/**********************************************************************
/* java.io.Writer implementation
/**********************************************************************
*/
@Override
public Writer append(char c) throws IOException {
write(c);
return this;
}
@Override
public Writer append(CharSequence csq) throws IOException {
String str = csq.toString();
_buffer.append(str, 0, str.length());
return this;
}
@Override
public Writer append(CharSequence csq, int start, int end) throws IOException {
String str = csq.subSequence(start, end).toString();
_buffer.append(str, 0, str.length());
return this;
}
@Override
public void close() { } // NOP
@Override
public void flush() { } // NOP
@Override
public void write(char[] cbuf) throws IOException {
_buffer.append(cbuf, 0, cbuf.length);
}
@Override
public void write(char[] cbuf, int off, int len) throws IOException {
_buffer.append(cbuf, off, len);
}
@Override
public void write(int c) throws IOException {
_buffer.append((char) c);
}
@Override
public void write(String str) throws IOException {
_buffer.append(str, 0, str.length());
}
@Override
public void write(String str, int off, int len) throws IOException {
_buffer.append(str, off, len);
}
/*
/**********************************************************************
/* Extended API
/**********************************************************************
*/
/**
* Main access method that will construct a String that contains
* all the contents, release all internal buffers we may have,
* and return result String.
* Note that the method is not idempotent -- if called second time,
* will just return an empty String.
*
* @return String that contains all aggregated content
* @throws IOException if there are general I/O or parse issues, including if the text is too large,
* see {@link com.fasterxml.jackson.core.StreamReadConstraints.Builder#maxStringLength(int)}
*/
public String getAndClear() throws IOException {
String result = _buffer.contentsAsString();
_buffer.releaseBuffers();
return result;
}
}