public class org.apache.activemq.store.kahadb.disk.journal.Journal extends java.lang.Object
{
public static final java.lang.String CALLER_BUFFER_APPENDER;
public static final boolean callerBufferAppender;
private static final int PREALLOC_CHUNK_SIZE;
public static final int RECORD_HEAD_SPACE;
public static final byte USER_RECORD_TYPE;
public static final byte BATCH_CONTROL_RECORD_TYPE;
public static final byte[] BATCH_CONTROL_RECORD_MAGIC;
public static final int BATCH_CONTROL_RECORD_SIZE;
public static final byte[] BATCH_CONTROL_RECORD_HEADER;
public static final byte[] EMPTY_BATCH_CONTROL_RECORD;
public static final int EOF_INT;
public static final byte EOF_EOT;
public static final byte[] EOF_RECORD;
private java.util.concurrent.ScheduledExecutorService scheduler;
public static final java.lang.String DEFAULT_DIRECTORY;
public static final java.lang.String DEFAULT_ARCHIVE_DIRECTORY;
public static final java.lang.String DEFAULT_FILE_PREFIX;
public static final java.lang.String DEFAULT_FILE_SUFFIX;
public static final int DEFAULT_MAX_FILE_LENGTH;
public static final int DEFAULT_CLEANUP_INTERVAL;
public static final int DEFAULT_MAX_WRITE_BATCH_SIZE;
private static final org.slf4j.Logger LOG;
protected final java.util.Map inflightWrites;
protected java.io.File directory;
protected java.io.File directoryArchive;
private boolean directoryArchiveOverridden;
protected java.lang.String filePrefix;
protected java.lang.String fileSuffix;
protected boolean started;
protected int maxFileLength;
protected int writeBatchSize;
protected org.apache.activemq.store.kahadb.disk.journal.FileAppender appender;
protected org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool;
protected java.util.Map fileMap;
protected java.util.Map fileByFileMap;
protected org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles;
protected final java.util.concurrent.atomic.AtomicReference lastAppendLocation;
protected java.util.concurrent.ScheduledFuture cleanupTask;
protected java.util.concurrent.atomic.AtomicLong totalLength;
protected boolean archiveDataLogs;
private org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget replicationTarget;
protected boolean checksum;
protected boolean checkForCorruptionOnStartup;
protected boolean enableAsyncDiskSync;
private int nextDataFileId;
private java.lang.Object dataFileIdLock;
private final java.util.concurrent.atomic.AtomicReference currentDataFile;
private volatile org.apache.activemq.store.kahadb.disk.journal.DataFile nextDataFile;
protected org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope;
protected org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy;
private java.io.File osKernelCopyTemplateFile;
private java.nio.ByteBuffer preAllocateDirectBuffer;
private long cleanupInterval;
protected org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy journalDiskSyncStrategy;
private org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener dataFileRemovedListener;
private java.lang.Runnable preAllocateNextDataFileTask;
private volatile java.util.concurrent.Future preAllocateNextDataFileFuture;
public void <init>()
{
org.apache.activemq.store.kahadb.disk.journal.Journal$4 v;
org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy v;
java.util.concurrent.ConcurrentHashMap v;
java.util.HashMap v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope v;
java.util.concurrent.atomic.AtomicReference v, v;
java.io.File v;
java.util.LinkedHashMap v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.store.kahadb.disk.util.LinkedNodeList v;
java.lang.Object v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map inflightWrites> = v;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(".");
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory> = v;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean directoryArchiveOverridden> = 0;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String filePrefix> = "db-";
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String fileSuffix> = ".log";
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength> = 33554432;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int writeBatchSize> = 4194304;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap> = v;
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap> = v;
v = new org.apache.activemq.store.kahadb.disk.util.LinkedNodeList;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles> = v;
v = new java.util.concurrent.atomic.AtomicReference;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength> = v;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean enableAsyncDiskSync> = 1;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int nextDataFileId> = 1;
v = new java.lang.Object;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.Object dataFileIdLock> = v;
v = new java.util.concurrent.atomic.AtomicReference;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>(java.lang.Object)>(null);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile> = v;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope ENTIRE_JOURNAL>;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope> = v;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy SPARSE_FILE>;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy> = v;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File osKernelCopyTemplateFile> = null;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer> = null;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: long cleanupInterval> = 30000L;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy: org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy ALWAYS>;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy journalDiskSyncStrategy> = v;
v = new org.apache.activemq.store.kahadb.disk.journal.Journal$4;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal$4: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.Runnable preAllocateNextDataFileTask> = v;
return;
}
public void corruptRecoveryLocation(org.apache.activemq.store.kahadb.disk.journal.Location) throws java.io.IOException
{
java.lang.Throwable v;
byte[] v;
java.io.RandomAccessFile v;
org.apache.activemq.store.kahadb.disk.util.SequenceSet v;
long v, v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor v;
int v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.util.ByteSequence v;
org.slf4j.Logger v;
org.apache.activemq.store.kahadb.disk.util.Sequence v;
java.io.IOException v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
java.io.File v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v, v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile getDataFile(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor openDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor: org.apache.activemq.util.RecoverableRandomAccessFile getRaf()>();
v = virtualinvoke v.<org.apache.activemq.util.RecoverableRandomAccessFile: java.io.RandomAccessFile getRaf()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = v + 1;
virtualinvoke v.<java.io.RandomAccessFile: void seek(long)>(v);
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int getWriteBatchSize()>();
v = newarray (byte)[v];
v = new org.apache.activemq.util.ByteSequence;
v = virtualinvoke v.<java.io.RandomAccessFile: int read(byte[])>(v);
specialinvoke v.<org.apache.activemq.util.ByteSequence: void <init>(byte[],int,int)>(v, 0, v);
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int findNextBatchRecord(org.apache.activemq.util.ByteSequence,java.io.RandomAccessFile)>(v, v);
if v < 0 goto label;
v = virtualinvoke v.<java.io.RandomAccessFile: long getFilePointer()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int remaining()>();
v = v - v;
v = staticinvoke <java.lang.Math: int toIntExact(long)>(v);
goto label;
label:
v = virtualinvoke v.<java.io.RandomAccessFile: long length()>();
v = staticinvoke <java.lang.Math: int toIntExact(long)>(v);
label:
v = new org.apache.activemq.store.kahadb.disk.util.Sequence;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = v - 1;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.util.Sequence: void <init>(long,long)>(v, v);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.io.File getFile()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Corrupt journal records found in \'{}\' between offsets: {}", v, v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(v);
v = (int) -1;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setSize(int)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: org.apache.activemq.store.kahadb.disk.util.SequenceSet corruptedBlocks>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.SequenceSet: void add(org.apache.activemq.store.kahadb.disk.util.Sequence)>(v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
throw v;
label:
return;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool getAccessorPool()
{
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
return v;
}
public void allowIOResumption()
{
org.apache.activemq.store.kahadb.disk.journal.FileAppender v, v;
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender>;
v = v instanceof org.apache.activemq.store.kahadb.disk.journal.DataFileAppender;
if v == 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender>;
v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAppender: boolean shutdown> = 0;
label:
return;
}
public void setCleanupInterval(long)
{
long v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: long;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: long cleanupInterval> = v;
return;
}
public long getCleanupInterval()
{
long v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: long cleanupInterval>;
return v;
}
private static byte[] createBatchControlRecordHeader()
{
java.lang.Throwable v;
byte[] v, v;
java.io.IOException v;
java.lang.RuntimeException v;
org.apache.activemq.util.DataByteArrayOutputStream v;
int v;
org.apache.activemq.util.ByteSequence v;
label:
v = new org.apache.activemq.util.DataByteArrayOutputStream;
specialinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void <init>()>();
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int BATCH_CONTROL_RECORD_SIZE>;
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeInt(int)>(v);
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeByte(int)>(2);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_MAGIC>;
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void write(byte[])>(v);
v = virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: org.apache.activemq.util.ByteSequence toByteSequence()>();
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void compact()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: byte[] getData()>();
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void close()>();
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String,java.lang.Throwable)>("Could not create batch control record header.", v);
throw v;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
private static byte[] createEmptyBatchControlRecordHeader()
{
java.lang.Throwable v;
byte[] v, v;
java.io.IOException v;
java.lang.RuntimeException v;
org.apache.activemq.util.DataByteArrayOutputStream v;
int v;
org.apache.activemq.util.ByteSequence v;
label:
v = new org.apache.activemq.util.DataByteArrayOutputStream;
specialinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void <init>()>();
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int BATCH_CONTROL_RECORD_SIZE>;
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeInt(int)>(v);
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeByte(int)>(2);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_MAGIC>;
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void write(byte[])>(v);
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeInt(int)>(0);
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeLong(long)>(0L);
v = virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: org.apache.activemq.util.ByteSequence toByteSequence()>();
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void compact()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: byte[] getData()>();
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void close()>();
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String,java.lang.Throwable)>("Could not create empty batch control record header.", v);
throw v;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
private static byte[] createEofBatchAndLocationRecord()
{
java.lang.Throwable v;
byte[] v;
org.apache.activemq.util.DataByteArrayOutputStream v;
int v;
java.io.IOException v;
java.lang.RuntimeException v;
org.apache.activemq.util.ByteSequence v;
label:
v = new org.apache.activemq.util.DataByteArrayOutputStream;
specialinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void <init>()>();
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int EOF_INT>;
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeInt(int)>(v);
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void writeByte(int)>(52);
v = virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: org.apache.activemq.util.ByteSequence toByteSequence()>();
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void compact()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: byte[] getData()>();
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayOutputStream: void close()>();
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String,java.lang.Throwable)>("Could not create eof header.", v);
throw v;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
public synchronized void start() throws java.io.IOException
{
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope v, v;
java.lang.Integer v, v;
org.apache.activemq.store.kahadb.disk.util.LinkedNodeList v, v, v, v, v;
byte v;
java.util.Map v, v, v;
org.apache.activemq.store.kahadb.disk.journal.CallerBufferingDataFileAppender v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v;
org.apache.activemq.store.kahadb.disk.util.LinkedNode v, v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy v;
long v, v, v, v, v, v;
java.util.concurrent.ScheduledExecutorService v, v;
java.lang.String v, v, v, v, v, v;
java.lang.NumberFormatException v;
java.io.File v, v, v, v;
java.util.concurrent.atomic.AtomicLong v, v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAppender v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
java.util.concurrent.ScheduledFuture v;
java.nio.ByteBuffer v, v;
int[] v;
org.apache.activemq.store.kahadb.disk.journal.Location v, v;
boolean v, v, v, v, v, v, v;
java.util.Collection v;
java.util.concurrent.atomic.AtomicReference v, v, v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.LinkedList v;
org.apache.activemq.store.kahadb.disk.journal.Journal$3 v;
org.slf4j.Logger v, v;
java.util.Iterator v;
org.apache.activemq.store.kahadb.disk.journal.Journal$1 v;
org.apache.activemq.store.kahadb.disk.journal.Journal$2 v;
java.util.concurrent.TimeUnit v;
java.lang.Object v, v, v, v, v, v;
java.io.File[] v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean started>;
if v == 0 goto label;
return;
label:
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = new org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool> = v;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean started> = 1;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: boolean callerBufferAppender>;
if v == 0 goto label;
v = new org.apache.activemq.store.kahadb.disk.journal.CallerBufferingDataFileAppender;
v = v;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.CallerBufferingDataFileAppender: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
goto label;
label:
v = new org.apache.activemq.store.kahadb.disk.journal.DataFileAppender;
v = v;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAppender: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
label:
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender> = v;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory>;
v = new org.apache.activemq.store.kahadb.disk.journal.Journal$1;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal$1: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles(java.io.FilenameFilter)>(v);
if v == null goto label;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
label:
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String filePrefix>;
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: int length()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String fileSuffix>;
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - v;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(v, v);
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
v = new org.apache.activemq.store.kahadb.disk.journal.DataFile;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: void <init>(java.io.File,int)>(v, v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer getDataFileId()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
label:
goto label;
label:
v := @caughtexception;
label:
v = v + 1;
goto label;
label:
v = new java.util.LinkedList;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
specialinvoke v.<java.util.LinkedList: void <init>(java.util.Collection)>(v);
staticinvoke <java.util.Collections: void sort(java.util.List)>(v);
v = virtualinvoke v.<java.util.LinkedList: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
if v != 0 goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.store.kahadb.disk.journal.DataFile)>(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[])>("ignoring zero length, partially initialised journal data file: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object getLast()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean isUnusedPreallocated(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
if v != 0 goto label;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: void addLast(org.apache.activemq.store.kahadb.disk.util.LinkedNode)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.io.File getFile()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean isCheckForCorruptionOnStartup()>();
if v == 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Location recoveryCheck(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
goto label;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope>;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope NONE>;
if v == v goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$5: int[] $SwitchMap$org$apache$activemq$store$kahadb$disk$journal$Journal$PreallocationStrategy>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy: int ordinal()>();
v = v[v];
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
default: goto label;
};
label:
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File createJournalTemplateFile()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File osKernelCopyTemplateFile> = v;
goto label;
label:
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer allocateDirectBuffer(int)>(1048576);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer> = v;
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int getMaxFileLength()>();
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer allocateDirectBuffer(int)>(v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer> = v;
label:
v = new org.apache.activemq.store.kahadb.disk.journal.Journal$2;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal$2: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newScheduledThreadPool(int,java.util.concurrent.ThreadFactory)>(1, v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.ScheduledExecutorService scheduler> = v;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: boolean isEmpty()>();
if v == 0 goto label;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int nextDataFileId> = 1;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void rotateWriteFile()>();
goto label;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: org.apache.activemq.store.kahadb.disk.util.LinkedNode getTail()>();
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer dataFileId>;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = v + 1;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int nextDataFileId> = v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
if v != null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: org.apache.activemq.store.kahadb.disk.util.LinkedNode getTail()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Location recoveryCheck(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: org.apache.activemq.store.kahadb.disk.util.LinkedNode getTail()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp v;
if v <= 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
if v <= 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = v - v;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.ScheduledExecutorService scheduler>;
v = new org.apache.activemq.store.kahadb.disk.journal.Journal$3;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal$3: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: long cleanupInterval>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: long cleanupInterval>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, v, v, v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.ScheduledFuture cleanupTask> = v;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = v - v;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long)>(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[])>("Startup took: \u ms");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
return;
catch java.lang.NumberFormatException from label to label with label;
}
private java.nio.ByteBuffer allocateDirectBuffer(int)
{
byte[] v;
int v;
java.nio.ByteBuffer v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: int;
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer allocateDirect(int)>(v);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer put(byte[])>(v);
return v;
}
public void preallocateEntireJournalDataFile(org.apache.activemq.util.RecoverableRandomAccessFile)
{
java.lang.Throwable v;
org.slf4j.Logger v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy v, v, v, v, v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope v, v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.RecoverableRandomAccessFile;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope NONE>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope>;
if v == v goto label;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy OS_KERNEL_COPY>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy>;
if v != v goto label;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void doPreallocationKernelCopy(org.apache.activemq.util.RecoverableRandomAccessFile)>(v);
goto label;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy ZEROS>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy>;
if v != v goto label;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void doPreallocationZeros(org.apache.activemq.util.RecoverableRandomAccessFile)>(v);
goto label;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy CHUNKED_ZEROS>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy>;
if v != v goto label;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void doPreallocationChunkedZeros(org.apache.activemq.util.RecoverableRandomAccessFile)>(v);
goto label;
label:
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void doPreallocationSparseFile(org.apache.activemq.util.RecoverableRandomAccessFile)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("cound not preallocate journal data file", v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void doPreallocationSparseFile(org.apache.activemq.util.RecoverableRandomAccessFile)
{
byte[] v;
org.slf4j.Logger v, v;
java.io.IOException v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
java.nio.ByteBuffer v;
java.nio.channels.ClosedByInterruptException v;
int v, v;
java.nio.channels.FileChannel v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.RecoverableRandomAccessFile;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer wrap(byte[])>(v);
label:
v = virtualinvoke v.<org.apache.activemq.util.RecoverableRandomAccessFile: java.nio.channels.FileChannel getChannel()>();
virtualinvoke v.<java.nio.channels.FileChannel: java.nio.channels.FileChannel position(long)>(0L);
virtualinvoke v.<java.nio.channels.FileChannel: int write(java.nio.ByteBuffer)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength>;
v = v - 5;
virtualinvoke v.<java.nio.channels.FileChannel: java.nio.channels.FileChannel position(long)>(v);
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer rewind()>();
virtualinvoke v.<java.nio.channels.FileChannel: int write(java.nio.ByteBuffer)>(v);
virtualinvoke v.<java.nio.channels.FileChannel: void force(boolean)>(0);
virtualinvoke v.<java.nio.channels.FileChannel: java.nio.channels.FileChannel position(long)>(0L);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Throwable)>("Could not preallocate journal file with sparse file", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Could not preallocate journal file with sparse file", v);
label:
return;
catch java.nio.channels.ClosedByInterruptException from label to label with label;
catch java.io.IOException from label to label with label;
}
private void doPreallocationZeros(org.apache.activemq.util.RecoverableRandomAccessFile)
{
org.slf4j.Logger v, v;
java.io.IOException v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
java.nio.ByteBuffer v, v;
java.nio.channels.ClosedByInterruptException v;
java.nio.channels.FileChannel v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.RecoverableRandomAccessFile;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer rewind()>();
label:
v = virtualinvoke v.<org.apache.activemq.util.RecoverableRandomAccessFile: java.nio.channels.FileChannel getChannel()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
virtualinvoke v.<java.nio.channels.FileChannel: int write(java.nio.ByteBuffer)>(v);
virtualinvoke v.<java.nio.channels.FileChannel: void force(boolean)>(0);
virtualinvoke v.<java.nio.channels.FileChannel: java.nio.channels.FileChannel position(long)>(0L);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Throwable)>("Could not preallocate journal file with zeros", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Could not preallocate journal file with zeros", v);
label:
return;
catch java.nio.channels.ClosedByInterruptException from label to label with label;
catch java.io.IOException from label to label with label;
}
private void doPreallocationKernelCopy(org.apache.activemq.util.RecoverableRandomAccessFile)
{
java.lang.Throwable v;
java.io.RandomAccessFile v;
int v;
java.lang.String v, v, v, v;
org.slf4j.Logger v, v, v;
java.io.IOException v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
java.io.File v, v, v;
java.io.FileNotFoundException v;
java.nio.channels.ClosedByInterruptException v;
java.nio.channels.FileChannel v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.RecoverableRandomAccessFile;
label:
v = new java.io.RandomAccessFile;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File osKernelCopyTemplateFile>;
specialinvoke v.<java.io.RandomAccessFile: void <init>(java.io.File,java.lang.String)>(v, "rw");
label:
v = virtualinvoke v.<java.io.RandomAccessFile: java.nio.channels.FileChannel getChannel()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int getMaxFileLength()>();
v = virtualinvoke v.<org.apache.activemq.util.RecoverableRandomAccessFile: java.nio.channels.FileChannel getChannel()>();
virtualinvoke v.<java.nio.channels.FileChannel: long transferTo(long,long,java.nio.channels.WritableByteChannel)>(0L, v, v);
label:
virtualinvoke v.<java.io.RandomAccessFile: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Throwable)>("Could not preallocate journal file with kernel copy", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File osKernelCopyTemplateFile>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("Could not find the template file on disk at \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File osKernelCopyTemplateFile>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("Could not transfer the template file to journal, transferFile=\u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.nio.channels.ClosedByInterruptException from label to label with label;
catch java.io.FileNotFoundException from label to label with label;
catch java.io.IOException from label to label with label;
}
private java.io.File createJournalTemplateFile()
{
java.lang.Throwable v;
byte[] v;
java.io.RandomAccessFile v;
java.nio.ByteBuffer v;
int v;
java.lang.String v, v, v, v;
org.slf4j.Logger v, v;
java.io.IOException v;
java.io.File v, v, v, v;
java.io.FileNotFoundException v;
java.nio.channels.FileChannel v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = new java.io.File;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory>;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, "db-log.template");
label:
v = new java.io.RandomAccessFile;
specialinvoke v.<java.io.RandomAccessFile: void <init>(java.io.File,java.lang.String)>(v, "rw");
label:
v = virtualinvoke v.<java.io.RandomAccessFile: java.nio.channels.FileChannel getChannel()>();
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer wrap(byte[])>(v);
virtualinvoke v.<java.nio.channels.FileChannel: int write(java.nio.ByteBuffer)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength>;
virtualinvoke v.<java.io.RandomAccessFile: void setLength(long)>(v);
v = virtualinvoke v.<java.io.RandomAccessFile: java.nio.channels.FileChannel getChannel()>();
virtualinvoke v.<java.nio.channels.FileChannel: void force(boolean)>(1);
label:
virtualinvoke v.<java.io.RandomAccessFile: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File osKernelCopyTemplateFile>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("Could not find the template file on disk at \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File osKernelCopyTemplateFile>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("Could not transfer the template file to journal, transferFile=\u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.io.FileNotFoundException from label to label with label;
catch java.io.IOException from label to label with label;
}
private void doPreallocationChunkedZeros(org.apache.activemq.util.RecoverableRandomAccessFile)
{
java.nio.ByteBuffer v, v, v, v, v, v, v;
int v, v, v, v;
org.slf4j.Logger v, v;
java.io.IOException v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
java.nio.channels.ClosedByInterruptException v;
java.nio.channels.FileChannel v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.RecoverableRandomAccessFile;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int capacity()>();
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer limit(int)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer rewind()>();
label:
v = virtualinvoke v.<org.apache.activemq.util.RecoverableRandomAccessFile: java.nio.channels.FileChannel getChannel()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength>;
label:
if v <= 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
v = virtualinvoke v.<java.nio.ByteBuffer: int remaining()>();
if v >= v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer limit(int)>(v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
v = virtualinvoke v.<java.nio.channels.FileChannel: int write(java.nio.ByteBuffer)>(v);
v = v - v;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.nio.ByteBuffer preAllocateDirectBuffer>;
virtualinvoke v.<java.nio.ByteBuffer: java.nio.ByteBuffer rewind()>();
goto label;
label:
virtualinvoke v.<java.nio.channels.FileChannel: void force(boolean)>(0);
virtualinvoke v.<java.nio.channels.FileChannel: java.nio.channels.FileChannel position(long)>(0L);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Throwable)>("Could not preallocate journal file with zeros", v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Could not preallocate journal file with zeros! Will continue without preallocation", v);
label:
return;
catch java.nio.channels.ClosedByInterruptException from label to label with label;
catch java.io.IOException from label to label with label;
}
private static byte[] bytes(java.lang.String)
{
byte[] v;
java.lang.RuntimeException v;
java.lang.String v;
java.io.UnsupportedEncodingException v;
v := @parameter: java.lang.String;
label:
v = virtualinvoke v.<java.lang.String: byte[] getBytes(java.lang.String)>("UTF-8");
label:
return v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.io.UnsupportedEncodingException from label to label with label;
}
public boolean isUnusedPreallocated(org.apache.activemq.store.kahadb.disk.journal.DataFile) throws java.io.IOException
{
java.lang.Throwable v;
byte[] v, v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor v;
int v;
org.apache.activemq.util.ByteSequence v;
boolean v;
java.lang.Exception v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v, v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.DataFile;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope>;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope ENTIRE_JOURNAL_ASYNC>;
if v != v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor openDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_HEADER>;
v = lengthof v;
v = newarray (byte)[v];
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor: void readFully(long,byte[])>(0L, v);
v = new org.apache.activemq.util.ByteSequence;
specialinvoke v.<org.apache.activemq.util.ByteSequence: void <init>(byte[])>(v);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: boolean startsWith(byte[])>(v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
throw v;
label:
return 0;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
}
protected org.apache.activemq.store.kahadb.disk.journal.Location recoveryCheck(org.apache.activemq.store.kahadb.disk.journal.DataFile) throws java.io.IOException
{
byte[] v, v;
java.io.RandomAccessFile v;
java.lang.Integer v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor v;
byte v, v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.store.kahadb.disk.util.Sequence v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v, v, v;
java.lang.Throwable v;
org.apache.activemq.store.kahadb.disk.util.SequenceSet v, v;
long v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v;
org.slf4j.Logger v, v, v;
java.io.IOException v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
java.io.File v, v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.DataFile;
v = new org.apache.activemq.store.kahadb.disk.journal.Location;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void <init>()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer getDataFileId()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setDataFileId(int)>(v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(0);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor openDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor: org.apache.activemq.util.RecoverableRandomAccessFile getRaf()>();
v = virtualinvoke v.<org.apache.activemq.util.RecoverableRandomAccessFile: java.io.RandomAccessFile getRaf()>();
virtualinvoke v.<java.io.RandomAccessFile: void seek(long)>(0L);
v = virtualinvoke v.<java.io.RandomAccessFile: long length()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int getWriteBatchSize()>();
v = newarray (byte)[v];
v = new org.apache.activemq.util.ByteSequence;
v = virtualinvoke v.<java.io.RandomAccessFile: int read(byte[])>(v);
specialinvoke v.<org.apache.activemq.util.ByteSequence: void <init>(byte[],int,int)>(v, 0, v);
label:
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int checkBatchRecord(org.apache.activemq.util.ByteSequence,java.io.RandomAccessFile)>(v, v);
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int BATCH_CONTROL_RECORD_SIZE>;
v = v + v;
v = v + v;
v = v cmp v;
if v > 0 goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int BATCH_CONTROL_RECORD_SIZE>;
v = v + v;
v = v + v;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(v);
goto label;
label:
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = lengthof v;
v = v + v;
v = v + v;
v = v cmp v;
if v <= 0 goto label;
label:
v = new org.apache.activemq.store.kahadb.disk.util.Sequence;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
specialinvoke v.<org.apache.activemq.store.kahadb.disk.util.Sequence: void <init>(long)>(v);
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int findNextBatchRecord(org.apache.activemq.util.ByteSequence,java.io.RandomAccessFile)>(v, v);
if v < 0 goto label;
v = virtualinvoke v.<java.io.RandomAccessFile: long getFilePointer()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int remaining()>();
v = v - v;
v = staticinvoke <java.lang.Math: int toIntExact(long)>(v);
v = v - 1;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.Sequence: void setLast(long)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: org.apache.activemq.store.kahadb.disk.util.SequenceSet corruptedBlocks>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.SequenceSet: void add(org.apache.activemq.store.kahadb.disk.util.Sequence)>(v);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.io.File getFile()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Corrupt journal records found in \'{}\' between offsets: {}", v, v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(v);
goto label;
label:
v = virtualinvoke v.<java.io.RandomAccessFile: long getFilePointer()>();
v = staticinvoke <java.lang.Math: int toIntExact(long)>(v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.Sequence: void setLast(long)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: org.apache.activemq.store.kahadb.disk.util.SequenceSet corruptedBlocks>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.SequenceSet: void add(org.apache.activemq.store.kahadb.disk.util.Sequence)>(v);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.io.File getFile()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Corrupt journal records found in \'{}\' from offset: {} to EOF", v, v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.store.kahadb.disk.journal.DataFile,org.apache.activemq.store.kahadb.disk.journal.Location)>(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[])>("exception on recovery check of: \u, at \u0001");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: void setLength(int)>(v);
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
if v <= v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = v - v;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
label:
return v;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private int findNextBatchRecord(org.apache.activemq.util.ByteSequence, java.io.RandomAccessFile) throws java.io.IOException
{
byte[] v, v, v, v, v, v;
java.io.RandomAccessFile v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.util.ByteSequence v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: java.io.RandomAccessFile;
v = new org.apache.activemq.util.ByteSequence;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_HEADER>;
specialinvoke v.<org.apache.activemq.util.ByteSequence: void <init>(byte[])>(v);
label:
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int indexOf(org.apache.activemq.util.ByteSequence,int)>(v, 0);
if v < 0 goto label;
v = v.<org.apache.activemq.util.ByteSequence: int offset>;
v = v + v;
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setOffset(int)>(v);
return v;
label:
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = v.<org.apache.activemq.util.ByteSequence: byte[] data>;
v = lengthof v;
if v == v goto label;
v = (int) -1;
return v;
label:
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_HEADER>;
v = lengthof v;
v = v - v;
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setOffset(int)>(v);
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void reset()>();
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = v.<org.apache.activemq.util.ByteSequence: byte[] data>;
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = v.<org.apache.activemq.util.ByteSequence: byte[] data>;
v = lengthof v;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_HEADER>;
v = lengthof v;
v = v - v;
v = virtualinvoke v.<java.io.RandomAccessFile: int read(byte[],int,int)>(v, v, v);
v = v + v;
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setLength(int)>(v);
goto label;
}
private int checkBatchRecord(org.apache.activemq.util.ByteSequence, java.io.RandomAccessFile) throws java.io.IOException
{
byte[] v, v, v, v, v, v, v, v, v;
java.io.RandomAccessFile v;
byte v, v, v, v;
java.util.zip.Adler v, v;
org.apache.activemq.util.ByteSequence v;
boolean v, v;
java.lang.Throwable v;
long v, v;
org.apache.activemq.util.DataByteArrayInputStream v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: java.io.RandomAccessFile;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = lengthof v;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void ensureAvailable(org.apache.activemq.util.ByteSequence,java.io.RandomAccessFile,int)>(v, v, v);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: boolean startsWith(byte[])>(v);
if v == 0 goto label;
return 0;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int BATCH_CONTROL_RECORD_SIZE>;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void ensureAvailable(org.apache.activemq.util.ByteSequence,java.io.RandomAccessFile,int)>(v, v, v);
v = new org.apache.activemq.util.DataByteArrayInputStream;
specialinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: void <init>(org.apache.activemq.util.ByteSequence)>(v);
label:
v = 0;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_HEADER>;
v = lengthof v;
if v >= v goto label;
v = virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: byte readByte()>();
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_HEADER>;
v = v[v];
if v == v goto label;
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: void close()>();
return -1;
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: int readInt()>();
if v < 0 goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int BATCH_CONTROL_RECORD_SIZE>;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = lengthof v;
v = v + v;
v = 2147483647 - v;
if v <= v goto label;
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: void close()>();
return -2;
label:
v = virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: long readLong()>();
v = null;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean isChecksum()>();
if v == 0 goto label;
v = v cmp 0L;
if v <= 0 goto label;
v = new java.util.zip.Adler;
specialinvoke v.<java.util.zip.Adler32: void <init>()>();
v = v;
label:
v = virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: int position()>();
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setOffset(int)>(v);
v = v;
label:
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int remaining()>();
if v < v goto label;
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: byte[] getData()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int getOffset()>();
interfaceinvoke v.<java.util.zip.Checksum: void update(byte[],int,int)>(v, v, v);
label:
v = v.<org.apache.activemq.util.ByteSequence: int offset>;
v = v + v;
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setOffset(int)>(v);
v = 0;
goto label;
label:
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = v.<org.apache.activemq.util.ByteSequence: byte[] data>;
v = lengthof v;
if v == v goto label;
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: void close()>();
return -3;
label:
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int remaining()>();
v = v - v;
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: byte[] getData()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int getOffset()>();
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int remaining()>();
interfaceinvoke v.<java.util.zip.Checksum: void update(byte[],int,int)>(v, v, v);
label:
v = v.<org.apache.activemq.util.ByteSequence: byte[] data>;
v = virtualinvoke v.<java.io.RandomAccessFile: int read(byte[])>(v);
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setLength(int)>(v);
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setOffset(int)>(0);
goto label;
label:
if v == null goto label;
v = interfaceinvoke v.<java.util.zip.Checksum: long getValue()>();
v = v cmp v;
if v == 0 goto label;
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: void close()>();
return -4;
label:
virtualinvoke v.<org.apache.activemq.util.DataByteArrayInputStream: void close()>();
return v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void ensureAvailable(org.apache.activemq.util.ByteSequence, java.io.RandomAccessFile, int) throws java.io.IOException
{
byte[] v, v;
java.io.RandomAccessFile v;
int v, v, v, v, v, v, v, v, v, v;
java.lang.String v;
org.apache.activemq.util.ByteSequence v;
java.io.EOFException v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: java.io.RandomAccessFile;
v := @parameter: int;
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int remaining()>();
if v >= v goto label;
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void reset()>();
v = v.<org.apache.activemq.util.ByteSequence: byte[] data>;
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = v.<org.apache.activemq.util.ByteSequence: byte[] data>;
v = lengthof v;
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = v - v;
v = virtualinvoke v.<java.io.RandomAccessFile: int read(byte[],int,int)>(v, v, v);
if v >= 0 goto label;
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: int remaining()>();
if v != 0 goto label;
v = new java.io.EOFException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("request for \u bytes reached EOF");
specialinvoke v.<java.io.EOFException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.activemq.util.ByteSequence: int length>;
v = v + v;
virtualinvoke v.<org.apache.activemq.util.ByteSequence: void setLength(int)>(v);
label:
return;
}
void addToTotalLength(int)
{
int v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: int;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
return;
}
public long length()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public void rotateWriteFile() throws java.io.IOException
{
java.lang.Throwable v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope v, v;
java.lang.Integer v;
java.lang.Runnable v;
java.util.concurrent.atomic.AtomicReference v, v;
java.util.concurrent.Future v;
org.apache.activemq.store.kahadb.disk.util.LinkedNodeList v;
java.util.Map v, v;
java.util.concurrent.ScheduledExecutorService v;
java.io.File v;
java.lang.Object v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.Object dataFileIdLock>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile nextDataFile>;
if v != null goto label;
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile newDataFile()>();
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer getDataFileId()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.io.File getFile()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: void addLast(org.apache.activemq.store.kahadb.disk.util.LinkedNode)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile nextDataFile> = null;
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope ENTIRE_JOURNAL_ASYNC>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope>;
if v != v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.ScheduledExecutorService scheduler>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.Runnable preAllocateNextDataFileTask>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.Future submit(java.lang.Runnable)>(v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.Future preAllocateNextDataFileFuture> = v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private org.apache.activemq.store.kahadb.disk.journal.DataFile newDataFile() throws java.io.IOException
{
int v, v;
org.apache.activemq.util.RecoverableRandomAccessFile v;
java.io.File v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int nextDataFileId>;
v = v + 1;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int nextDataFileId> = v;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File getFile(int)>(v);
v = new org.apache.activemq.store.kahadb.disk.journal.DataFile;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: void <init>(java.io.File,int)>(v, v);
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: org.apache.activemq.util.RecoverableRandomAccessFile appendRandomAccessFile()>();
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void preallocateEntireJournalDataFile(org.apache.activemq.util.RecoverableRandomAccessFile)>(v);
return v;
}
public org.apache.activemq.store.kahadb.disk.journal.DataFile reserveDataFile()
{
java.lang.Throwable v, v;
java.lang.Integer v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.activemq.store.kahadb.disk.util.LinkedNodeList v, v, v;
java.util.Map v, v;
int v, v;
boolean v;
java.io.File v;
java.lang.Object v;
org.apache.activemq.store.kahadb.disk.util.LinkedNode v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.Object dataFileIdLock>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int nextDataFileId>;
v = v + 1;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int nextDataFileId> = v;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File getFile(int)>(v);
v = new org.apache.activemq.store.kahadb.disk.journal.DataFile;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: void <init>(java.io.File,int)>(v, v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer getDataFileId()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: boolean isEmpty()>();
if v == 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: void addLast(org.apache.activemq.store.kahadb.disk.util.LinkedNode)>(v);
goto label;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: org.apache.activemq.store.kahadb.disk.util.LinkedNode getTail()>();
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: void linkBefore(org.apache.activemq.store.kahadb.disk.util.LinkedNode)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public java.io.File getFile(int)
{
int v;
java.lang.String v, v, v;
java.io.File v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: int;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String filePrefix>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String fileSuffix>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,java.lang.String)>(v, 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[])>("\u0001\u0001\u0001");
v = new java.io.File;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory>;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
return v;
}
org.apache.activemq.store.kahadb.disk.journal.DataFile getDataFile(org.apache.activemq.store.kahadb.disk.journal.Location) throws java.io.IOException
{
java.lang.Throwable v;
org.slf4j.Logger v;
java.io.IOException v;
java.lang.Integer v;
java.util.concurrent.atomic.AtomicReference v;
java.io.File v;
java.util.Map v, v;
int v, v;
java.lang.Object v;
java.lang.String v, v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getDataFileId()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v != null goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Integer,java.util.Map)>(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[])>("Looking for key \u but not found in fileMap: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
v = new java.io.IOException;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getDataFileId()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File getFile(int)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Could not locate data file \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public void close() throws java.io.IOException
{
java.lang.Throwable v, v;
java.util.concurrent.ScheduledFuture v;
java.util.concurrent.atomic.AtomicReference v, v;
org.apache.activemq.store.kahadb.disk.journal.FileAppender v;
java.util.concurrent.Future v, v;
org.apache.activemq.store.kahadb.disk.util.LinkedNodeList v;
java.util.Map v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v;
java.util.concurrent.ScheduledExecutorService v;
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean started>;
if v != 0 goto label;
exitmonitor v;
label:
return;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.ScheduledFuture cleanupTask>;
interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean cancel(boolean)>(1);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.Future preAllocateNextDataFileFuture>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.Future preAllocateNextDataFileFuture>;
interfaceinvoke v.<java.util.concurrent.Future: boolean cancel(boolean)>(1);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.ScheduledExecutorService scheduler>;
staticinvoke <org.apache.activemq.util.ThreadPoolUtils: void shutdownGraceful(java.util.concurrent.ExecutorService,long)>(v, 4000L);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void close()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender>;
interfaceinvoke v.<org.apache.activemq.store.kahadb.disk.journal.FileAppender: void close()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: void clear()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(null);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean started> = 0;
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public synchronized void cleanup()
{
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void disposeUnused()>();
label:
return;
}
public synchronized boolean delete() throws java.io.IOException
{
java.lang.Throwable v, v;
java.util.concurrent.atomic.AtomicReference v, v;
java.util.concurrent.Future v, v;
org.apache.activemq.store.kahadb.disk.util.LinkedNodeList v;
java.util.Map v, v, v;
boolean v, v, v;
java.util.Iterator v;
java.util.Collection v;
org.apache.activemq.store.kahadb.disk.journal.FileAppender v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAppender v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v;
java.lang.Object v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender>;
interfaceinvoke v.<org.apache.activemq.store.kahadb.disk.journal.FileAppender: void close()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void close()>();
v = 1;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: boolean delete()>();
v = v & v;
goto label;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.Future preAllocateNextDataFileFuture>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.Future preAllocateNextDataFileFuture>;
interfaceinvoke v.<java.util.concurrent.Future: boolean cancel(boolean)>(1);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.Object dataFileIdLock>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile nextDataFile>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile nextDataFile>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: boolean delete()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile nextDataFile> = null;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: void set(long)>(0L);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(null);
v = new org.apache.activemq.store.kahadb.disk.util.LinkedNodeList;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles> = v;
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = new org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool> = v;
v = new org.apache.activemq.store.kahadb.disk.journal.DataFileAppender;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAppender: void <init>(org.apache.activemq.store.kahadb.disk.journal.Journal)>(v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender> = v;
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void removeDataFiles(java.util.Set) throws java.io.IOException
{
java.lang.Throwable v;
java.util.Iterator v;
java.util.Set v;
java.util.concurrent.atomic.AtomicReference v, v;
java.io.File v;
java.util.Map v, v;
int v, v;
java.lang.Object v, v, v;
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: java.util.Set;
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getDataFileId()>();
if v >= v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.io.File getFile()>();
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: boolean unlink()>();
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v == null goto label;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void forceRemoveDataFile(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void forceRemoveDataFile(org.apache.activemq.store.kahadb.disk.journal.DataFile) throws java.io.IOException
{
int v, v;
java.lang.String v, v;
boolean v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v, v, v;
java.io.File v, v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v;
org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.DataFile;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void disposeDataFileAccessors(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = neg v;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean archiveDataLogs>;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File getDirectoryArchive()>();
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Archive directory exists: {}", v);
goto label;
label:
v = virtualinvoke v.<java.io.File: boolean isAbsolute()>();
if v == 0 goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Archive directory [{}] does not exist - creating it now", v);
label:
staticinvoke <org.apache.activemq.util.IOHelper: void mkdirs(java.io.File)>(v);
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Moving data file {} to {} ", v, v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: void move(java.io.File)>(v);
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Successfully moved data file");
goto label;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Deleting data file: {}", v);
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: boolean delete()>();
if v == 0 goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Discarded data file: {}", v);
goto label;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.io.File getFile()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object)>("Failed to discard data file : {}", v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener dataFileRemovedListener>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener dataFileRemovedListener>;
interfaceinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener: void fileRemoved(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
label:
return;
}
public int getMaxFileLength()
{
int v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength>;
return v;
}
public void setMaxFileLength(int)
{
int v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: int;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength> = v;
return;
}
public java.lang.String toString()
{
java.lang.String v;
java.io.File v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory>;
v = virtualinvoke v.<java.io.File: java.lang.String toString()>();
return v;
}
public org.apache.activemq.store.kahadb.disk.journal.Location getNextLocation(org.apache.activemq.store.kahadb.disk.journal.Location) throws java.io.IOException, java.lang.IllegalStateException
{
org.apache.activemq.store.kahadb.disk.journal.Location v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Location getNextLocation(org.apache.activemq.store.kahadb.disk.journal.Location,org.apache.activemq.store.kahadb.disk.journal.Location)>(v, null);
return v;
}
public org.apache.activemq.store.kahadb.disk.journal.Location getNextLocation(org.apache.activemq.store.kahadb.disk.journal.Location, org.apache.activemq.store.kahadb.disk.journal.Location) throws java.io.IOException, java.lang.IllegalStateException
{
byte[] v;
java.lang.Integer v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor v;
org.apache.activemq.store.kahadb.disk.util.LinkedNodeList v;
byte v, v, v;
org.apache.activemq.store.kahadb.disk.journal.Location v, v, v, v, v, v;
org.apache.activemq.store.kahadb.disk.util.Sequence v;
java.io.EOFException v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v, v;
org.apache.activemq.store.kahadb.disk.util.LinkedNode v, v;
java.lang.Throwable v, v, v;
org.apache.activemq.store.kahadb.disk.util.SequenceSet v;
long v;
java.util.concurrent.atomic.AtomicReference v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v;
org.slf4j.Logger v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v = null;
label:
if v != null goto label;
if v != null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.util.LinkedNodeList dataFiles>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.LinkedNodeList: org.apache.activemq.store.kahadb.disk.util.LinkedNode getHead()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v != null goto label;
return null;
label:
v = new org.apache.activemq.store.kahadb.disk.journal.Location;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void <init>()>();
v = v;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer getDataFileId()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setDataFileId(int)>(v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(0);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getSize()>();
v = (int) -1;
if v != v goto label;
v = new org.apache.activemq.store.kahadb.disk.journal.Location;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void <init>(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
v = v;
goto label;
label:
v = new org.apache.activemq.store.kahadb.disk.journal.Location;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void <init>(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
v = v;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getSize()>();
v = v + v;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(v);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getSize()>();
v = v + v;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile getDataFile(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
if v > v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: org.apache.activemq.store.kahadb.disk.util.LinkedNode getNext()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v != null goto label;
return null;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer getDataFileId()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setDataFileId(int)>(v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(0);
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int compareTo(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
if v < 0 goto label;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("reached limit: {} at: {}", v, v);
return null;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor openDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
label:
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor: void readLocationDetails(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.store.kahadb.disk.journal.Location,org.apache.activemq.store.kahadb.disk.journal.Location)>(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 on next: \u, cur: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
throw v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
throw v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: org.apache.activemq.store.kahadb.disk.util.SequenceSet corruptedBlocks>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getOffset()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.SequenceSet: org.apache.activemq.store.kahadb.disk.util.Sequence get(int)>(v);
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.util.Sequence: long range()>();
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setSize(int)>(v);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getSize()>();
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: int EOF_INT>;
if v != v goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: byte getType()>();
if v == 52 goto label;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: byte getType()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: int getSize()>();
if v != 0 goto label;
label:
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD>;
v = lengthof v;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setSize(int)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = staticinvoke <java.lang.Math: int max(int,int)>(v, v);
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: void setOffset(int)>(v);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Location: byte getType()>();
if v != 1 goto label;
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.io.EOFException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activemq.util.ByteSequence read(org.apache.activemq.store.kahadb.disk.journal.Location) throws java.io.IOException, java.lang.IllegalStateException
{
java.lang.Throwable v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile getDataFile(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor openDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor: org.apache.activemq.util.ByteSequence readRecord(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activemq.store.kahadb.disk.journal.Location write(org.apache.activemq.util.ByteSequence, boolean) throws java.io.IOException, java.lang.IllegalStateException
{
org.apache.activemq.store.kahadb.disk.journal.FileAppender v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.util.ByteSequence v;
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: boolean;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender>;
v = interfaceinvoke v.<org.apache.activemq.store.kahadb.disk.journal.FileAppender: org.apache.activemq.store.kahadb.disk.journal.Location storeItem(org.apache.activemq.util.ByteSequence,byte,boolean)>(v, 1, v);
return v;
}
public org.apache.activemq.store.kahadb.disk.journal.Location write(org.apache.activemq.util.ByteSequence, java.lang.Runnable) throws java.io.IOException, java.lang.IllegalStateException
{
java.lang.Runnable v;
org.apache.activemq.store.kahadb.disk.journal.FileAppender v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: java.lang.Runnable;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.FileAppender appender>;
v = interfaceinvoke v.<org.apache.activemq.store.kahadb.disk.journal.FileAppender: org.apache.activemq.store.kahadb.disk.journal.Location storeItem(org.apache.activemq.util.ByteSequence,byte,java.lang.Runnable)>(v, 1, v);
return v;
}
public void update(org.apache.activemq.store.kahadb.disk.journal.Location, org.apache.activemq.util.ByteSequence, boolean) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor v;
org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool v, v, v;
org.apache.activemq.store.kahadb.disk.journal.DataFile v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.util.ByteSequence v;
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: boolean;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFile getDataFile(org.apache.activemq.store.kahadb.disk.journal.Location)>(v);
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor openDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFile)>(v);
label:
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor: void updateRecord(org.apache.activemq.store.kahadb.disk.journal.Location,org.apache.activemq.util.ByteSequence,boolean)>(v, v, v);
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool accessorPool>;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFileAccessorPool: void closeDataFileAccessor(org.apache.activemq.store.kahadb.disk.journal.DataFileAccessor)>(v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy getPreallocationStrategy()
{
org.apache.activemq.store.kahadb.disk.journal.Journal v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy>;
return v;
}
public void setPreallocationStrategy(org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy)
{
org.apache.activemq.store.kahadb.disk.journal.Journal v;
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationStrategy preallocationStrategy> = v;
return;
}
public org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope getPreallocationScope()
{
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope>;
return v;
}
public void setPreallocationScope(org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope)
{
org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$PreallocationScope preallocationScope> = v;
return;
}
public java.io.File getDirectory()
{
java.io.File v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory>;
return v;
}
public void setDirectory(java.io.File)
{
java.io.File v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: java.io.File;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory> = v;
return;
}
public java.lang.String getFilePrefix()
{
java.lang.String v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String filePrefix>;
return v;
}
public void setFilePrefix(java.lang.String)
{
java.lang.String v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: java.lang.String;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String filePrefix> = v;
return;
}
public java.util.Map getInflightWrites()
{
java.util.Map v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map inflightWrites>;
return v;
}
public org.apache.activemq.store.kahadb.disk.journal.Location getLastAppendLocation()
{
java.lang.Object v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
return v;
}
public void setLastAppendLocation(org.apache.activemq.store.kahadb.disk.journal.Location)
{
java.util.concurrent.atomic.AtomicReference v;
org.apache.activemq.store.kahadb.disk.journal.Location v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Location;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference lastAppendLocation>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
return;
}
public java.io.File getDirectoryArchive()
{
java.io.File v, v, v, v;
java.lang.String v, v, v;
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean directoryArchiveOverridden>;
if v != 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directoryArchive>;
if v != null goto label;
v = new java.io.File;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directory>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = <java.io.File: java.lang.String separator>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("\u0001\u0001data-archive");
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directoryArchive> = v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directoryArchive>;
return v;
}
public void setDirectoryArchive(java.io.File)
{
java.io.File v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: java.io.File;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean directoryArchiveOverridden> = 1;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.io.File directoryArchive> = v;
return;
}
public boolean isArchiveDataLogs()
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean archiveDataLogs>;
return v;
}
public void setArchiveDataLogs(boolean)
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: boolean;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean archiveDataLogs> = v;
return;
}
public org.apache.activemq.store.kahadb.disk.journal.DataFile getDataFileById(int)
{
java.lang.Throwable v;
java.util.Map v;
int v;
java.lang.Object v;
java.lang.Integer v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: int;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activemq.store.kahadb.disk.journal.DataFile getCurrentDataFile(int) throws java.io.IOException
{
java.lang.Throwable v, v, v;
java.util.concurrent.atomic.AtomicReference v, v, v, v, v, v;
int v, v, v, v, v, v, v;
java.lang.Object v, v, v, v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: int;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = v + v;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength>;
if v >= v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
exitmonitor v;
label:
return v;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.Object dataFileIdLock>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: int getLength()>();
v = v + v;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int maxFileLength>;
if v < v goto label;
virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal: void rotateWriteFile()>();
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
exitmonitor v;
label:
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public java.lang.Integer getCurrentDataFileId()
{
java.lang.Throwable v;
java.lang.Object v;
java.lang.Integer v;
java.util.concurrent.atomic.AtomicReference v, v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.DataFile: java.lang.Integer getDataFileId()>();
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
public java.util.Set getFiles()
{
java.lang.Throwable v;
java.util.Map v;
java.util.Set v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileByFileMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
public java.util.Map getFileMap()
{
java.lang.Throwable v;
java.util.TreeMap v;
java.util.Map v;
java.util.concurrent.atomic.AtomicReference v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicReference currentDataFile>;
entermonitor v;
label:
v = new java.util.TreeMap;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.Map fileMap>;
specialinvoke v.<java.util.TreeMap: void <init>(java.util.Map)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
public long getDiskSize()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public void setReplicationTarget(org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget)
{
org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget replicationTarget> = v;
return;
}
public org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget getReplicationTarget()
{
org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.ReplicationTarget replicationTarget>;
return v;
}
public java.lang.String getFileSuffix()
{
java.lang.String v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String fileSuffix>;
return v;
}
public void setFileSuffix(java.lang.String)
{
java.lang.String v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: java.lang.String;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.lang.String fileSuffix> = v;
return;
}
public boolean isChecksum()
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean checksum>;
return v;
}
public void setChecksum(boolean)
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: boolean;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean checksum> = v;
return;
}
public boolean isCheckForCorruptionOnStartup()
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean checkForCorruptionOnStartup>;
return v;
}
public void setCheckForCorruptionOnStartup(boolean)
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: boolean;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean checkForCorruptionOnStartup> = v;
return;
}
public void setWriteBatchSize(int)
{
int v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: int;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int writeBatchSize> = v;
return;
}
public int getWriteBatchSize()
{
int v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: int writeBatchSize>;
return v;
}
public void setSizeAccumulator(java.util.concurrent.atomic.AtomicLong)
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: java.util.concurrent.atomic.AtomicLong;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: java.util.concurrent.atomic.AtomicLong totalLength> = v;
return;
}
public void setEnableAsyncDiskSync(boolean)
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: boolean;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean enableAsyncDiskSync> = v;
return;
}
public boolean isEnableAsyncDiskSync()
{
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean enableAsyncDiskSync>;
return v;
}
public org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy getJournalDiskSyncStrategy()
{
org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy journalDiskSyncStrategy>;
return v;
}
public void setJournalDiskSyncStrategy(org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy)
{
org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy journalDiskSyncStrategy> = v;
return;
}
public boolean isJournalDiskSyncPeriodic()
{
org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy v, v;
boolean v;
org.apache.activemq.store.kahadb.disk.journal.Journal v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy: org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy PERIODIC>;
v = v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy journalDiskSyncStrategy>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.journal.Journal$JournalDiskSyncStrategy: boolean equals(java.lang.Object)>(v);
return v;
}
public void setDataFileRemovedListener(org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener)
{
org.apache.activemq.store.kahadb.disk.journal.Journal v;
org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener v;
v := @this: org.apache.activemq.store.kahadb.disk.journal.Journal;
v := @parameter: org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener;
v.<org.apache.activemq.store.kahadb.disk.journal.Journal: org.apache.activemq.store.kahadb.disk.journal.Journal$DataFileRemovedListener dataFileRemovedListener> = v;
return;
}
static void <clinit>()
{
byte[] v, v, v, v, v, v;
org.slf4j.Logger v;
java.nio.ByteBuffer v;
int v, v, v, v, v;
java.lang.String v;
boolean v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String,java.lang.String)>("org.apache.kahadb.journal.CALLER_BUFFER_APPENDER", "false");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
<org.apache.activemq.store.kahadb.disk.journal.Journal: boolean callerBufferAppender> = v;
v = staticinvoke <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] bytes(java.lang.String)>("WRITE BATCH");
<org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_MAGIC> = v;
v = <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_MAGIC>;
v = lengthof v;
v = 5 + v;
v = v + 4;
v = v + 8;
<org.apache.activemq.store.kahadb.disk.journal.Journal: int BATCH_CONTROL_RECORD_SIZE> = v;
v = staticinvoke <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] createBatchControlRecordHeader()>();
<org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] BATCH_CONTROL_RECORD_HEADER> = v;
v = staticinvoke <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] createEmptyBatchControlRecordHeader()>();
<org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EMPTY_BATCH_CONTROL_RECORD> = v;
v = newarray (byte)[4];
v[0] = 45;
v[1] = 113;
v[2] = 77;
v[3] = 97;
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer wrap(byte[])>(v);
v = virtualinvoke v.<java.nio.ByteBuffer: int getInt()>();
<org.apache.activemq.store.kahadb.disk.journal.Journal: int EOF_INT> = v;
v = staticinvoke <org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] createEofBatchAndLocationRecord()>();
<org.apache.activemq.store.kahadb.disk.journal.Journal: byte[] EOF_RECORD> = v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/store/kahadb/disk/journal/Journal;");
<org.apache.activemq.store.kahadb.disk.journal.Journal: org.slf4j.Logger LOG> = v;
return;
}
}