public class org.apache.activemq.leveldb.RecordLog$LogAppender extends org.apache.activemq.leveldb.RecordLog$LogReader
{
private long append_offset;
private final org.apache.activemq.leveldb.RecordLog$LogInfo info;
private final java.util.concurrent.atomic.AtomicLong flushed_offset;
private final org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer;
public long append_offset()
{
long v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v = v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset>;
return v;
}
public void append_offset_$eq(long)
{
long v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v := @parameter: long;
v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset> = v;
return;
}
public org.apache.activemq.leveldb.RecordLog$LogInfo info()
{
org.apache.activemq.leveldb.RecordLog$LogInfo v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v = v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.apache.activemq.leveldb.RecordLog$LogInfo info>;
return v;
}
public java.io.RandomAccessFile open()
{
java.io.RandomAccessFile v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
java.io.File v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v = new java.io.RandomAccessFile;
v = specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogReader: java.io.File file()>();
specialinvoke v.<java.io.RandomAccessFile: void <init>(java.io.File,java.lang.String)>(v, "rw");
return v;
}
public void on_close()
{
org.apache.activemq.leveldb.RecordLog$LogAppender v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: void force()>();
return;
}
public java.util.concurrent.atomic.AtomicLong flushed_offset()
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v = v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.util.concurrent.atomic.AtomicLong flushed_offset>;
return v;
}
public long append_position()
{
org.apache.activemq.leveldb.RecordLog$LogAppender v;
long v, v, v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v = specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogReader: long position()>();
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset()>();
v = v + v;
return v;
}
public org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer()
{
org.apache.activemq.leveldb.RecordLog$LogAppender v;
org.fusesource.hawtbuf.DataByteArrayOutputStream v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v = v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer>;
return v;
}
public void force()
{
org.apache.activemq.leveldb.RecordLog$LogAppender$$anonfun$force$1 v;
org.apache.activemq.leveldb.util.TimeMetric v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
org.apache.activemq.leveldb.RecordLog v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: void flush()>();
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.apache.activemq.leveldb.RecordLog org$apache$activemq$leveldb$RecordLog$LogAppender$$$outer()>();
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog: org.apache.activemq.leveldb.util.TimeMetric max_log_flush_latency()>();
v = new org.apache.activemq.leveldb.RecordLog$LogAppender$$anonfun$force$1;
specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender$$anonfun$force$1: void <init>(org.apache.activemq.leveldb.RecordLog$LogAppender)>(v);
virtualinvoke v.<org.apache.activemq.leveldb.util.TimeMetric: java.lang.Object apply(scala.Function)>(v);
return;
}
public synchronized long skip(long)
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
long v, v, v, v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v := @parameter: long;
virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: void flush()>();
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset()>();
v = v + v;
virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: void append_offset_$eq(long)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.util.concurrent.atomic.AtomicLong flushed_offset()>();
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
return v;
}
public synchronized scala.Tuple append(byte, org.fusesource.hawtbuf.Buffer)
{
org.apache.activemq.leveldb.RecordLog$ v, v, v;
byte[] v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
org.apache.activemq.leveldb.RecordLog v;
long v, v, v;
org.fusesource.hawtbuf.Buffer v;
byte v, v;
java.lang.Long v;
int v, v, v, v, v, v, v, v;
org.fusesource.hawtbuf.DataByteArrayOutputStream v, v, v, v, v, v;
org.apache.activemq.leveldb.RecordLog$LogInfo v;
scala.Tuple v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v := @parameter: byte;
v := @parameter: org.fusesource.hawtbuf.Buffer;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_position()>();
v = v.<org.fusesource.hawtbuf.Buffer: int length>;
v = <org.apache.activemq.leveldb.RecordLog$: org.apache.activemq.leveldb.RecordLog$ MODULE$>;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$: int LOG_HEADER_SIZE()>();
v = v + v;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer()>();
v = virtualinvoke v.<org.fusesource.hawtbuf.DataByteArrayOutputStream: int position()>();
v = v + v;
v = <org.apache.activemq.leveldb.RecordLog$: org.apache.activemq.leveldb.RecordLog$ MODULE$>;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$: int BUFFER_SIZE()>();
if v <= v goto label;
virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: void flush()>();
label:
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.apache.activemq.leveldb.RecordLog org$apache$activemq$leveldb$RecordLog$LogAppender$$$outer()>();
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog: int checksum(org.fusesource.hawtbuf.Buffer)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer()>();
v = <org.apache.activemq.leveldb.RecordLog$: org.apache.activemq.leveldb.RecordLog$ MODULE$>;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$: byte LOG_HEADER_PREFIX()>();
virtualinvoke v.<org.fusesource.hawtbuf.DataByteArrayOutputStream: void writeByte(int)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer()>();
virtualinvoke v.<org.fusesource.hawtbuf.DataByteArrayOutputStream: void writeByte(int)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer()>();
virtualinvoke v.<org.fusesource.hawtbuf.DataByteArrayOutputStream: void writeInt(int)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer()>();
virtualinvoke v.<org.fusesource.hawtbuf.DataByteArrayOutputStream: void writeInt(int)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer()>();
v = v.<org.fusesource.hawtbuf.Buffer: byte[] data>;
v = v.<org.fusesource.hawtbuf.Buffer: int offset>;
virtualinvoke v.<org.fusesource.hawtbuf.DataByteArrayOutputStream: void write(byte[],int,int)>(v, v, v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset()>();
v = v + v;
virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: void append_offset_$eq(long)>(v);
v = new scala.Tuple;
v = staticinvoke <scala.runtime.BoxesRunTime: java.lang.Long boxToLong(long)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.apache.activemq.leveldb.RecordLog$LogInfo info()>();
specialinvoke v.<scala.Tuple2: void <init>(java.lang.Object,java.lang.Object)>(v, v);
return v;
}
public void flush()
{
org.apache.activemq.leveldb.util.TimeMetric v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
org.apache.activemq.leveldb.RecordLog v;
org.apache.activemq.leveldb.RecordLog$LogAppender$$anonfun$flush$1 v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.apache.activemq.leveldb.RecordLog org$apache$activemq$leveldb$RecordLog$LogAppender$$$outer()>();
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog: org.apache.activemq.leveldb.util.TimeMetric max_log_flush_latency()>();
v = new org.apache.activemq.leveldb.RecordLog$LogAppender$$anonfun$flush$1;
specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender$$anonfun$flush$1: void <init>(org.apache.activemq.leveldb.RecordLog$LogAppender)>(v);
virtualinvoke v.<org.apache.activemq.leveldb.util.TimeMetric: java.lang.Object apply(scala.Function)>(v);
return;
}
public void check_read_flush(long)
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
byte v;
long v, v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v := @parameter: long;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.util.concurrent.atomic.AtomicLong flushed_offset()>();
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp v;
if v >= 0 goto label;
virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: void flush()>();
label:
return;
}
public void <init>(org.apache.activemq.leveldb.RecordLog, java.io.File, long, long)
{
org.apache.activemq.leveldb.RecordLog$ v, v;
org.apache.activemq.leveldb.RecordLog$LogAppender v;
org.apache.activemq.leveldb.RecordLog v;
long v, v, v, v, v, v, v;
org.fusesource.hawtbuf.Buffer v;
java.nio.ByteBuffer v;
byte v;
int v, v, v;
org.fusesource.hawtbuf.DataByteArrayOutputStream v;
org.apache.activemq.leveldb.RecordLog$LogInfo v;
scala.runtime.BoxedUnit v;
java.io.File v, v;
java.util.concurrent.atomic.AtomicLong v;
java.nio.channels.FileChannel v, v, v, v;
v := @this: org.apache.activemq.leveldb.RecordLog$LogAppender;
v := @parameter: org.apache.activemq.leveldb.RecordLog;
v := @parameter: java.io.File;
v := @parameter: long;
v := @parameter: long;
v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset> = v;
specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogReader: void <init>(org.apache.activemq.leveldb.RecordLog,java.io.File,long)>(v, v, v);
v = new org.apache.activemq.leveldb.RecordLog$LogInfo;
v = specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogReader: java.io.File file()>();
v = specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogReader: long position()>();
specialinvoke v.<org.apache.activemq.leveldb.RecordLog$LogInfo: void <init>(java.io.File,long,long)>(v, v, 0L);
v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.apache.activemq.leveldb.RecordLog$LogInfo info> = v;
v = new java.util.concurrent.atomic.AtomicLong;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset()>();
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>(long)>(v);
v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.util.concurrent.atomic.AtomicLong flushed_offset> = v;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: long append_offset()>();
v = v cmp 0L;
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.nio.channels.FileChannel channel()>();
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog: long logSize()>();
v = v - 1L;
virtualinvoke v.<java.nio.channels.FileChannel: java.nio.channels.FileChannel position(long)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.nio.channels.FileChannel channel()>();
v = new org.fusesource.hawtbuf.Buffer;
specialinvoke v.<org.fusesource.hawtbuf.Buffer: void <init>(int)>(1);
v = virtualinvoke v.<org.fusesource.hawtbuf.Buffer: java.nio.ByteBuffer toByteBuffer()>();
virtualinvoke v.<java.nio.channels.FileChannel: int write(java.nio.ByteBuffer)>(v);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.nio.channels.FileChannel channel()>();
virtualinvoke v.<java.nio.channels.FileChannel: void force(boolean)>(1);
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$LogAppender: java.nio.channels.FileChannel channel()>();
virtualinvoke v.<java.nio.channels.FileChannel: java.nio.channels.FileChannel position(long)>(0L);
goto label;
label:
v = <scala.runtime.BoxedUnit: scala.runtime.BoxedUnit UNIT>;
label:
v = new org.fusesource.hawtbuf.DataByteArrayOutputStream;
v = <org.apache.activemq.leveldb.RecordLog$: org.apache.activemq.leveldb.RecordLog$ MODULE$>;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$: int BUFFER_SIZE()>();
v = <org.apache.activemq.leveldb.RecordLog$: org.apache.activemq.leveldb.RecordLog$ MODULE$>;
v = virtualinvoke v.<org.apache.activemq.leveldb.RecordLog$: int LOG_HEADER_SIZE()>();
v = v + v;
specialinvoke v.<org.fusesource.hawtbuf.DataByteArrayOutputStream: void <init>(int)>(v);
v.<org.apache.activemq.leveldb.RecordLog$LogAppender: org.fusesource.hawtbuf.DataByteArrayOutputStream write_buffer> = v;
return;
}
}