class org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream extends java.lang.Object implements org.apache.kafkaesqueesque.common.record.LogInputStream
{
private final java.nio.ByteBuffer buffer;
private final int maxMessageSize;
void <init>(java.nio.ByteBuffer, int)
{
int v;
org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream;
v := @parameter: java.nio.ByteBuffer;
v := @parameter: int;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer> = v;
v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: int maxMessageSize> = v;
return;
}
public org.apache.kafkaesqueesque.common.record.MutableRecordBatch nextBatch()
{
java.lang.Integer v;
java.nio.ByteBuffer v, v, v, v, v, v, v;
byte v;
int v, v, v, v, v, v, v, v;
org.apache.kafkaesqueesque.common.record.DefaultRecordBatch v;
org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream v;
org.apache.kafkaesqueesque.common.record.AbstractLegacyRecordBatch$ByteBufferLegacyRecordBatch v;
v := @this: org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream;
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
v = virtualinvoke v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.lang.Integer nextBatchSize()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v >= v goto label;
label:
return null;
label:
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v + 16;
v = virtualinvoke v.<java.nio.ByteBuffer: byte get(int)>(v);
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer slice()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer limit(int)>(v);
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = v + v;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.Buffer position(int)>(v);
if v <= 1 goto label;
v = new org.apache.kafkaesqueesque.common.record.DefaultRecordBatch;
specialinvoke v.<org.apache.kafkaesqueesque.common.record.DefaultRecordBatch: void <init>(java.nio.ByteBuffer)>(v);
return v;
label:
v = new org.apache.kafkaesqueesque.common.record.AbstractLegacyRecordBatch$ByteBufferLegacyRecordBatch;
specialinvoke v.<org.apache.kafkaesqueesque.common.record.AbstractLegacyRecordBatch$ByteBufferLegacyRecordBatch: void <init>(java.nio.ByteBuffer)>(v);
return v;
}
java.lang.Integer nextBatchSize() throws org.apache.kafkaesqueesque.common.errors.CorruptRecordException
{
java.lang.Object[] v, v;
java.lang.Integer v, v, v, v, v;
java.nio.ByteBuffer v, v, v, v, v;
org.apache.kafkaesqueesque.common.errors.CorruptRecordException v, v, v;
byte v;
int v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v;
org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream v;
v := @this: org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream;
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v >= 12 goto label;
return null;
label:
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v + 8;
v = virtualinvoke v.<java.nio.ByteBuffer: int getInt(int)>(v);
if v >= 14 goto label;
v = new org.apache.kafkaesqueesque.common.errors.CorruptRecordException;
v = newarray (java.lang.Object)[2];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(14);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Record size %d is less than the minimum record overhead (%d)", v);
specialinvoke v.<org.apache.kafkaesqueesque.common.errors.CorruptRecordException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: int maxMessageSize>;
if v <= v goto label;
v = new org.apache.kafkaesqueesque.common.errors.CorruptRecordException;
v = newarray (java.lang.Object)[2];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: int maxMessageSize>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Record size %d exceeds the largest allowable message size (%d).", v);
specialinvoke v.<org.apache.kafkaesqueesque.common.errors.CorruptRecordException: void <init>(java.lang.String)>(v);
throw v;
label:
if v >= 17 goto label;
return null;
label:
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = v.<org.apache.kafkaesqueesque.common.record.ByteBufferLogInputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v + 16;
v = virtualinvoke v.<java.nio.ByteBuffer: byte get(int)>(v);
if v < 0 goto label;
if v <= 2 goto label;
label:
v = new org.apache.kafkaesqueesque.common.errors.CorruptRecordException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (byte)>(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[])>("Invalid magic found in record: \u0001");
specialinvoke v.<org.apache.kafkaesqueesque.common.errors.CorruptRecordException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v + 12;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
return v;
}
}