Package org.mozilla.universalchardet
Class UnicodeBOMInputStream
- java.lang.Object
-
- java.io.InputStream
-
- org.mozilla.universalchardet.UnicodeBOMInputStream
-
- All Implemented Interfaces:
java.io.Closeable,java.lang.AutoCloseable
public class UnicodeBOMInputStream extends java.io.InputStreamTheUnicodeBOMInputStreamclass wraps anyInputStreamand detects the presence of any Unicode BOM (Byte Order Mark) at its beginning, as defined by RFC 3629 - UTF-8, a transformation format of ISO 10646The Unicode FAQ defines 5 types of BOMs:
00 00 FE FF = UTF-32, big-endian
FF FE 00 00 = UTF-32, little-endian
FE FF = UTF-16, big-endian
FF FE = UTF-16, little-endian
EF BB BF = UTF-8
Use the
getBOM()method to know whether a BOM has been detected or not.Use the
skipBOM()method to remove the detected BOM from the wrappedInputStreamobject.- Version:
- 1.0
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classUnicodeBOMInputStream.BOMType safe enumeration class that describes the different types of Unicode BOMs.
-
Field Summary
Fields Modifier and Type Field Description private UnicodeBOMInputStream.BOMbomprivate java.io.PushbackInputStreaminprivate booleanskipped
-
Constructor Summary
Constructors Constructor Description UnicodeBOMInputStream(java.io.InputStream inputStream)Constructs a newUnicodeBOMInputStreamthat wraps the specifiedInputStream.UnicodeBOMInputStream(java.io.InputStream inputStream, boolean skipIfFound)Constructs a newUnicodeBOMInputStreamthat wraps the specifiedInputStream.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intavailable()voidclose()UnicodeBOMInputStream.BOMgetBOM()Returns theBOMthat was detected in the wrappedInputStreamobject.voidmark(int readlimit)booleanmarkSupported()intread()intread(byte[] b)intread(byte[] b, int off, int len)voidreset()longskip(long n)UnicodeBOMInputStreamskipBOM()Skips theBOMthat was found in the wrappedInputStreamobject.
-
-
-
Field Detail
-
in
private final java.io.PushbackInputStream in
-
bom
private final UnicodeBOMInputStream.BOM bom
-
skipped
private boolean skipped
-
-
Constructor Detail
-
UnicodeBOMInputStream
public UnicodeBOMInputStream(java.io.InputStream inputStream) throws java.io.IOExceptionConstructs a newUnicodeBOMInputStreamthat wraps the specifiedInputStream. By default skip BOM bytes- Parameters:
inputStream- anInputStream.- Throws:
java.lang.NullPointerException- wheninputStreamisnull.java.io.IOException- on reading from the specifiedInputStreamwhen trying to detect the Unicode BOM.
-
UnicodeBOMInputStream
public UnicodeBOMInputStream(java.io.InputStream inputStream, boolean skipIfFound) throws java.io.IOExceptionConstructs a newUnicodeBOMInputStreamthat wraps the specifiedInputStream.- Parameters:
inputStream- anInputStream.skipIfFound- to automatically skip BOM bytes if found- Throws:
java.lang.NullPointerException- wheninputStreamisnull.java.io.IOException- on reading from the specifiedInputStreamwhen trying to detect the Unicode BOM.
-
-
Method Detail
-
getBOM
public final UnicodeBOMInputStream.BOM getBOM()
Returns theBOMthat was detected in the wrappedInputStreamobject.- Returns:
- a
BOMvalue.
-
skipBOM
public final UnicodeBOMInputStream skipBOM() throws java.io.IOException
Skips theBOMthat was found in the wrappedInputStreamobject.- Returns:
- this
UnicodeBOMInputStream. - Throws:
java.io.IOException- when trying to skip the BOM from the wrappedInputStreamobject.
-
read
public int read() throws java.io.IOException- Specified by:
readin classjava.io.InputStream- Throws:
java.io.IOException
-
read
public int read(byte[] b) throws java.io.IOException- Overrides:
readin classjava.io.InputStream- Throws:
java.io.IOException
-
read
public int read(byte[] b, int off, int len) throws java.io.IOException- Overrides:
readin classjava.io.InputStream- Throws:
java.io.IOException
-
skip
public long skip(long n) throws java.io.IOException- Overrides:
skipin classjava.io.InputStream- Throws:
java.io.IOException
-
available
public int available() throws java.io.IOException- Overrides:
availablein classjava.io.InputStream- Throws:
java.io.IOException
-
close
public void close() throws java.io.IOException- Specified by:
closein interfacejava.lang.AutoCloseable- Specified by:
closein interfacejava.io.Closeable- Overrides:
closein classjava.io.InputStream- Throws:
java.io.IOException
-
mark
public void mark(int readlimit)
- Overrides:
markin classjava.io.InputStream
-
reset
public void reset() throws java.io.IOException- Overrides:
resetin classjava.io.InputStream- Throws:
java.io.IOException
-
markSupported
public boolean markSupported()
- Overrides:
markSupportedin classjava.io.InputStream
-
-