Class UTF8Writer

  • All Implemented Interfaces:
    CompletelyCloseable, java.io.Closeable, java.io.Flushable, java.lang.Appendable, java.lang.AutoCloseable

    public final class UTF8Writer
    extends java.io.Writer
    implements CompletelyCloseable
    Specialized buffering UTF-8 writer used by XmlWriter. 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).
    • Constructor Summary

      Constructors 
      Constructor Description
      UTF8Writer​(WriterConfig cfg, java.io.OutputStream out, boolean autoclose)  
    • Method Summary

      All Methods Instance Methods Concrete Methods 
      Modifier and Type Method Description
      private void _close​(boolean forceClosing)  
      private int _convertSurrogate​(int secondPart)
      Method called to calculate UTF codepoint, from a surrogate pair.
      void close()  
      void closeCompletely()  
      void flush()  
      private void throwIllegal​(int code)  
      void write​(char[] cbuf)  
      void write​(char[] cbuf, int off, int len)  
      void write​(int c)  
      void write​(java.lang.String str)  
      void write​(java.lang.String str, int off, int len)  
      • Methods inherited from class java.io.Writer

        append, append, append, nullWriter
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Field Detail

      • mAutoCloseOutput

        final boolean mAutoCloseOutput
      • mOut

        final java.io.OutputStream mOut
      • mOutBuffer

        byte[] mOutBuffer
      • mOutBufferLast

        final int mOutBufferLast
      • mOutPtr

        int mOutPtr
      • mSurrogate

        int mSurrogate
        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
    • Constructor Detail

      • UTF8Writer

        public UTF8Writer​(WriterConfig cfg,
                          java.io.OutputStream out,
                          boolean autoclose)
    • Method Detail

      • close

        public void close()
                   throws java.io.IOException
        Specified by:
        close in interface java.lang.AutoCloseable
        Specified by:
        close in interface java.io.Closeable
        Specified by:
        close in class java.io.Writer
        Throws:
        java.io.IOException
      • flush

        public void flush()
                   throws java.io.IOException
        Specified by:
        flush in interface java.io.Flushable
        Specified by:
        flush in class java.io.Writer
        Throws:
        java.io.IOException
      • write

        public void write​(char[] cbuf)
                   throws java.io.IOException
        Overrides:
        write in class java.io.Writer
        Throws:
        java.io.IOException
      • write

        public void write​(char[] cbuf,
                          int off,
                          int len)
                   throws java.io.IOException
        Specified by:
        write in class java.io.Writer
        Throws:
        java.io.IOException
      • write

        public void write​(int c)
                   throws java.io.IOException
        Overrides:
        write in class java.io.Writer
        Throws:
        java.io.IOException
      • write

        public void write​(java.lang.String str)
                   throws java.io.IOException
        Overrides:
        write in class java.io.Writer
        Throws:
        java.io.IOException
      • write

        public void write​(java.lang.String str,
                          int off,
                          int len)
                   throws java.io.IOException
        Overrides:
        write in class java.io.Writer
        Throws:
        java.io.IOException
      • _close

        private final void _close​(boolean forceClosing)
                           throws java.io.IOException
        Throws:
        java.io.IOException
      • _convertSurrogate

        private final int _convertSurrogate​(int secondPart)
                                     throws java.io.IOException
        Method called to calculate UTF codepoint, from a surrogate pair.
        Throws:
        java.io.IOException
      • throwIllegal

        private void throwIllegal​(int code)
                           throws java.io.IOException
        Throws:
        java.io.IOException