Package net.sf.saxon.serialize
Class UTF8Writer
- java.lang.Object
-
- java.io.Writer
-
- net.sf.saxon.serialize.UTF8Writer
-
- All Implemented Interfaces:
java.io.Closeable,java.io.Flushable,java.lang.Appendable,java.lang.AutoCloseable
public final class UTF8Writer extends java.io.WriterSpecialized buffering UTF-8 writer. The main reason for custom version is to allow for efficient buffer recycling; the second benefit is that encoder has less overhead for short content encoding (compared to JDK default codecs).- Author:
- Tatu Saloranta
-
-
Field Summary
Fields Modifier and Type Field Description protected java.io.OutputStream_outprotected byte[]_outBufferprotected int_outBufferLastprotected int_outPtr(package private) int_surrogateWhen outputting chars from BMP, surrogate pairs need to be coalesced.(package private) static intSURR1_FIRST(package private) static intSURR1_LAST(package private) static intSURR2_FIRST(package private) static intSURR2_LAST
-
Constructor Summary
Constructors Constructor Description UTF8Writer(java.io.OutputStream out)UTF8Writer(java.io.OutputStream out, int bufferLength)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()voidflush()voidwrite(char[] cbuf)voidwrite(char[] cbuf, int off, int len)voidwrite(int c)voidwrite(java.lang.String str)voidwrite(java.lang.String str, int off, int len)
-
-
-
Field Detail
-
SURR1_FIRST
static final int SURR1_FIRST
- See Also:
- Constant Field Values
-
SURR1_LAST
static final int SURR1_LAST
- See Also:
- Constant Field Values
-
SURR2_FIRST
static final int SURR2_FIRST
- See Also:
- Constant Field Values
-
SURR2_LAST
static final int SURR2_LAST
- See Also:
- Constant Field Values
-
_out
protected java.io.OutputStream _out
-
_outBuffer
protected byte[] _outBuffer
-
_outBufferLast
protected final int _outBufferLast
-
_outPtr
protected int _outPtr
-
_surrogate
int _surrogate
When outputting chars from BMP, surrogate pairs need to be coalesced. To do this, both pairs must be known first; and since it is possible pairs may be split, we need temporary storage for the first half
-
-
Method Detail
-
close
public void close() throws java.io.IOException- Specified by:
closein interfacejava.lang.AutoCloseable- Specified by:
closein interfacejava.io.Closeable- Specified by:
closein classjava.io.Writer- Throws:
java.io.IOException
-
flush
public void flush() throws java.io.IOException- Specified by:
flushin interfacejava.io.Flushable- Specified by:
flushin classjava.io.Writer- Throws:
java.io.IOException
-
write
public void write(char[] cbuf) throws java.io.IOException- Overrides:
writein classjava.io.Writer- Throws:
java.io.IOException
-
write
public void write(char[] cbuf, int off, int len) throws java.io.IOException- Specified by:
writein classjava.io.Writer- Throws:
java.io.IOException
-
write
public void write(int c) throws java.io.IOException- Overrides:
writein classjava.io.Writer- Throws:
java.io.IOException
-
write
public void write(java.lang.String str) throws java.io.IOException- Overrides:
writein classjava.io.Writer- Throws:
java.io.IOException
-
write
public void write(java.lang.String str, int off, int len) throws java.io.IOException- Overrides:
writein classjava.io.Writer- Throws:
java.io.IOException
-
-