public class org.apache.activemq.store.journal.JournalMessageStore extends org.apache.activemq.store.AbstractMessageStore
{
private static final org.slf4j.Logger LOG;
protected final org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter;
protected final org.apache.activemq.store.journal.JournalTransactionStore transactionStore;
protected final org.apache.activemq.store.MessageStore longTermStore;
protected final org.apache.activemq.util.TransactionTemplate transactionTemplate;
protected org.apache.activeio.journal.RecordLocation lastLocation;
protected java.util.Set inFlightTxLocations;
private java.util.Map messages;
private java.util.List messageAcks;
private java.util.Map cpAddedMessageIds;
private org.apache.activemq.usage.MemoryUsage memoryUsage;
public void <init>(org.apache.activemq.store.journal.JournalPersistenceAdapter, org.apache.activemq.store.MessageStore, org.apache.activemq.command.ActiveMQDestination)
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.filter.NonCachedMessageEvaluationContext v;
org.apache.activemq.util.TransactionTemplate v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalTransactionStore v;
java.util.ArrayList v;
org.apache.activemq.command.ActiveMQDestination v;
java.util.HashSet v;
java.util.LinkedHashMap v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.store.journal.JournalPersistenceAdapter;
v := @parameter: org.apache.activemq.store.MessageStore;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
specialinvoke v.<org.apache.activemq.store.AbstractMessageStore: void <init>(org.apache.activemq.command.ActiveMQDestination)>(v);
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Set inFlightTxLocations> = v;
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map messages> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.List messageAcks> = v;
v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter> = v;
v = virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: org.apache.activemq.store.journal.JournalTransactionStore getTransactionStore()>();
v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalTransactionStore transactionStore> = v;
v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore> = v;
v = new org.apache.activemq.util.TransactionTemplate;
v = new org.apache.activemq.broker.ConnectionContext;
v = new org.apache.activemq.filter.NonCachedMessageEvaluationContext;
specialinvoke v.<org.apache.activemq.filter.NonCachedMessageEvaluationContext: void <init>()>();
specialinvoke v.<org.apache.activemq.broker.ConnectionContext: void <init>(org.apache.activemq.filter.MessageEvaluationContext)>(v);
specialinvoke v.<org.apache.activemq.util.TransactionTemplate: void <init>(org.apache.activemq.store.PersistenceAdapter,org.apache.activemq.broker.ConnectionContext)>(v, v);
v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.util.TransactionTemplate transactionTemplate> = v;
return;
}
public void setMemoryUsage(org.apache.activemq.usage.MemoryUsage)
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.usage.MemoryUsage v;
org.apache.activemq.store.journal.JournalMessageStore v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.usage.MemoryUsage;
v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.usage.MemoryUsage memoryUsage> = v;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void setMemoryUsage(org.apache.activemq.usage.MemoryUsage)>(v);
return;
}
public void addMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.Message) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalTransactionStore v;
org.apache.activeio.journal.RecordLocation v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
java.lang.String v, v;
boolean v, v, v;
org.slf4j.Logger v, v, v;
org.apache.activemq.command.MessageId v;
java.util.Set v;
org.apache.activemq.store.journal.JournalMessageStore$1 v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
org.apache.activemq.transaction.Transaction v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.Message;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
virtualinvoke v.<org.apache.activemq.command.Message: int incrementReferenceCount()>();
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isResponseRequired()>();
v = virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: org.apache.activeio.journal.RecordLocation writeCommand(org.apache.activemq.command.DataStructure,boolean)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isInTransaction()>();
if v != 0 goto label;
if v == 0 goto label;
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,org.apache.activeio.journal.RecordLocation)>(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[])>("Journalled message add for: \u, at: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
virtualinvoke v.<org.apache.activemq.store.journal.JournalMessageStore: void addMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message,org.apache.activeio.journal.RecordLocation)>(v, v, v);
goto label;
label:
if v == 0 goto label;
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,org.apache.activeio.journal.RecordLocation)>(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[])>("Journalled transacted message add for: \u, at: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
entermonitor v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Set inFlightTxLocations>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalTransactionStore transactionStore>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalTransactionStore: void addMessage(org.apache.activemq.store.journal.JournalMessageStore,org.apache.activemq.command.Message,org.apache.activeio.journal.RecordLocation)>(v, v, v);
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.transaction.Transaction getTransaction()>();
v = new org.apache.activemq.store.journal.JournalMessageStore$1;
specialinvoke v.<org.apache.activemq.store.journal.JournalMessageStore$1: void <init>(org.apache.activemq.store.journal.JournalMessageStore,boolean,org.apache.activemq.command.MessageId,org.apache.activeio.journal.RecordLocation,org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v, v, v, v, v);
virtualinvoke v.<org.apache.activemq.transaction.Transaction: void addSynchronization(org.apache.activemq.transaction.Synchronization)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
void addMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.Message, org.apache.activeio.journal.RecordLocation)
{
java.lang.Throwable v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v, v;
org.apache.activeio.journal.RecordLocation v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.store.IndexListener$MessageContext v;
java.lang.Long v;
java.util.Map v;
org.apache.activemq.store.IndexListener v, v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.Message;
v := @parameter: org.apache.activeio.journal.RecordLocation;
entermonitor v;
label:
v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activeio.journal.RecordLocation lastLocation> = v;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map messages>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(0L);
virtualinvoke v.<org.apache.activemq.command.MessageId: void setFutureOrSequenceLong(java.lang.Object)>(v);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.IndexListener indexListener>;
if v == null goto label;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.IndexListener indexListener>;
v = new org.apache.activemq.store.IndexListener$MessageContext;
specialinvoke v.<org.apache.activemq.store.IndexListener$MessageContext: void <init>(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message,java.lang.Runnable)>(v, v, null);
interfaceinvoke v.<org.apache.activemq.store.IndexListener: void onAdd(org.apache.activemq.store.IndexListener$MessageContext)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void replayAddMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.Message)
{
java.lang.Throwable v;
org.apache.activemq.store.MessageStore v, v;
org.slf4j.Logger v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v, v;
java.lang.String v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.Message;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = interfaceinvoke v.<org.apache.activemq.store.MessageStore: org.apache.activemq.command.Message getMessage(org.apache.activemq.command.MessageId)>(v);
if v != null goto label;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void addMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.lang.Throwable)>(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[])>("Could not replay add for message \'\u0001\'.  Message may have already been added. reason: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void removeMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.MessageAck) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalTransactionStore v;
org.apache.activeio.journal.RecordLocation v;
org.apache.activemq.broker.ConnectionContext v;
java.lang.String v, v;
boolean v, v, v;
org.apache.activemq.command.MessageAck v;
org.slf4j.Logger v, v, v;
org.apache.activemq.command.MessageId v, v;
java.util.Set v;
org.apache.activemq.store.journal.JournalMessageStore$2 v;
org.apache.activemq.command.JournalQueueAck v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
org.apache.activemq.transaction.Transaction v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.MessageAck;
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
v = new org.apache.activemq.command.JournalQueueAck;
specialinvoke v.<org.apache.activemq.command.JournalQueueAck: void <init>()>();
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
virtualinvoke v.<org.apache.activemq.command.JournalQueueAck: void setDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
virtualinvoke v.<org.apache.activemq.command.JournalQueueAck: void setMessageAck(org.apache.activemq.command.MessageAck)>(v);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: boolean isResponseRequired()>();
v = virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: org.apache.activeio.journal.RecordLocation writeCommand(org.apache.activemq.command.DataStructure,boolean)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isInTransaction()>();
if v != 0 goto label;
if v == 0 goto label;
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,org.apache.activeio.journal.RecordLocation)>(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[])>("Journalled message remove for: \u, at: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
virtualinvoke v.<org.apache.activemq.store.journal.JournalMessageStore: void removeMessage(org.apache.activemq.command.MessageAck,org.apache.activeio.journal.RecordLocation)>(v, v);
goto label;
label:
if v == 0 goto label;
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,org.apache.activeio.journal.RecordLocation)>(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[])>("Journalled transacted message remove for: \u, at: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
entermonitor v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Set inFlightTxLocations>;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalTransactionStore transactionStore>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalTransactionStore: void removeMessage(org.apache.activemq.store.journal.JournalMessageStore,org.apache.activemq.command.MessageAck,org.apache.activeio.journal.RecordLocation)>(v, v, v);
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.transaction.Transaction getTransaction()>();
v = new org.apache.activemq.store.journal.JournalMessageStore$2;
specialinvoke v.<org.apache.activemq.store.journal.JournalMessageStore$2: void <init>(org.apache.activemq.store.journal.JournalMessageStore,boolean,org.apache.activemq.command.MessageAck,org.apache.activeio.journal.RecordLocation)>(v, v, v, v);
virtualinvoke v.<org.apache.activemq.transaction.Transaction: void addSynchronization(org.apache.activemq.transaction.Synchronization)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
final void removeMessage(org.apache.activemq.command.MessageAck, org.apache.activeio.journal.RecordLocation)
{
java.lang.Throwable v;
org.apache.activemq.command.MessageAck v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v;
org.apache.activeio.journal.RecordLocation v;
java.util.List v;
java.util.Map v;
java.lang.Object v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.command.MessageAck;
v := @parameter: org.apache.activeio.journal.RecordLocation;
entermonitor v;
label:
v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activeio.journal.RecordLocation lastLocation> = v;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map messages>;
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.journal.JournalMessageStore: java.util.List messageAcks>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
virtualinvoke v.<org.apache.activemq.command.Message: int decrementReferenceCount()>();
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void replayRemoveMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.MessageAck)
{
java.lang.Throwable v;
org.apache.activemq.store.MessageStore v, v;
org.apache.activemq.command.MessageAck v;
org.slf4j.Logger v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
java.lang.String v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.MessageAck;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = interfaceinvoke v.<org.apache.activemq.store.MessageStore: org.apache.activemq.command.Message getMessage(org.apache.activemq.command.MessageId)>(v);
if v == null goto label;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.MessageAck)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.lang.Throwable)>(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[])>("Could not replay acknowledge for message \'\u0001\'.  Message may have already been acknowledged. reason: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activeio.journal.RecordLocation checkpoint() throws java.io.IOException
{
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activeio.journal.RecordLocation v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v = virtualinvoke v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activeio.journal.RecordLocation checkpoint(org.apache.activemq.util.Callback)>(null);
return v;
}
public org.apache.activeio.journal.RecordLocation checkpoint(org.apache.activemq.util.Callback) throws java.io.IOException
{
java.lang.Throwable v, v, v;
org.apache.activemq.util.TransactionTemplate v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activeio.journal.RecordLocation v;
java.util.ArrayList v, v;
java.util.LinkedHashMap v;
java.util.Map v;
int v, v;
org.apache.activemq.util.Callback v;
java.util.Set v;
org.apache.activemq.store.journal.JournalMessageStore$3 v;
java.util.List v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
java.lang.Object v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.util.Callback;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: int getMaxCheckpointMessageAddSize()>();
entermonitor v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map messages>;
v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map cpAddedMessageIds> = v;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.List messageAcks>;
v = new java.util.ArrayList;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Set inFlightTxLocations>;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map messages> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.List messageAcks> = v;
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.util.TransactionTemplate transactionTemplate>;
v = new org.apache.activemq.store.journal.JournalMessageStore$3;
specialinvoke v.<org.apache.activemq.store.journal.JournalMessageStore$3: void <init>(org.apache.activemq.store.journal.JournalMessageStore,int,java.util.List,org.apache.activemq.util.Callback)>(v, v, v, v);
virtualinvoke v.<org.apache.activemq.util.TransactionTemplate: void run(org.apache.activemq.util.Callback)>(v);
entermonitor v;
label:
v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map cpAddedMessageIds> = null;
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 0 goto label;
staticinvoke <java.util.Collections: void sort(java.util.List)>(v);
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
return v;
label:
entermonitor v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activeio.journal.RecordLocation lastLocation>;
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;
catch java.lang.Throwable from label to label with label;
}
public org.apache.activemq.command.Message getMessage(org.apache.activemq.command.MessageId) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v;
org.apache.activemq.command.Message v;
java.util.Map v, v, v;
java.lang.Object v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.command.MessageId;
entermonitor v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map messages>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map cpAddedMessageIds>;
if v == null goto label;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: java.util.Map cpAddedMessageIds>;
interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v == null goto label;
return v;
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
v = interfaceinvoke v.<org.apache.activemq.store.MessageStore: org.apache.activemq.command.Message getMessage(org.apache.activemq.command.MessageId)>(v);
return v;
catch java.lang.Throwable from label to label with label;
}
public void recover(org.apache.activemq.store.MessageRecoveryListener) throws java.lang.Exception
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
org.apache.activemq.store.MessageRecoveryListener v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.store.MessageRecoveryListener;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: void checkpoint(boolean,boolean)>(1, 1);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void recover(org.apache.activemq.store.MessageRecoveryListener)>(v);
return;
}
public void start() throws java.lang.Exception
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
org.apache.activemq.usage.MemoryUsage v, v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.usage.MemoryUsage memoryUsage>;
if v == null goto label;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void addUsageListener(org.apache.activemq.usage.UsageListener)>(v);
label:
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void start()>();
return;
}
public void stop() throws java.lang.Exception
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
org.apache.activemq.usage.MemoryUsage v, v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void stop()>();
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.usage.MemoryUsage memoryUsage>;
if v == null goto label;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void removeUsageListener(org.apache.activemq.usage.UsageListener)>(v);
label:
return;
}
public org.apache.activemq.store.MessageStore getLongTermMessageStore()
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
return v;
}
public void removeAllMessages(org.apache.activemq.broker.ConnectionContext) throws java.io.IOException
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: void checkpoint(boolean,boolean)>(1, 1);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void removeAllMessages(org.apache.activemq.broker.ConnectionContext)>(v);
return;
}
public void addMessageReference(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.MessageId, long, java.lang.String) throws java.io.IOException
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v;
java.io.IOException v;
long v;
java.lang.String v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.MessageId;
v := @parameter: long;
v := @parameter: java.lang.String;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("The journal does not support message references.");
throw v;
}
public java.lang.String getMessageReference(org.apache.activemq.command.MessageId) throws java.io.IOException
{
java.io.IOException v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.command.MessageId;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("The journal does not support message references.");
throw v;
}
public int getMessageCount() throws java.io.IOException
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
int v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: void checkpoint(boolean,boolean)>(1, 1);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
v = interfaceinvoke v.<org.apache.activemq.store.MessageStore: int getMessageCount()>();
return v;
}
public long getMessageSize() throws java.io.IOException
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
long v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: void checkpoint(boolean,boolean)>(1, 1);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
v = interfaceinvoke v.<org.apache.activemq.store.MessageStore: long getMessageSize()>();
return v;
}
public void recoverNextMessages(int, org.apache.activemq.store.MessageRecoveryListener) throws java.lang.Exception
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
int v;
org.apache.activemq.store.MessageRecoveryListener v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: int;
v := @parameter: org.apache.activemq.store.MessageRecoveryListener;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: void checkpoint(boolean,boolean)>(1, 1);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void recoverNextMessages(int,org.apache.activemq.store.MessageRecoveryListener)>(v, v);
return;
}
public void resetBatching()
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void resetBatching()>();
return;
}
public void setBatch(org.apache.activemq.command.MessageId) throws java.lang.Exception
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.store.journal.JournalMessageStore v;
org.apache.activemq.command.MessageId v;
org.apache.activemq.store.journal.JournalPersistenceAdapter v;
v := @this: org.apache.activemq.store.journal.JournalMessageStore;
v := @parameter: org.apache.activemq.command.MessageId;
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.journal.JournalPersistenceAdapter peristenceAdapter>;
virtualinvoke v.<org.apache.activemq.store.journal.JournalPersistenceAdapter: void checkpoint(boolean,boolean)>(1, 1);
v = v.<org.apache.activemq.store.journal.JournalMessageStore: org.apache.activemq.store.MessageStore longTermStore>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void setBatch(org.apache.activemq.command.MessageId)>(v);
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/store/journal/JournalMessageStore;");
<org.apache.activemq.store.journal.JournalMessageStore: org.slf4j.Logger LOG> = v;
return;
}
}