Class LineInputStream

  • All Implemented Interfaces:
    Closeable, AutoCloseable

    public class LineInputStream
    extends FilterInputStream
    LineInputStream supports reading CRLF terminated lines that contain only US-ASCII characters from an input stream. Provides functionality that is similar to the deprecated DataInputStream.readLine(). Expected use is to read lines as String objects from an IMAP/SMTP/etc. stream.

    This class also supports UTF-8 data by calling the appropriate constructor. Or, if the System property mail.mime.allowutf8 is set to true, an attempt will be made to interpret the data as UTF-8, falling back to treating it as an 8-bit charset if that fails.

    LineInputStream is implemented as a FilterInputStream, so one can just wrap it around any input stream and read bytes from this filter.

    Author:
    John Mani, Bill Shannon
    • Constructor Detail

      • LineInputStream

        public LineInputStream​(InputStream in)
      • LineInputStream

        public LineInputStream​(InputStream in,
                               boolean allowutf8)
        Parameters:
        in - the InputStream
        allowutf8 - allow UTF-8 characters?
        Since:
        JavaMail 1.6
    • Method Detail

      • readLine

        public String readLine()
                        throws IOException
        Read a line containing only ASCII characters from the input stream. A line is terminated by a CR or NL or CR-NL sequence. A common error is a CR-CR-NL sequence, which will also terminate a line. The line terminator is not returned as part of the returned String. Returns null if no data is available.

        This class is similar to the deprecated DataInputStream.readLine()

        Returns:
        the line
        Throws:
        IOException - for I/O errors