uk.org.ogsadai.common
Class Base64Reader
java.lang.Object
  |
  +--java.io.Reader
        |
        +--uk.org.ogsadai.common.Base64Reader
- public class Base64Reader- extends java.io.Reader
A java.io.Reader that wraps a
 java.io.InputStream and Base64 encodes its contents.
- Author:
- The OGSA-DAI Project Team
 
| Fields inherited from class java.io.Reader | 
| lock | 
 
| Constructor Summary | 
| Base64Reader(java.io.InputStream input)Constructs a
 Base64Readerthat wraps the specifiedInputStream. | 
 
| Method Summary | 
|  void | close()
 | 
|  int | read(char[] cbuf,
     int off,
     int len)Read Base64 encoded characters into a portion of an
 array.
 | 
|  java.lang.String | readAll()Reads and Base64 encodes the entire contents of the
 InputStream. | 
| private  void | readAndEncode()Reads from the wrapped
 InputStreaminto the
 buffer, then encodes to Base64. | 
 
| Methods inherited from class java.io.Reader | 
| mark, markSupported, read, read, ready, reset, skip | 
 
| Methods inherited from class java.lang.Object | 
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
 
COPYRIGHT_NOTICE
private static final java.lang.String COPYRIGHT_NOTICE
- See Also:
- Constant Field Values
LOG
private static final DAILogger LOG
BUFFER_SIZE
private static final int BUFFER_SIZE
- See Also:
- Constant Field Values
mInputStream
private final java.io.InputStream mInputStream
mByteBuffer
private byte[] mByteBuffer
mBase64Data
private char[] mBase64Data
mEncoded
private boolean mEncoded
mRemaining
private int mRemaining
mClosed
private boolean mClosed
Base64Reader
public Base64Reader(java.io.InputStream input)
             throws java.lang.IllegalArgumentException,
                    OutOfMemoryException
- Constructs a Base64Readerthat wraps the specifiedInputStream. Data read from the input stream will be
 Base64 encoded.
 Default buffer size is 4096 * 3 bytes.
 
 
- Parameters:
- input- The- InputStreamto wrap and encode.
- Throws:
- java.lang.IllegalArgumentException- if- inputis- null.
- OutOfMemoryException- if there is no memory available.
read
public int read(char[] cbuf,
                int off,
                int len)
         throws java.io.IOException,
                java.lang.IllegalArgumentException
- Read Base64 encoded characters into a portion of an
 array. This method will block until some input is available, an
 I/O error occurs, or the end of the stream is reached.
 
- 
- Specified by:
- readin class- java.io.Reader
 
- 
- Parameters:
- cbuf- Destination buffer. Must be able to hold- len.
- off- Offset at which to start storing characters. Must be >= 0
     and < size of- cbuf.
- len- Maximum number of characters to read. Must be >= 1 and <
      size of- cbuf-- off.
- Returns:
- The number of characters read, or -1 if the end of the
 stream has been reached.
- Throws:
- java.io.IOException- if the reader has already been closed or
 there is a problem when reading from the- InputStream.
- java.lang.IllegalArgumentException- if the- cbufis- nullor if- offor- lencontain unsuitable values.
- See Also:
- Reader.read(char[], int, int)
 
readAndEncode
private void readAndEncode()
                    throws java.io.IOException
- Reads from the wrapped InputStreaminto the
 buffer, then encodes to Base64. Called whenever there is no
 more encoded data to be read.
 
- 
- Throws:
- java.io.IOException- if a problem is encountered in reading the
 data from the- InputStream.
 
close
public void close()
- 
- Specified by:
- closein class- java.io.Reader
 
- 
 
readAll
public java.lang.String readAll()
                         throws java.io.IOException,
                                OutOfMemoryException
- Reads and Base64 encodes the entire contents of the
 InputStream.
 Note that this method may carry a significant memory overhead
 because all the input data will be encoded and stored in memory
 in its entirety.
 
- 
- Returns:
- a Stringcontaining the Base64 encoded data.
- Throws:
- java.io.IOException- if the reader has already been closed or
 there is a problem when reading from the- InputStream.
- OutOfMemoryException- if there is no memory available.