mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-08 22:12:50 +00:00
Treat IllegalStateExceptions thrown by some implementations as EOFExceptions
This commit is contained in:
parent
cf4306cff2
commit
34ad8c0fc0
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
package org.servalproject.json;
|
package org.servalproject.json;
|
||||||
|
|
||||||
|
import java.io.EOFException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
@ -31,6 +32,7 @@ public class JSONTokeniser {
|
|||||||
|
|
||||||
final InputStream underlyingStream;
|
final InputStream underlyingStream;
|
||||||
final PushbackReader reader;
|
final PushbackReader reader;
|
||||||
|
private boolean closed = false;
|
||||||
Object pushedToken;
|
Object pushedToken;
|
||||||
|
|
||||||
private static final boolean DUMP_JSON_TO_STDERR = false;
|
private static final boolean DUMP_JSON_TO_STDERR = false;
|
||||||
@ -104,18 +106,36 @@ public class JSONTokeniser {
|
|||||||
|
|
||||||
private int _read() throws IOException
|
private int _read() throws IOException
|
||||||
{
|
{
|
||||||
int n = this.reader.read();
|
try {
|
||||||
if (DUMP_JSON_TO_STDERR && n != -1)
|
int n = this.reader.read();
|
||||||
System.err.print((char)n);
|
if (DUMP_JSON_TO_STDERR && n != -1)
|
||||||
return n;
|
System.err.print((char) n);
|
||||||
|
return n;
|
||||||
|
}catch (IllegalStateException e){
|
||||||
|
if (closed) {
|
||||||
|
EOFException eof = new EOFException();
|
||||||
|
eof.initCause(e);
|
||||||
|
throw eof;
|
||||||
|
}
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private int _read(char[] buf, int offset, int length) throws IOException
|
private int _read(char[] buf, int offset, int length) throws IOException
|
||||||
{
|
{
|
||||||
int n = this.reader.read(buf, offset, length);
|
try {
|
||||||
if (DUMP_JSON_TO_STDERR && n != -1)
|
int n = this.reader.read(buf, offset, length);
|
||||||
System.err.print(new String(buf, offset, n));
|
if (DUMP_JSON_TO_STDERR && n != -1)
|
||||||
return n;
|
System.err.print(new String(buf, offset, n));
|
||||||
|
return n;
|
||||||
|
}catch (IllegalStateException e){
|
||||||
|
if (closed) {
|
||||||
|
EOFException eof = new EOFException();
|
||||||
|
eof.initCause(e);
|
||||||
|
throw eof;
|
||||||
|
}
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void unexpected(Object tok) throws UnexpectedTokenException
|
public static void unexpected(Object tok) throws UnexpectedTokenException
|
||||||
@ -493,8 +513,9 @@ public class JSONTokeniser {
|
|||||||
|
|
||||||
public void close() throws IOException
|
public void close() throws IOException
|
||||||
{
|
{
|
||||||
this.underlyingStream.close();
|
closed = true;
|
||||||
this.reader.close();
|
this.reader.close();
|
||||||
|
this.underlyingStream.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user