final class org.apache.axiom.mime.DebugInputStream extends java.io.InputStream
{
private final java.io.InputStream parent;
private final org.apache.commons.logging.Log log;
private long read;
private int chunks;
private boolean logged;
void <init>(java.io.InputStream, org.apache.commons.logging.Log)
{
org.apache.axiom.mime.DebugInputStream v;
org.apache.commons.logging.Log v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v := @parameter: java.io.InputStream;
v := @parameter: org.apache.commons.logging.Log;
specialinvoke v.<java.io.InputStream: void <init>()>();
v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent> = v;
v.<org.apache.axiom.mime.DebugInputStream: org.apache.commons.logging.Log log> = v;
return;
}
private void log(java.io.IOException)
{
org.apache.axiom.mime.DebugInputStream v;
int v;
java.io.IOException v;
long v;
org.apache.commons.logging.Log v;
java.lang.String v;
boolean v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v := @parameter: java.io.IOException;
v = v.<org.apache.axiom.mime.DebugInputStream: boolean logged>;
if v != 0 goto label;
v = v.<org.apache.axiom.mime.DebugInputStream: org.apache.commons.logging.Log log>;
v = v.<org.apache.axiom.mime.DebugInputStream: long read>;
v = v.<org.apache.axiom.mime.DebugInputStream: int chunks>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("IOException occurred after reading \u bytes in \u chunks");
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object,java.lang.Throwable)>(v, v);
v.<org.apache.axiom.mime.DebugInputStream: boolean logged> = 1;
label:
return;
}
private void logEOF()
{
org.apache.axiom.mime.DebugInputStream v;
int v;
long v;
org.apache.commons.logging.Log v;
java.lang.String v;
boolean v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v = v.<org.apache.axiom.mime.DebugInputStream: boolean logged>;
if v != 0 goto label;
v = v.<org.apache.axiom.mime.DebugInputStream: org.apache.commons.logging.Log log>;
v = v.<org.apache.axiom.mime.DebugInputStream: long read>;
v = v.<org.apache.axiom.mime.DebugInputStream: int chunks>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("EOF reached after reading \u bytes in \u chunks");
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>(v);
v.<org.apache.axiom.mime.DebugInputStream: boolean logged> = 1;
label:
return;
}
public int available() throws java.io.IOException
{
org.apache.axiom.mime.DebugInputStream v;
int v;
java.io.IOException v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
v = virtualinvoke v.<java.io.InputStream: int available()>();
label:
return v;
label:
v := @caughtexception;
specialinvoke v.<org.apache.axiom.mime.DebugInputStream: void log(java.io.IOException)>(v);
throw v;
catch java.io.IOException from label to label with label;
}
public boolean markSupported()
{
org.apache.axiom.mime.DebugInputStream v;
boolean v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
v = virtualinvoke v.<java.io.InputStream: boolean markSupported()>();
return v;
}
public void mark(int)
{
int v;
org.apache.axiom.mime.DebugInputStream v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v := @parameter: int;
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
virtualinvoke v.<java.io.InputStream: void mark(int)>(v);
return;
}
public void reset() throws java.io.IOException
{
org.apache.axiom.mime.DebugInputStream v;
java.io.IOException v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
virtualinvoke v.<java.io.InputStream: void reset()>();
label:
goto label;
label:
v := @caughtexception;
specialinvoke v.<org.apache.axiom.mime.DebugInputStream: void log(java.io.IOException)>(v);
throw v;
label:
return;
catch java.io.IOException from label to label with label;
}
public int read() throws java.io.IOException
{
org.apache.axiom.mime.DebugInputStream v;
java.io.IOException v;
long v, v;
int v, v, v, v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
v = virtualinvoke v.<java.io.InputStream: int read()>();
label:
goto label;
label:
v := @caughtexception;
specialinvoke v.<org.apache.axiom.mime.DebugInputStream: void log(java.io.IOException)>(v);
throw v;
label:
v = (int) -1;
if v != v goto label;
specialinvoke v.<org.apache.axiom.mime.DebugInputStream: void logEOF()>();
goto label;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: long read>;
v = v + 1L;
v.<org.apache.axiom.mime.DebugInputStream: long read> = v;
v = v.<org.apache.axiom.mime.DebugInputStream: int chunks>;
v = v + 1;
v.<org.apache.axiom.mime.DebugInputStream: int chunks> = v;
label:
return v;
catch java.io.IOException from label to label with label;
}
public int read(byte[], int, int) throws java.io.IOException
{
byte[] v;
org.apache.axiom.mime.DebugInputStream v;
java.io.IOException v;
long v, v;
int v, v, v, v, v, v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: int;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
v = virtualinvoke v.<java.io.InputStream: int read(byte[],int,int)>(v, v, v);
label:
goto label;
label:
v := @caughtexception;
specialinvoke v.<org.apache.axiom.mime.DebugInputStream: void log(java.io.IOException)>(v);
throw v;
label:
v = (int) -1;
if v != v goto label;
specialinvoke v.<org.apache.axiom.mime.DebugInputStream: void logEOF()>();
goto label;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: long read>;
v = v + v;
v.<org.apache.axiom.mime.DebugInputStream: long read> = v;
v = v.<org.apache.axiom.mime.DebugInputStream: int chunks>;
v = v + 1;
v.<org.apache.axiom.mime.DebugInputStream: int chunks> = v;
label:
return v;
catch java.io.IOException from label to label with label;
}
public long skip(long) throws java.io.IOException
{
org.apache.axiom.mime.DebugInputStream v;
java.io.IOException v;
long v, v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v := @parameter: long;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
v = virtualinvoke v.<java.io.InputStream: long skip(long)>(v);
label:
return v;
label:
v := @caughtexception;
specialinvoke v.<org.apache.axiom.mime.DebugInputStream: void log(java.io.IOException)>(v);
throw v;
catch java.io.IOException from label to label with label;
}
public void close() throws java.io.IOException
{
org.apache.axiom.mime.DebugInputStream v;
int v;
long v;
org.apache.commons.logging.Log v;
java.lang.String v;
boolean v;
java.io.InputStream v;
v := @this: org.apache.axiom.mime.DebugInputStream;
v = v.<org.apache.axiom.mime.DebugInputStream: boolean logged>;
if v != 0 goto label;
v = v.<org.apache.axiom.mime.DebugInputStream: org.apache.commons.logging.Log log>;
v = v.<org.apache.axiom.mime.DebugInputStream: long read>;
v = v.<org.apache.axiom.mime.DebugInputStream: int chunks>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Closing stream after reading \u bytes in \u chunks");
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>(v);
v.<org.apache.axiom.mime.DebugInputStream: boolean logged> = 1;
label:
v = v.<org.apache.axiom.mime.DebugInputStream: java.io.InputStream parent>;
virtualinvoke v.<java.io.InputStream: void close()>();
return;
}
}