public class org.apache.kafkaesque.common.utils.ByteBufferOutputStream extends java.io.OutputStream
{
private static final float REALLOCATION_FACTOR;
private final int initialCapacity;
private final int initialPosition;
private java.nio.ByteBuffer buffer;
public void <init>(java.nio.ByteBuffer)
{
int v, v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: java.nio.ByteBuffer;
specialinvoke v.<java.io.OutputStream: void <init>()>();
v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer> = v;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: int initialPosition> = v;
v = virtualinvoke v.<java.nio.ByteBuffer: int capacity()>();
v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: int initialCapacity> = v;
return;
}
public void <init>(int)
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: int;
specialinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: void <init>(int,boolean)>(v, 0);
return;
}
public void <init>(int, boolean)
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
boolean v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: int;
v := @parameter: boolean;
if v == 0 goto label;
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocateDirect(int)>(v);
goto label;
label:
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(v);
label:
specialinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: void <init>(java.nio.ByteBuffer)>(v);
return;
}
public void write(int)
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: int;
virtualinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: void ensureRemaining(int)>(1);
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(byte)>(v);
return;
}
public void write(byte[], int, int)
{
byte[] v;
int v, v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: byte[];
v := @parameter: int;
v := @parameter: int;
virtualinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: void ensureRemaining(int)>(v);
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(byte[],int,int)>(v, v, v);
return;
}
public void write(java.nio.ByteBuffer)
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v, v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: java.nio.ByteBuffer;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
virtualinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: void ensureRemaining(int)>(v);
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(java.nio.ByteBuffer)>(v);
return;
}
public java.nio.ByteBuffer buffer()
{
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
return v;
}
public int position()
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
return v;
}
public int remaining()
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
return v;
}
public int limit()
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int limit()>();
return v;
}
public void position(int)
{
int v, v, v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v, v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: int;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v - v;
virtualinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: void ensureRemaining(int)>(v);
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer position(int)>(v);
return;
}
public int initialCapacity()
{
int v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: int initialCapacity>;
return v;
}
public void ensureRemaining(int)
{
int v, v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
java.nio.ByteBuffer v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: int;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v <= v goto label;
specialinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: void expandBuffer(int)>(v);
label:
return;
}
private void expandBuffer(int)
{
java.nio.ByteBuffer v, v, v, v, v, v, v;
int v, v, v, v, v, v, v;
float v;
org.apache.kafkaesque.common.utils.ByteBufferOutputStream v;
v := @this: org.apache.kafkaesque.common.utils.ByteBufferOutputStream;
v := @parameter: int;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int limit()>();
v = v * 1.1F;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int position()>();
v = v + v;
v = staticinvoke <java.lang.Math: int max(int,int)>(v, v);
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocate(int)>(v);
v = virtualinvoke v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: int limit()>();
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer flip()>();
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(java.nio.ByteBuffer)>(v);
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer limit(int)>(v);
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer>;
v = v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: int initialPosition>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer position(int)>(v);
v.<org.apache.kafkaesque.common.utils.ByteBufferOutputStream: java.nio.ByteBuffer buffer> = v;
return;
}
}