public class org.apache.activemq.store.jdbc.JDBCMessageStore extends org.apache.activemq.store.AbstractMessageStore
{
private static final org.slf4j.Logger LOG;
protected final org.apache.activemq.wireformat.WireFormat wireFormat;
protected final org.apache.activemq.store.jdbc.JDBCAdapter adapter;
protected final org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter;
protected org.apache.activemq.ActiveMQMessageAudit audit;
protected final java.util.LinkedList pendingAdditions;
protected final java.util.TreeMap rolledBackAcks;
final long[] perPriorityLastRecovered;
public void <init>(org.apache.activemq.store.jdbc.JDBCPersistenceAdapter, org.apache.activemq.store.jdbc.JDBCAdapter, org.apache.activemq.wireformat.WireFormat, org.apache.activemq.command.ActiveMQDestination, org.apache.activemq.ActiveMQMessageAudit) throws java.io.IOException
{
org.apache.activemq.broker.BrokerService v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.wireformat.WireFormat v;
org.apache.activemq.command.ActiveMQDestination v;
long[] v;
java.util.TreeMap v;
org.apache.activemq.ActiveMQMessageAudit v;
java.util.LinkedList v;
boolean v, v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter;
v := @parameter: org.apache.activemq.store.jdbc.JDBCAdapter;
v := @parameter: org.apache.activemq.wireformat.WireFormat;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: org.apache.activemq.ActiveMQMessageAudit;
specialinvoke v.<org.apache.activemq.store.AbstractMessageStore: void <init>(org.apache.activemq.command.ActiveMQDestination)>(v);
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions> = v;
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.TreeMap rolledBackAcks> = v;
v = newarray (long)[10];
v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered> = v;
v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter> = v;
v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter> = v;
v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.wireformat.WireFormat wireFormat> = v;
v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.ActiveMQMessageAudit audit> = v;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean isQueue()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.broker.BrokerService getBrokerService()>();
v = virtualinvoke v.<org.apache.activemq.broker.BrokerService: boolean shouldRecordVirtualDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
if v == 0 goto label;
specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: void recordDestinationCreation(org.apache.activemq.command.ActiveMQDestination)>(v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: void resetBatching()>();
return;
}
private void recordDestinationCreation(org.apache.activemq.command.ActiveMQDestination) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCAdapter v, v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
java.io.IOException v;
long v;
org.apache.activemq.command.ActiveMQDestination v;
java.sql.SQLException v;
byte v;
org.apache.activemq.store.jdbc.TransactionContext v;
java.lang.String v, v, v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext()>();
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: long doGetLastAckedDurableSubscriberMessageId(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.ActiveMQDestination,java.lang.String,java.lang.String)>(v, v, v, v);
v = v cmp 0L;
if v >= 0 goto label;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doRecordDestination(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.ActiveMQDestination)>(v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.ActiveMQDestination,java.sql.SQLException)>(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[])>("Failed to record destination: \u. Reason: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void addMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.Message) throws java.io.IOException
{
byte[] v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
byte v, v;
java.lang.Long v, v, v;
org.apache.activemq.store.jdbc.TransactionContext v;
org.apache.activemq.store.IndexListener v, v;
org.apache.activemq.util.ByteSequence v;
boolean v, v, v;
org.apache.activemq.command.MessageId v, v;
org.apache.activemq.wireformat.WireFormat v;
org.apache.activemq.command.ActiveMQDestination v, v;
java.lang.Throwable v, v;
long v, v;
java.sql.SQLException v;
org.apache.activemq.ActiveMQMessageAudit v, v;
org.apache.activemq.command.XATransactionId v, v;
java.lang.String v, v, v, v;
java.util.LinkedList v, v, v;
org.slf4j.Logger v, v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
java.io.IOException v, v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore$1 v;
org.apache.activemq.store.jdbc.JDBCMessageStore$2 v;
org.apache.activemq.store.IndexListener$MessageContext v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
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 = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.ActiveMQMessageAudit audit>;
if v == null goto label;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.ActiveMQMessageAudit audit>;
v = virtualinvoke v.<org.apache.activemq.ActiveMQMessageAudit: boolean isDuplicate(org.apache.activemq.broker.region.MessageReference)>(v);
if v == 0 goto label;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getPhysicalName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.apache.activemq.command.MessageId)>(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[])>("\u ignoring duplicated (add) message, already stored: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
return;
label:
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.command.XATransactionId getXid()>();
goto label;
label:
v = null;
label:
v = v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.wireformat.WireFormat wireFormat>;
v = interfaceinvoke v.<org.apache.activemq.wireformat.WireFormat: org.apache.activemq.util.ByteSequence marshal(java.lang.Object)>(v);
v = staticinvoke <org.apache.activemq.util.ByteSequenceData: byte[] toByteArray(org.apache.activemq.util.ByteSequence)>(v);
label:
goto label;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.io.IOException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext(org.apache.activemq.broker.ConnectionContext)>(v);
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: long getNextSequenceId()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
virtualinvoke v.<org.apache.activemq.command.MessageId: void setEntryLocator(java.lang.Object)>(v);
if v != null goto label;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
virtualinvoke v.<java.util.LinkedList: boolean add(java.lang.Object)>(v);
v = new org.apache.activemq.store.jdbc.JDBCMessageStore$1;
specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore$1: void <init>(org.apache.activemq.store.jdbc.JDBCMessageStore,org.apache.activemq.command.Message,long)>(v, v, v);
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void onCompletion(java.lang.Runnable)>(v);
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.IndexListener indexListener>;
if v == null goto label;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.IndexListener indexListener>;
v = new org.apache.activemq.store.IndexListener$MessageContext;
v = new org.apache.activemq.store.jdbc.JDBCMessageStore$2;
specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore$2: void <init>(org.apache.activemq.store.jdbc.JDBCMessageStore,long)>(v, v);
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, v);
interfaceinvoke v.<org.apache.activemq.store.IndexListener: void onAdd(org.apache.activemq.store.IndexListener$MessageContext)>(v);
goto label;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
virtualinvoke v.<java.util.LinkedList: boolean remove(java.lang.Object)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.Message: long getExpiration()>();
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: boolean isPrioritizedMessages()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: byte getPriority()>();
goto label;
label:
v = 0;
label:
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doAddMessage(org.apache.activemq.store.jdbc.TransactionContext,long,org.apache.activemq.command.MessageId,org.apache.activemq.command.ActiveMQDestination,byte[],long,byte,org.apache.activemq.command.XATransactionId)>(v, v, v, v, v, v, v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.sql.SQLException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
if v != null goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: byte getPriority()>();
virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: void onAdd(org.apache.activemq.command.Message,long,byte)>(v, v, 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.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private long minPendingSequeunceId()
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
long v, v, v;
org.apache.activemq.util.LongSequenceGenerator v;
java.lang.Object v;
java.util.LinkedList v, v, v;
boolean v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions>;
v = virtualinvoke v.<java.util.LinkedList: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions>;
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object get(int)>(0);
v = virtualinvoke v.<java.lang.Long: long longValue()>();
exitmonitor v;
label:
return v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.util.LongSequenceGenerator sequenceGenerator>;
v = virtualinvoke v.<org.apache.activemq.util.LongSequenceGenerator: long getLastSequenceId()>();
v = v + 1L;
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 void updateMessage(org.apache.activemq.command.Message) throws java.io.IOException
{
java.lang.Throwable v;
byte[] v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.command.MessageId v, v;
org.apache.activemq.wireformat.WireFormat v;
java.io.IOException v;
org.apache.activemq.command.ActiveMQDestination v;
java.sql.SQLException v;
org.apache.activemq.command.Message v;
org.apache.activemq.store.jdbc.TransactionContext v;
java.lang.String v;
org.apache.activemq.util.ByteSequence v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.command.Message;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext()>();
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.wireformat.WireFormat wireFormat>;
v = interfaceinvoke v.<org.apache.activemq.wireformat.WireFormat: org.apache.activemq.util.ByteSequence marshal(java.lang.Object)>(v);
v = staticinvoke <org.apache.activemq.util.ByteSequenceData: byte[] toByteArray(org.apache.activemq.util.ByteSequence)>(v);
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doUpdateMessage(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.ActiveMQDestination,org.apache.activemq.command.MessageId,byte[])>(v, v, v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
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.sql.SQLException)>(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[])>("Failed to update message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
protected void onAdd(org.apache.activemq.command.Message, long, byte)
{
org.apache.activemq.command.Message v;
byte v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
long v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.command.Message;
v := @parameter: long;
v := @parameter: byte;
return;
}
public void addMessageReference(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.MessageId, long, java.lang.String) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.command.MessageId v;
java.io.IOException v;
long v, v;
org.apache.activemq.command.ActiveMQDestination v;
java.sql.SQLException v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.store.jdbc.TransactionContext v;
java.lang.String v, v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.MessageId;
v := @parameter: long;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext(org.apache.activemq.broker.ConnectionContext)>(v);
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: long getNextSequenceId()>();
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doAddMessageReference(org.apache.activemq.store.jdbc.TransactionContext,long,org.apache.activemq.command.MessageId,org.apache.activemq.command.ActiveMQDestination,long,java.lang.String)>(v, v, v, v, v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.sql.SQLException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return;
catch java.sql.SQLException 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;
byte[] v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
java.sql.SQLException v;
org.apache.activemq.store.jdbc.TransactionContext v;
java.lang.String v, v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.command.MessageId v;
org.apache.activemq.wireformat.WireFormat v;
java.io.IOException v, v, v;
java.lang.Object v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.command.MessageId;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext()>();
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: byte[] doGetMessage(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.MessageId)>(v, v);
if v != null goto label;
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
return null;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.wireformat.WireFormat wireFormat>;
v = new org.apache.activemq.util.ByteSequence;
specialinvoke v.<org.apache.activemq.util.ByteSequence: void <init>(byte[])>(v);
v = interfaceinvoke v.<org.apache.activemq.wireformat.WireFormat: java.lang.Object unmarshal(org.apache.activemq.util.ByteSequence)>(v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
return v;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.io.IOException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.sql.SQLException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.sql.SQLException from label to label with label;
catch java.sql.SQLException 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.String getMessageReference(org.apache.activemq.command.MessageId) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.command.MessageId v;
java.io.IOException v, v, v;
long v;
java.sql.SQLException v;
org.apache.activemq.store.jdbc.TransactionContext v;
java.lang.String v, v, v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.command.MessageId;
v = virtualinvoke v.<org.apache.activemq.command.MessageId: long getBrokerSequenceId()>();
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext()>();
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: java.lang.String doGetMessageReference(org.apache.activemq.store.jdbc.TransactionContext,long)>(v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
return v;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.io.IOException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,java.sql.SQLException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
catch java.io.IOException from label to label with label;
catch java.sql.SQLException from label to label with label;
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.jdbc.JDBCAdapter v;
long v, v, v;
java.sql.SQLException v;
org.apache.activemq.broker.ConnectionContext v;
long[] v;
byte v;
org.apache.activemq.store.jdbc.TransactionContext v;
org.apache.activemq.command.XATransactionId v;
java.lang.String v;
org.apache.activemq.command.MessageAck v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.command.MessageId v, v, v, v, v;
java.io.IOException v;
org.apache.activemq.command.ActiveMQDestination v;
java.lang.Object v, v, v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.MessageAck;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: java.lang.Object getFutureOrSequenceLong()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: java.lang.Object getFutureOrSequenceLong()>();
v = virtualinvoke v.<java.lang.Long: long longValue()>();
v = v cmp 0L;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: java.lang.Object getFutureOrSequenceLong()>();
v = virtualinvoke v.<java.lang.Long: long longValue()>();
goto label;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: org.apache.activemq.command.MessageId getLastMessageId()>();
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: long[] getStoreSequenceIdForMessageId(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.MessageId,org.apache.activemq.command.ActiveMQDestination)>(v, v, v);
v = v[0];
label:
v = v;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext(org.apache.activemq.broker.ConnectionContext)>(v);
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.command.XATransactionId getXid()>();
goto label;
label:
v = null;
label:
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doRemoveMessage(org.apache.activemq.store.jdbc.TransactionContext,long,org.apache.activemq.command.XATransactionId)>(v, v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
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.sql.SQLException)>(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[])>("Failed to broker message: \u in container: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void recover(org.apache.activemq.store.MessageRecoveryListener) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.store.jdbc.JDBCMessageStore$3 v;
java.io.IOException v;
org.apache.activemq.command.ActiveMQDestination v;
java.sql.SQLException v;
org.apache.activemq.store.jdbc.TransactionContext v;
java.lang.String v;
org.apache.activemq.store.MessageRecoveryListener v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.store.MessageRecoveryListener;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext()>();
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = new org.apache.activemq.store.jdbc.JDBCMessageStore$3;
specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore$3: void <init>(org.apache.activemq.store.jdbc.JDBCMessageStore,org.apache.activemq.store.MessageRecoveryListener)>(v, v);
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doRecover(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.ActiveMQDestination,org.apache.activemq.store.jdbc.JDBCMessageRecoveryListener)>(v, v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.sql.SQLException)>(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[])>("Failed to recover container. Reason: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void removeAllMessages(org.apache.activemq.broker.ConnectionContext) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
java.io.IOException v;
org.apache.activemq.command.ActiveMQDestination v;
java.sql.SQLException v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.store.jdbc.TransactionContext v;
java.lang.String v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext(org.apache.activemq.broker.ConnectionContext)>(v);
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doRemoveAllMessages(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.ActiveMQDestination)>(v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.sql.SQLException)>(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[])>("Failed to broker remove all messages: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public int getMessageCount() throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
java.io.IOException v;
org.apache.activemq.command.ActiveMQDestination v, v;
java.sql.SQLException v;
org.apache.activemq.store.jdbc.TransactionContext v;
int v;
java.lang.String v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext()>();
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: int doGetMessageCount(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.ActiveMQDestination)>(v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.ActiveMQDestination,java.sql.SQLException)>(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[])>("Failed to get Message Count: \u. Reason: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Exception)>(v, v);
throw v;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return v;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void recoverNextMessages(int, org.apache.activemq.store.MessageRecoveryListener) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.store.jdbc.JDBCAdapter v;
long v, v;
java.sql.SQLException v;
long[] v, v;
org.apache.activemq.store.jdbc.TransactionContext v;
int v, v, v;
java.lang.String v, v;
boolean v, v;
org.slf4j.Logger v, v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.store.jdbc.JDBCMessageStore$4 v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.store.MessageRecoveryListener v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: int;
v := @parameter: org.apache.activemq.store.MessageRecoveryListener;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: org.apache.activemq.store.jdbc.TransactionContext getTransactionContext()>();
label:
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = staticinvoke <java.util.Arrays: java.lang.String toString(long[])>(v);
v = specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long minPendingSequeunceId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.store.jdbc.JDBCMessageStore,java.lang.String,long)>(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[])>("\u recoverNext lastRecovered:\u, minPending:\u0001");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
label:
v = specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: int recoverRolledBackAcks(int,org.apache.activemq.store.MessageRecoveryListener)>(v, v);
v = v - v;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCAdapter adapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long minPendingSequeunceId()>();
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: boolean isPrioritizedMessages()>();
v = new org.apache.activemq.store.jdbc.JDBCMessageStore$4;
specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore$4: void <init>(org.apache.activemq.store.jdbc.JDBCMessageStore,org.apache.activemq.store.MessageRecoveryListener)>(v, v);
interfaceinvoke v.<org.apache.activemq.store.jdbc.JDBCAdapter: void doRecoverNextMessages(org.apache.activemq.store.jdbc.TransactionContext,org.apache.activemq.command.ActiveMQDestination,long[],long,int,boolean,org.apache.activemq.store.jdbc.JDBCMessageRecoveryListener)>(v, v, v, v, v, v, v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: void log(java.lang.String,java.sql.SQLException)>("JDBC Failure: ", v);
label:
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.TransactionContext: void close()>();
throw v;
label:
return;
catch java.sql.SQLException 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 void trackRollbackAck(org.apache.activemq.command.Message)
{
java.lang.Throwable v;
org.apache.activemq.command.Message v;
java.util.TreeMap v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.command.MessageId v;
java.lang.Object v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.command.Message;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.TreeMap rolledBackAcks>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.TreeMap rolledBackAcks>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: java.lang.Object getEntryLocator()>();
virtualinvoke v.<java.util.TreeMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private int recoverRolledBackAcks(int, org.apache.activemq.store.MessageRecoveryListener) throws java.lang.Exception
{
java.lang.Throwable v;
long v, v;
java.util.ArrayList v;
byte v, v;
int v, v;
boolean v, v, v;
java.util.Iterator v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
java.util.Set v;
java.util.TreeMap v, v, v, v;
java.lang.Object v, v, v, v, v, v, v;
org.apache.activemq.store.MessageRecoveryListener v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: int;
v := @parameter: org.apache.activemq.store.MessageRecoveryListener;
v = 0;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.TreeMap rolledBackAcks>;
entermonitor v;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.TreeMap rolledBackAcks>;
v = virtualinvoke v.<java.util.TreeMap: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.TreeMap rolledBackAcks>;
v = virtualinvoke v.<java.util.TreeMap: java.util.Set entrySet()>();
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = virtualinvoke v.<java.lang.Long: long longValue()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: byte getPriority()>();
v = specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long lastRecovered(int)>(v);
v = v cmp v;
if v > 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<org.apache.activemq.store.MessageRecoveryListener: boolean recoverMessage(org.apache.activemq.command.Message)>(v);
v = v + 1;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
if v != v goto label;
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
goto label;
label:
v = virtualinvoke v.<java.util.ArrayList: 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 = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.TreeMap rolledBackAcks>;
virtualinvoke v.<java.util.TreeMap: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private long lastRecovered(int)
{
long[] v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
int v, v;
long v;
boolean v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: int;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: boolean isPrioritizedMessages()>();
if v == 0 goto label;
v = v;
goto label;
label:
v = 0;
label:
v = v[v];
return v;
}
private void trackLastRecovered(long, int)
{
long[] v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
int v, v;
long v;
boolean v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: long;
v := @parameter: int;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: boolean isPrioritizedMessages()>();
if v == 0 goto label;
v = v;
goto label;
label:
v = 0;
label:
v[v] = v;
return;
}
public void resetBatching()
{
long[] v;
org.slf4j.Logger v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = staticinvoke <java.util.Arrays: java.lang.String toString(long[])>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.store.jdbc.JDBCMessageStore,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[])>("\u resetBatching. last recovered: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
label:
specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: void setLastRecovered(long)>(-1L);
return;
}
private void setLastRecovered(long)
{
long[] v, v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
int v, v;
long v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: long;
v = 0;
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = lengthof v;
if v >= v goto label;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v[v] = v;
v = v + 1;
goto label;
label:
return;
}
public void setBatch(org.apache.activemq.command.MessageId)
{
long v;
long[] v, v, v;
java.lang.String v, v, v, v;
boolean v, v;
org.slf4j.Logger v, v, v, v;
org.apache.activemq.store.jdbc.JDBCPersistenceAdapter v;
org.apache.activemq.store.jdbc.JDBCMessageStore v;
org.apache.activemq.command.MessageId v;
java.io.IOException v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: org.apache.activemq.command.MessageId;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = staticinvoke <java.util.Arrays: java.lang.String toString(long[])>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.store.jdbc.JDBCMessageStore,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[])>("\u setBatch: last recovered: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
label:
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.store.jdbc.JDBCPersistenceAdapter persistenceAdapter>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCPersistenceAdapter: long[] getStoreSequenceIdForMessageId(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.MessageId,org.apache.activemq.command.ActiveMQDestination)>(null, v, v);
v = v[0];
specialinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: void setLastRecovered(long)>(v);
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.store.jdbc.JDBCMessageStore: void resetBatching()>();
label:
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: long[] perPriorityLastRecovered>;
v = staticinvoke <java.util.Arrays: java.lang.String toString(long[])>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.store.jdbc.JDBCMessageStore,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[])>("\u setBatch: new last recovered: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>(v);
label:
return;
catch java.io.IOException from label to label with label;
}
public void setPrioritizedMessages(boolean)
{
org.apache.activemq.store.jdbc.JDBCMessageStore v;
boolean v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v := @parameter: boolean;
specialinvoke v.<org.apache.activemq.store.AbstractMessageStore: void setPrioritizedMessages(boolean)>(v);
return;
}
public java.lang.String toString()
{
org.apache.activemq.store.jdbc.JDBCMessageStore v;
int v;
java.lang.String v, v;
java.util.LinkedList v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.store.jdbc.JDBCMessageStore;
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getPhysicalName()>();
v = v.<org.apache.activemq.store.jdbc.JDBCMessageStore: java.util.LinkedList pendingAdditions>;
v = virtualinvoke v.<java.util.LinkedList: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(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[])>("\u,pendingSize:\u0001");
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/store/jdbc/JDBCMessageStore;");
<org.apache.activemq.store.jdbc.JDBCMessageStore: org.slf4j.Logger LOG> = v;
return;
}
}