Class BoundedInputStream

All Implemented Interfaces:
Closeable, AutoCloseable

public class BoundedInputStream extends ProxyInputStream
Reads bytes up to a maximum count and stops once reached.

To build an instance, see BoundedInputStream.AbstractBuilder.

By default, a BoundedInputStream is unbound; so make sure to call BoundedInputStream.AbstractBuilder.setMaxCount(long).

You can find out how many bytes this stream has seen so far by calling getCount(). This value reflects bytes read and skipped.

Using a ServletInputStream

A ServletInputStream can block if you try to read content that isn't there because it doesn't know whether the content hasn't arrived yet or whether the content has finished. Initialize an BoundedInputStream with the Content-Length sent in the ServletInputStream's header, this stop it from blocking, providing it's been sent with a correct content length in the first place.

Using NIO


 BoundedInputStream s = BoundedInputStream.builder()
   .setPath(Paths.get("MyFile.xml"))
   .setMaxCount(1024)
   .setPropagateClose(false)
   .get();
 
 

Using IO


 BoundedInputStream s = BoundedInputStream.builder()
   .setFile(new File("MyFile.xml"))
   .setMaxCount(1024)
   .setPropagateClose(false)
   .get();
 
 

Counting Bytes

You can set the running count when building, which is most useful when starting from another stream:


 InputStream in = ...;
 BoundedInputStream s = BoundedInputStream.builder()
   .setInputStream(in)
   .setCount(12)
   .setMaxCount(1024)
   .setPropagateClose(false)
   .get();
 
 
Since:
2.0
See Also:
  • Constructor Details

    • BoundedInputStream

      @Deprecated public BoundedInputStream(InputStream in)
      Deprecated.
      Constructs a new BoundedInputStream that wraps the given input stream and is unlimited.
      Parameters:
      in - The wrapped input stream.
    • BoundedInputStream

      @Deprecated public BoundedInputStream(InputStream inputStream, long maxCount)
      Deprecated.
      Constructs a new BoundedInputStream that wraps the given input stream and limits it to a certain size.
      Parameters:
      inputStream - The wrapped input stream.
      maxCount - The maximum number of bytes to return.
  • Method Details

    • builder

      public static BoundedInputStream.Builder builder()
      Constructs a new BoundedInputStream.AbstractBuilder.
      Returns:
      a new BoundedInputStream.AbstractBuilder.
      Since:
      2.16.0
    • available

      public int available() throws IOException
      Invokes the delegate's available() method.
      Overrides:
      available in class ProxyInputStream
      Returns:
      the number of available bytes
      Throws:
      IOException - if an I/O error occurs.
    • close

      public void close() throws IOException
      Invokes the delegate's InputStream.close() method if isPropagateClose() is true.
      Specified by:
      close in interface AutoCloseable
      Specified by:
      close in interface Closeable
      Overrides:
      close in class ProxyInputStream
      Throws:
      IOException - if an I/O error occurs.
    • getCount

      public long getCount()
      Gets the count of bytes read.
      Returns:
      The count of bytes read.
      Since:
      2.12.0
    • getMaxCount

      public long getMaxCount()
      Gets the max count of bytes to read.
      Returns:
      The max count of bytes to read.
      Since:
      2.16.0
    • getMaxLength

      @Deprecated public long getMaxLength()
      Deprecated.
      Gets the max count of bytes to read.
      Returns:
      The max count of bytes to read.
      Since:
      2.12.0
    • getRemaining

      public long getRemaining()
      Gets how many bytes remain to read.
      Returns:
      bytes how many bytes remain to read.
      Since:
      2.16.0
    • isPropagateClose

      public boolean isPropagateClose()
      Tests whether the close() method should propagate to the underling InputStream.
      Returns:
      true if calling close() propagates to the close() method of the underlying stream or false if it does not.
    • mark

      public void mark(int readLimit)
      Invokes the delegate's InputStream.mark(int) method.
      Overrides:
      mark in class ProxyInputStream
      Parameters:
      readLimit - read ahead limit
    • markSupported

      public boolean markSupported()
      Invokes the delegate's InputStream.markSupported() method.
      Overrides:
      markSupported in class ProxyInputStream
      Returns:
      true if mark is supported, otherwise false
    • read

      public int read() throws IOException
      Invokes the delegate's InputStream.read() method if the current position is less than the limit.
      Overrides:
      read in class ProxyInputStream
      Returns:
      the byte read or -1 if the end of stream or the limit has been reached.
      Throws:
      IOException - if an I/O error occurs.
    • read

      public int read(byte[] b) throws IOException
      Invokes the delegate's InputStream.read(byte[]) method.
      Overrides:
      read in class ProxyInputStream
      Parameters:
      b - the buffer to read the bytes into
      Returns:
      the number of bytes read or -1 if the end of stream or the limit has been reached.
      Throws:
      IOException - if an I/O error occurs.
    • read

      public int read(byte[] b, int off, int len) throws IOException
      Invokes the delegate's InputStream.read(byte[], int, int) method.
      Overrides:
      read in class ProxyInputStream
      Parameters:
      b - the buffer to read the bytes into
      off - The start offset
      len - The number of bytes to read
      Returns:
      the number of bytes read or -1 if the end of stream or the limit has been reached.
      Throws:
      IOException - if an I/O error occurs.
    • reset

      public void reset() throws IOException
      Invokes the delegate's InputStream.reset() method.
      Overrides:
      reset in class ProxyInputStream
      Throws:
      IOException - if an I/O error occurs.
    • setPropagateClose

      @Deprecated public void setPropagateClose(boolean propagateClose)
      Deprecated.
      Use BoundedInputStream.AbstractBuilder.setPropagateClose(boolean).
      Sets whether the close() method should propagate to the underling InputStream.
      Parameters:
      propagateClose - true if calling close() propagates to the close() method of the underlying stream or false if it does not.
    • skip

      public long skip(long n) throws IOException
      Invokes the delegate's InputStream.skip(long) method.
      Overrides:
      skip in class ProxyInputStream
      Parameters:
      n - the number of bytes to skip
      Returns:
      the actual number of bytes skipped
      Throws:
      IOException - if an I/O error occurs.
    • toString

      public String toString()
      Invokes the delegate's Object.toString() method.
      Overrides:
      toString in class Object
      Returns:
      the delegate's Object.toString()