public class org.apache.activemq.broker.region.Queue extends org.apache.activemq.broker.region.BaseDestination implements org.apache.activemq.thread.Task, org.apache.activemq.usage.UsageListener, org.apache.activemq.store.IndexListener
{
protected static final org.slf4j.Logger LOG;
protected final org.apache.activemq.thread.TaskRunnerFactory taskFactory;
protected org.apache.activemq.thread.TaskRunner taskRunner;
private final java.util.concurrent.locks.ReentrantReadWriteLock consumersLock;
protected final java.util.List consumers;
private final java.util.concurrent.locks.ReentrantReadWriteLock messagesLock;
protected org.apache.activemq.broker.region.cursors.PendingMessageCursor messages;
private final java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock;
private final org.apache.activemq.broker.region.cursors.PendingList pagedInMessages;
private final java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock;
protected org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList;
private java.util.concurrent.atomic.AtomicInteger pendingSends;
private org.apache.activemq.broker.region.group.MessageGroupMap messageGroupOwners;
private org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy;
private org.apache.activemq.broker.region.group.MessageGroupMapFactory messageGroupMapFactory;
final java.util.concurrent.locks.Lock sendLock;
private java.util.concurrent.ExecutorService executor;
private final java.util.Map messagesWaitingForSpace;
private boolean useConsumerPriority;
private boolean strictOrderDispatch;
private final org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector;
private boolean optimizedDispatch;
private boolean iterationRunning;
private boolean firstConsumer;
private int timeBeforeDispatchStarts;
private int consumersBeforeDispatchStarts;
private java.util.concurrent.CountDownLatch consumersBeforeStartsLatch;
private final java.util.concurrent.atomic.AtomicLong pendingWakeups;
private boolean allConsumersExclusiveByDefault;
private volatile boolean resetNeeded;
private final java.lang.Runnable sendMessagesWaitingForSpaceTask;
private final java.util.concurrent.atomic.AtomicBoolean expiryTaskInProgress;
private final java.lang.Runnable expireMessagesWork;
private final java.lang.Runnable expireMessagesTask;
private final java.lang.Object iteratingMutex;
java.util.concurrent.DelayQueue flowControlTimeoutMessages;
private final org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask flowControlTimeoutTask;
private final java.util.Comparator orderedCompare;
java.util.concurrent.ConcurrentLinkedQueue browserSubscriptions;
private volatile javax.jms.ResourceAllocationException sendMemAllocationException;
private final java.util.LinkedList indexOrderedCursorUpdates;
public boolean singlePendingSend()
{
java.util.concurrent.atomic.AtomicInteger v;
org.apache.activemq.broker.region.Queue v;
int v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicInteger pendingSends>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v > 1 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void <init>(org.apache.activemq.broker.BrokerService, org.apache.activemq.command.ActiveMQDestination, org.apache.activemq.store.MessageStore, org.apache.activemq.broker.region.DestinationStatistics, org.apache.activemq.thread.TaskRunnerFactory) throws java.lang.Exception
{
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v;
org.apache.activemq.broker.region.policy.RoundRobinDispatchPolicy v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask v;
java.util.LinkedHashMap v;
org.apache.activemq.broker.region.group.CachedMessageGroupMapFactory v;
java.util.concurrent.atomic.AtomicInteger v;
java.util.concurrent.DelayQueue v;
org.apache.activemq.broker.region.cursors.OrderedPendingList v;
java.util.LinkedList v;
org.apache.activemq.store.MessageStore v;
org.apache.activemq.broker.BrokerService v;
java.util.concurrent.locks.ReentrantLock v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.region.Queue$1 v;
org.apache.activemq.broker.region.Queue$2 v;
org.apache.activemq.broker.region.Queue$3 v;
org.apache.activemq.broker.region.Queue$4 v;
org.apache.activemq.command.ActiveMQDestination v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.thread.TaskRunnerFactory v;
java.lang.Object v;
org.apache.activemq.broker.region.QueueDispatchSelector v;
org.apache.activemq.broker.region.DestinationStatistics v;
java.util.concurrent.ConcurrentLinkedQueue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.BrokerService;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: org.apache.activemq.store.MessageStore;
v := @parameter: org.apache.activemq.broker.region.DestinationStatistics;
v := @parameter: org.apache.activemq.thread.TaskRunnerFactory;
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void <init>(org.apache.activemq.broker.BrokerService,org.apache.activemq.store.MessageStore,org.apache.activemq.command.ActiveMQDestination,org.apache.activemq.broker.region.DestinationStatistics)>(v, v, v, v);
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(50);
v.<org.apache.activemq.broker.region.Queue: java.util.List consumers> = v;
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock> = v;
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock> = v;
v = new org.apache.activemq.broker.region.cursors.OrderedPendingList;
specialinvoke v.<org.apache.activemq.broker.region.cursors.OrderedPendingList: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages> = v;
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock> = v;
v = new org.apache.activemq.broker.region.cursors.QueueDispatchPendingList;
specialinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicInteger pendingSends> = v;
v = new org.apache.activemq.broker.region.policy.RoundRobinDispatchPolicy;
specialinvoke v.<org.apache.activemq.broker.region.policy.RoundRobinDispatchPolicy: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy> = v;
v = new org.apache.activemq.broker.region.group.CachedMessageGroupMapFactory;
specialinvoke v.<org.apache.activemq.broker.region.group.CachedMessageGroupMapFactory: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMapFactory messageGroupMapFactory> = v;
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.Lock sendLock> = v;
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.Map messagesWaitingForSpace> = v;
v.<org.apache.activemq.broker.region.Queue: boolean useConsumerPriority> = 1;
v.<org.apache.activemq.broker.region.Queue: boolean strictOrderDispatch> = 0;
v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch> = 0;
v.<org.apache.activemq.broker.region.Queue: boolean iterationRunning> = 0;
v.<org.apache.activemq.broker.region.Queue: boolean firstConsumer> = 0;
v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts> = 0;
v.<org.apache.activemq.broker.region.Queue: int consumersBeforeDispatchStarts> = 0;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicLong pendingWakeups> = v;
v.<org.apache.activemq.broker.region.Queue: boolean allConsumersExclusiveByDefault> = 0;
v = new org.apache.activemq.broker.region.Queue$1;
specialinvoke v.<org.apache.activemq.broker.region.Queue$1: void <init>(org.apache.activemq.broker.region.Queue)>(v);
v.<org.apache.activemq.broker.region.Queue: java.lang.Runnable sendMessagesWaitingForSpaceTask> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicBoolean expiryTaskInProgress> = v;
v = new org.apache.activemq.broker.region.Queue$2;
specialinvoke v.<org.apache.activemq.broker.region.Queue$2: void <init>(org.apache.activemq.broker.region.Queue)>(v);
v.<org.apache.activemq.broker.region.Queue: java.lang.Runnable expireMessagesWork> = v;
v = new org.apache.activemq.broker.region.Queue$3;
specialinvoke v.<org.apache.activemq.broker.region.Queue$3: void <init>(org.apache.activemq.broker.region.Queue)>(v);
v.<org.apache.activemq.broker.region.Queue: java.lang.Runnable expireMessagesTask> = v;
v = new java.lang.Object;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.lang.Object iteratingMutex> = v;
v = new java.util.concurrent.DelayQueue;
specialinvoke v.<java.util.concurrent.DelayQueue: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.DelayQueue flowControlTimeoutMessages> = v;
v = new org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask;
specialinvoke v.<org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask: void <init>(org.apache.activemq.broker.region.Queue)>(v);
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask flowControlTimeoutTask> = v;
v = new org.apache.activemq.broker.region.Queue$4;
specialinvoke v.<org.apache.activemq.broker.region.Queue$4: void <init>(org.apache.activemq.broker.region.Queue)>(v);
v.<org.apache.activemq.broker.region.Queue: java.util.Comparator orderedCompare> = v;
v = new java.util.concurrent.ConcurrentLinkedQueue;
specialinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ConcurrentLinkedQueue browserSubscriptions> = v;
v.<org.apache.activemq.broker.region.Queue: javax.jms.ResourceAllocationException sendMemAllocationException> = null;
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates> = v;
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.TaskRunnerFactory taskFactory> = v;
v = new org.apache.activemq.broker.region.QueueDispatchSelector;
specialinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: void <init>(org.apache.activemq.command.ActiveMQDestination)>(v);
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector> = v;
if v == null goto label;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void registerIndexListener(org.apache.activemq.store.IndexListener)>(v);
label:
return;
}
public java.util.List getConsumers()
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Queue v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.ArrayList v;
java.util.List v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = new java.util.ArrayList;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public void setPrioritizedMessages(boolean)
{
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v;
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void setPrioritizedMessages(boolean)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: void setPrioritizedMessages(boolean)>(v);
return;
}
public void initialize() throws java.lang.Exception
{
org.apache.activemq.management.CountStatisticImpl v;
org.apache.activemq.usage.MemoryUsage v, v;
org.apache.activemq.usage.SystemUsage v, v, v;
boolean v, v, v, v, v, v, v;
org.apache.activemq.broker.BrokerService v;
org.apache.activemq.broker.region.cursors.StoreQueueCursor v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.region.Queue$BatchMessageRecoveryListener v;
org.apache.activemq.command.ActiveMQDestination v, v;
org.apache.activemq.thread.TaskRunnerFactory v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.DestinationStatistics v;
org.apache.activemq.broker.Broker v, v;
int v, v, v, v, v;
java.lang.String v, v;
org.apache.activemq.broker.region.cursors.VMPendingMessageCursor v;
org.apache.activemq.store.MessageStore v, v, v, v, v;
org.apache.activemq.thread.TaskRunner v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
if v != null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean isTemporary()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v != null goto label;
label:
v = new org.apache.activemq.broker.region.cursors.VMPendingMessageCursor;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isPrioritizedMessages()>();
specialinvoke v.<org.apache.activemq.broker.region.cursors.VMPendingMessageCursor: void <init>(boolean)>(v);
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages> = v;
goto label;
label:
v = new org.apache.activemq.broker.region.cursors.StoreQueueCursor;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
specialinvoke v.<org.apache.activemq.broker.region.cursors.StoreQueueCursor: void <init>(org.apache.activemq.broker.Broker,org.apache.activemq.broker.region.Queue)>(v, v);
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages> = v;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = v instanceof org.apache.activemq.broker.region.cursors.VMPendingMessageCursor;
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.BrokerService brokerService>;
v = virtualinvoke v.<org.apache.activemq.broker.BrokerService: org.apache.activemq.usage.SystemUsage getSystemUsage()>();
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage> = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.MemoryUsage getMemoryUsage()>();
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void setParent(org.apache.activemq.usage.Usage)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.TaskRunnerFactory taskFactory>;
v = v.<org.apache.activemq.broker.region.Queue: 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)>(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[])>("Queue:\u0001");
v = virtualinvoke v.<org.apache.activemq.thread.TaskRunnerFactory: org.apache.activemq.thread.TaskRunner createTaskRunner(org.apache.activemq.thread.Task,java.lang.String)>(v, v);
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.TaskRunner taskRunner> = v;
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void initialize()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setSystemUsage(org.apache.activemq.usage.SystemUsage)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isEnableAudit()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setEnableAudit(boolean)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxAuditDepth()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setMaxAuditDepth(int)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxProducersToAudit()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setMaxProducersToAudit(int)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isUseCache()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setUseCache(boolean)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getCursorMemoryHighWaterMark()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setMemoryUsageHighWaterMark(int)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void start()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
v = interfaceinvoke v.<org.apache.activemq.store.MessageStore: int getMessageCount()>();
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean isRecoveryRequired()>();
if v == 0 goto label;
v = new org.apache.activemq.broker.region.Queue$BatchMessageRecoveryListener;
specialinvoke v.<org.apache.activemq.broker.region.Queue$BatchMessageRecoveryListener: void <init>(org.apache.activemq.broker.region.Queue,int)>(v, v);
label:
virtualinvoke v.<org.apache.activemq.broker.region.Queue$BatchMessageRecoveryListener: void reset()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxPageSize()>();
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void recoverNextMessages(int,org.apache.activemq.store.MessageRecoveryListener)>(v, v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue$BatchMessageRecoveryListener: void processExpired()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue$BatchMessageRecoveryListener: boolean done()>();
if v == 0 goto label;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void add(long)>(v);
label:
return;
}
public void addSubscription(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription) throws java.lang.Exception
{
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v, v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v, v, v;
byte v, v, v;
java.lang.Long v, v, v;
boolean v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.ActiveMQDestination v;
java.util.concurrent.CountDownLatch v, v, v;
java.util.List v;
org.apache.activemq.broker.region.QueueDispatchSelector v, v;
org.apache.activemq.broker.region.DestinationStatistics v, v, v;
java.util.concurrent.ConcurrentLinkedQueue v;
java.lang.Throwable v, v;
java.lang.Object[] v;
org.apache.activemq.broker.region.Subscription v, v;
long v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v;
int v, v, v, v;
java.lang.String v;
org.apache.activemq.command.ConsumerInfo v, v, v, v;
org.slf4j.Logger v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[5];
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v[0] = v;
v[1] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getDequeues()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getDispatched()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[3] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getInflight()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[4] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("{} add sub: {}, dequeues: {}, dispatched: {}, inflight: {}", v);
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void addSubscription(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription)>(v, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: void add(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Destination)>(v, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 0 goto label;
v.<org.apache.activemq.broker.region.Queue: boolean firstConsumer> = 1;
v = v.<org.apache.activemq.broker.region.Queue: int consumersBeforeDispatchStarts>;
if v == 0 goto label;
v = new java.util.concurrent.CountDownLatch;
v = v.<org.apache.activemq.broker.region.Queue: int consumersBeforeDispatchStarts>;
v = v - 1;
specialinvoke v.<java.util.concurrent.CountDownLatch: void <init>(int)>(v);
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.CountDownLatch consumersBeforeStartsLatch> = v;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.CountDownLatch consumersBeforeStartsLatch>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.CountDownLatch consumersBeforeStartsLatch>;
virtualinvoke v.<java.util.concurrent.CountDownLatch: void countDown()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void addToConsumerList(org.apache.activemq.broker.region.Subscription)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isExclusive()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isAllConsumersExclusiveByDefault()>();
if v == 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: org.apache.activemq.broker.region.Subscription getExclusiveConsumer()>();
if v != null goto label;
v = v;
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: byte getPriority()>();
if v == 127 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: byte getPriority()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: byte getPriority()>();
if v <= v goto label;
label:
v = v;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: void setExclusiveConsumer(org.apache.activemq.broker.region.Subscription)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v instanceof org.apache.activemq.broker.region.QueueBrowserSubscription;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: void incrementQueueRef()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ConcurrentLinkedQueue browserSubscriptions>;
virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: boolean add(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch>;
if v != 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void wakeup()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch>;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void wakeup()>();
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void removeSubscription(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription, long) throws java.lang.Exception
{
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v, v;
org.apache.activemq.command.ConsumerId v;
org.apache.activemq.broker.ConnectionContext v;
byte v, v, v, v, v, v, v;
java.lang.Long v, v, v, v, v, v;
org.apache.activemq.broker.BrokerService v, v;
org.apache.activemq.broker.region.QueueDispatchSelector v, v, v;
java.lang.Throwable v, v;
java.lang.Object[] v;
org.apache.activemq.broker.region.group.MessageGroupMap v;
long v, v, v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v;
java.lang.String v;
org.apache.activemq.command.ConsumerInfo v, v, v, v, v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v, v, v;
org.apache.activemq.management.CountStatisticImpl v, v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v;
org.apache.activemq.command.ActiveMQDestination v, v;
java.util.List v, v, v, v;
org.apache.activemq.broker.region.LockOwner v;
org.apache.activemq.broker.region.DestinationStatistics v, v, v;
java.util.concurrent.ConcurrentLinkedQueue v;
org.apache.activemq.broker.region.Subscription v, v, v, v;
org.apache.activemq.broker.region.cursors.OrderedPendingList v;
org.apache.activemq.broker.region.MessageReference v, v;
org.slf4j.Logger v, v;
java.util.Iterator v, v, v, v;
java.lang.Object v, v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: long;
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void removeSubscription(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,long)>(v, v, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[7];
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getDequeues()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[3] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getDispatched()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[4] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getInflight()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[5] = v;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: long getAssignedGroupCount(org.apache.activemq.command.ActiveMQDestination)>(v);
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[6] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("{} remove sub: {}, lastDeliveredSeqId: {}, dequeues: {}, dispatched: {}, inflight: {}, groups: {}", v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: boolean removeFromConsumerList(org.apache.activemq.broker.region.Subscription)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isExclusive()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: org.apache.activemq.broker.region.Subscription getExclusiveConsumer()>();
if v != v goto label;
v = null;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: 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.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isExclusive()>();
if v == 0 goto label;
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: byte getPriority()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: byte getPriority()>();
if v <= v goto label;
label:
v = v;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: void setExclusiveConsumer(org.apache.activemq.broker.region.Subscription)>(v);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isAllConsumersExclusiveByDefault()>();
if v == 0 goto label;
v = null;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: 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()>();
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: byte getPriority()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: byte getPriority()>();
if v <= v goto label;
label:
v = v;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: void setExclusiveConsumer(org.apache.activemq.broker.region.Subscription)>(v);
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: org.apache.activemq.command.ConsumerId getConsumerId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMap getMessageGroupOwners()>();
interfaceinvoke v.<org.apache.activemq.broker.region.group.MessageGroupMap: org.apache.activemq.broker.region.group.MessageGroupSet removeConsumer(org.apache.activemq.command.ConsumerId)>(v);
v = 0;
v = null;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: java.util.List remove(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Destination)>(v, v);
v = v cmp -1L;
if v <= 0 goto label;
v = interfaceinvoke v.<java.util.List: 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.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: long getBrokerSequenceId()>();
v = v cmp v;
if v != 0 goto label;
v = v;
v = 1;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("found lastDeliveredSeqID: {}, message reference: {}", v, v);
label:
v = interfaceinvoke v.<java.util.List: 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.broker.region.Queue: org.apache.activemq.broker.BrokerService brokerService>;
v = virtualinvoke v.<org.apache.activemq.broker.BrokerService: boolean isStopping()>();
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.broker.region.LockOwner getLockOwner()>();
if v != v goto label;
interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: boolean unlock()>();
v = v cmp -2L;
if v != 0 goto label;
interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: void incrementRedeliveryCounter()>();
goto label;
label:
if v == 0 goto label;
interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: void incrementRedeliveryCounter()>();
label:
if v != v goto label;
v = 0;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: boolean isDropped()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: void remove()>();
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = v.<org.apache.activemq.broker.region.Queue: boolean strictOrderDispatch>;
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: void addForRedelivery(java.util.List,boolean)>(v, v);
v = v instanceof org.apache.activemq.broker.region.QueueBrowserSubscription;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: void decrementQueueRef()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ConcurrentLinkedQueue browserSubscriptions>;
virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: boolean remove(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean hasRedeliveries()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.BrokerService brokerService>;
v = virtualinvoke v.<org.apache.activemq.broker.BrokerService: boolean isStopping()>();
if v != 0 goto label;
v = new org.apache.activemq.broker.region.cursors.OrderedPendingList;
specialinvoke v.<org.apache.activemq.broker.region.cursors.OrderedPendingList: void <init>()>();
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doDispatch(org.apache.activemq.broker.region.cursors.PendingList)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch>;
if v != 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void wakeup()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch>;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void wakeup()>();
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void send(org.apache.activemq.broker.ProducerBrokerExchange, org.apache.activemq.command.Message) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.state.ProducerState v, v;
byte v;
java.lang.Long v, v, v, v;
org.apache.activemq.broker.region.Queue$TimeoutMessage v;
java.util.Map v, v;
org.apache.activemq.usage.SystemUsage v, v, v;
org.apache.activemq.command.ProducerAck v, v;
org.apache.activemq.broker.ProducerBrokerExchange v, v;
java.lang.Throwable v, v;
java.lang.Object[] v, v;
long v, v, v, v, v, v;
org.apache.activemq.broker.Broker v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.Connection v, v;
org.apache.activemq.command.ProducerId v, v, v;
org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask v, v, v;
org.apache.activemq.management.CountStatisticImpl v, v, v;
org.apache.activemq.usage.MemoryUsage v, v, v, v, v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
javax.jms.ResourceAllocationException v, v;
javax.jms.JMSException v;
org.apache.activemq.broker.region.Queue$5 v;
org.apache.activemq.command.ActiveMQDestination v, v, v, v, v;
org.apache.activemq.broker.region.DestinationStatistics v, v, v;
int v, v, v, v;
java.util.concurrent.DelayQueue v;
org.slf4j.Logger v, v, v, v;
org.apache.activemq.command.ProducerInfo v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ProducerBrokerExchange;
v := @parameter: org.apache.activemq.command.Message;
v = virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: org.apache.activemq.broker.ConnectionContext getConnectionContext()>();
virtualinvoke v.<org.apache.activemq.command.Message: void setRegionDestination(org.apache.activemq.command.Message$MessageDestination)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: org.apache.activemq.state.ProducerState getProducerState()>();
if v != null goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Send failed for: {}, missing producer state for: {}", v, v);
v = new javax.jms.JMSException;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.ActiveMQDestination)>(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[])>("Cannot send message to \u with invalid (null) producer state");
specialinvoke v.<javax.jms.JMSException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: org.apache.activemq.state.ProducerState getProducerState()>();
v = virtualinvoke v.<org.apache.activemq.state.ProducerState: org.apache.activemq.command.ProducerInfo getInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isResponseRequired()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.ProducerInfo: int getWindowSize()>();
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isInRecoveryMode()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isExpired()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: org.apache.activemq.broker.Broker getRoot()>();
interfaceinvoke v.<org.apache.activemq.broker.Broker: void messageExpired(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference,org.apache.activemq.broker.region.Subscription)>(v, v, null);
if v == 0 goto label;
v = new org.apache.activemq.command.ProducerAck;
v = virtualinvoke v.<org.apache.activemq.command.ProducerInfo: org.apache.activemq.command.ProducerId getProducerId()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: int getSize()>();
specialinvoke v.<org.apache.activemq.command.ProducerAck: void <init>(org.apache.activemq.command.ProducerId,int)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.broker.Connection getConnection()>();
interfaceinvoke v.<org.apache.activemq.broker.Connection: void dispatchAsync(org.apache.activemq.command.Command)>(v);
label:
return;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: boolean isFull()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void isFull(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.usage.Usage)>(v, v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void fastProducer(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ProducerInfo)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isProducerFlowControl()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isProducerFlowControl()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isFlowControlLogRequired()>();
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: long getLimit()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[0] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v[1] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object[])>("Usage Manager Memory Limit ({}) reached on {}, size {}. Producers will be throttled to the rate at which messages are removed from this destination to prevent flooding it. See http://activemq.apache.org/producer-flow-control.html for more info.", v);
goto label;
label:
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: long getLimit()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[0] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v[1] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("Usage Manager Memory Limit ({}) reached on {}, size {}. Producers will be throttled to the rate at which messages are removed from this destination to prevent flooding it. See http://activemq.apache.org/producer-flow-control.html for more info.", v);
label:
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isNetworkConnection()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: boolean isSendFailIfNoSpace()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: javax.jms.ResourceAllocationException sendMemAllocationException>;
if v != null goto label;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Queue: javax.jms.ResourceAllocationException sendMemAllocationException>;
if v != null goto label;
v = new javax.jms.ResourceAllocationException;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Usage Manager Memory Limit reached on \u. See http://activemq.apache.org/producer-flow-control.html for more info");
specialinvoke v.<javax.jms.ResourceAllocationException: void <init>(java.lang.String)>(v);
v = v;
v.<org.apache.activemq.broker.region.Queue: javax.jms.ResourceAllocationException sendMemAllocationException> = v;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.command.ProducerInfo: int getWindowSize()>();
if v > 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isResponseRequired()>();
if v == 0 goto label;
label:
v = virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: org.apache.activemq.broker.ProducerBrokerExchange copy()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.Map messagesWaitingForSpace>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask flowControlTimeoutTask>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask: boolean isAlive()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask flowControlTimeoutTask>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Producer Flow Control Timeout Task");
virtualinvoke v.<org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask: void setName(java.lang.String)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask flowControlTimeoutTask>;
virtualinvoke v.<org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask: void start()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.Map messagesWaitingForSpace>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = new org.apache.activemq.broker.region.Queue$5;
specialinvoke v.<org.apache.activemq.broker.region.Queue$5: void <init>(org.apache.activemq.broker.region.Queue,org.apache.activemq.command.Message,org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.ProducerBrokerExchange,boolean,org.apache.activemq.command.ProducerInfo)>(v, v, v, v, v, v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getBlockedSends()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: void blockingOnFlowControl(boolean)>(1);
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isNetworkConnection()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: long getSendFailIfNoSpaceAfterTimeout()>();
v = v cmp 0L;
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.DelayQueue flowControlTimeoutMessages>;
v = new org.apache.activemq.broker.region.Queue$TimeoutMessage;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: long getSendFailIfNoSpaceAfterTimeout()>();
specialinvoke v.<org.apache.activemq.broker.region.Queue$TimeoutMessage: void <init>(org.apache.activemq.broker.region.Queue,org.apache.activemq.command.Message,org.apache.activemq.broker.ConnectionContext,long)>(v, v, v, v);
virtualinvoke v.<java.util.concurrent.DelayQueue: boolean add(java.util.concurrent.Delayed)>(v);
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void registerCallbackForNotFullNotification()>();
virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: void setDontSendReponse(boolean)>(1);
exitmonitor v;
label:
return;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: boolean isFull()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.ProducerId getProducerId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.ProducerId,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[])>("Usage Manager Memory Limit reached. Producer (\u) stopped to prevent flooding \u. See http://activemq.apache.org/producer-flow-control.html for more info");
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void waitForSpace(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.ProducerBrokerExchange,org.apache.activemq.usage.Usage,java.lang.String)>(v, v, v, v);
label:
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isExpired()>();
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Expired message: {}", v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: org.apache.activemq.broker.Broker getRoot()>();
interfaceinvoke v.<org.apache.activemq.broker.Broker: void messageExpired(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference,org.apache.activemq.broker.region.Subscription)>(v, v, null);
return;
label:
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void doMessageSend(org.apache.activemq.broker.ProducerBrokerExchange,org.apache.activemq.command.Message)>(v, v);
if v == 0 goto label;
v = new org.apache.activemq.command.ProducerAck;
v = virtualinvoke v.<org.apache.activemq.command.ProducerInfo: org.apache.activemq.command.ProducerId getProducerId()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: int getSize()>();
specialinvoke v.<org.apache.activemq.command.ProducerAck: void <init>(org.apache.activemq.command.ProducerId,int)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.broker.Connection getConnection()>();
interfaceinvoke v.<org.apache.activemq.broker.Connection: void dispatchAsync(org.apache.activemq.command.Command)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void registerCallbackForNotFullNotification()
{
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.usage.MemoryUsage v;
java.lang.Runnable v, v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = v.<org.apache.activemq.broker.region.Queue: java.lang.Runnable sendMessagesWaitingForSpaceTask>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: boolean notifyCallbackWhenNotFull(java.lang.Runnable)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.lang.Runnable sendMessagesWaitingForSpaceTask>;
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
return;
}
public void onAdd(org.apache.activemq.store.IndexListener$MessageContext)
{
java.lang.Throwable v;
org.apache.activemq.store.IndexListener$MessageContext v;
org.apache.activemq.broker.region.Queue v;
java.util.LinkedList v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.store.IndexListener$MessageContext;
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
virtualinvoke v.<java.util.LinkedList: void addLast(java.lang.Object)>(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;
}
public void rollbackPendingCursorAdditions(org.apache.activemq.command.MessageId)
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v;
java.lang.Runnable v, v;
org.apache.activemq.command.Message v;
int v, v;
java.lang.Object v;
java.util.LinkedList v, v, v, v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.MessageId;
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
v = virtualinvoke v.<java.util.LinkedList: int size()>();
v = v - 1;
label:
if v < 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object get(int)>(v);
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.command.Message message>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
virtualinvoke v.<java.util.LinkedList: boolean remove(java.lang.Object)>(v);
v = v.<org.apache.activemq.store.IndexListener$MessageContext: java.lang.Runnable onCompletion>;
if v == null goto label;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: java.lang.Runnable onCompletion>;
interfaceinvoke v.<java.lang.Runnable: void run()>();
goto label;
label:
v = v - 1;
goto label;
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;
}
private void doPendingCursorAdditions() throws java.lang.Exception
{
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
java.lang.Runnable v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v, v, v, v, v, v;
java.lang.Long v;
boolean v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v, v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
java.lang.Throwable v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
int v;
java.util.LinkedList v, v, v, v, v;
org.slf4j.Logger v;
java.util.Iterator v, v;
java.util.concurrent.locks.Lock v, v, v;
java.lang.Object v, v, v, v, v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.Lock sendLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lockInterruptibly()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object peek()>();
label:
if v == null goto label;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.command.Message message>;
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 getFutureOrSequenceLong()>();
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object removeFirst()>();
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.command.Message message>;
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 getFutureOrSequenceLong()>();
v = v instanceof java.lang.Long;
if v == 0 goto label;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.command.Message message>;
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 getFutureOrSequenceLong()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(-1L);
v = virtualinvoke v.<java.lang.Long: int compareTo(java.lang.Long)>(v);
if v != 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.command.Message message>;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("{} messageStore indicated duplicate add attempt for {}, suppressing duplicate dispatch", v, v);
goto label;
label:
virtualinvoke v.<java.util.LinkedList: boolean add(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
virtualinvoke v.<java.util.LinkedList: java.lang.Object peek()>();
goto label;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = virtualinvoke v.<java.util.LinkedList: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.command.Message message>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean addMessageLast(org.apache.activemq.broker.region.MessageReference)>(v);
if v != 0 goto label;
v.<org.apache.activemq.store.IndexListener$MessageContext: boolean duplicate> = 1;
label:
v = v.<org.apache.activemq.store.IndexListener$MessageContext: java.lang.Runnable onCompletion>;
if v == null goto label;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: java.lang.Runnable onCompletion>;
interfaceinvoke v.<java.lang.Runnable: void run()>();
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.Lock sendLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.Lock sendLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
v = virtualinvoke v.<java.util.LinkedList: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v.<org.apache.activemq.store.IndexListener$MessageContext: boolean duplicate>;
if v != 0 goto label;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.broker.ConnectionContext context>;
v = v.<org.apache.activemq.store.IndexListener$MessageContext: org.apache.activemq.command.Message message>;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void messageSent(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v);
goto label;
label:
virtualinvoke v.<java.util.LinkedList: void clear()>();
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
void doMessageSend(org.apache.activemq.broker.ProducerBrokerExchange, org.apache.activemq.command.Message) throws java.io.IOException, java.lang.Exception
{
java.util.concurrent.atomic.AtomicBoolean v;
long v;
org.apache.activemq.broker.region.PendingMarshalUsageTracker v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.store.ListenableFuture v;
java.util.concurrent.atomic.AtomicInteger v, v;
boolean v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.store.MessageStore v, v, v;
java.util.concurrent.CancellationException v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v, v;
java.lang.Exception v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
org.apache.activemq.broker.ProducerBrokerExchange v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ProducerBrokerExchange;
v := @parameter: org.apache.activemq.command.Message;
v = virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: org.apache.activemq.broker.ConnectionContext getConnectionContext()>();
v = null;
virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: void incrementSend()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicInteger pendingSends>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void checkUsage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.ProducerBrokerExchange,org.apache.activemq.command.Message)>(v, v, v);
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: long getDestinationSequenceId()>();
virtualinvoke v.<org.apache.activemq.command.MessageId: void setBrokerSequenceId(long)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isPersistent()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
virtualinvoke v.<org.apache.activemq.command.MessageId: void setFutureOrSequenceLong(java.lang.Object)>(null);
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean isCacheEnabled()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isPersistJMSRedelivered()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isOptimizeStorage()>();
v = interfaceinvoke v.<org.apache.activemq.store.MessageStore: org.apache.activemq.store.ListenableFuture asyncAddQueueMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message,boolean)>(v, v, v);
v = new org.apache.activemq.broker.region.PendingMarshalUsageTracker;
specialinvoke v.<org.apache.activemq.broker.region.PendingMarshalUsageTracker: void <init>(org.apache.activemq.command.Message)>(v);
interfaceinvoke v.<org.apache.activemq.store.ListenableFuture: void addListener(java.lang.Runnable)>(v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
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.broker.region.Queue: boolean resetNeeded> = 1;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicInteger pendingSends>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void rollbackPendingCursorAdditions(org.apache.activemq.command.MessageId)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isReduceMemoryFootprint()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isMarshalled()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.command.Message: void clearUnMarshalledState()>();
label:
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: boolean tryOrderedCursorAdd(org.apache.activemq.command.Message,org.apache.activemq.broker.ConnectionContext)>(v, v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v != 0 goto label;
label:
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isResponseRequired()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.store.ListenableFuture: boolean isCancelled()>();
if v != 0 goto label;
label:
interfaceinvoke v.<org.apache.activemq.store.ListenableFuture: java.lang.Object get()>();
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.lang.Exception from label to label with label;
catch java.util.concurrent.CancellationException from label to label with label;
}
private boolean tryOrderedCursorAdd(org.apache.activemq.command.Message, org.apache.activemq.broker.ConnectionContext) throws java.lang.Exception
{
org.apache.activemq.store.MessageStore v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.store.IndexListener$MessageContext v;
org.apache.activemq.broker.region.Queue$CursorAddSync v;
org.apache.activemq.transaction.Transaction v;
boolean v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.Message;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v = 1;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isInTransaction()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.transaction.Transaction getTransaction()>();
v = new org.apache.activemq.broker.region.Queue$CursorAddSync;
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);
specialinvoke v.<org.apache.activemq.broker.region.Queue$CursorAddSync: void <init>(org.apache.activemq.broker.region.Queue,org.apache.activemq.store.IndexListener$MessageContext)>(v, v);
virtualinvoke v.<org.apache.activemq.transaction.Transaction: void addSynchronization(org.apache.activemq.transaction.Synchronization)>(v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isPersistent()>();
if v == 0 goto label;
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPendingCursorAdditions()>();
goto label;
label:
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: boolean tryCursorAdd(org.apache.activemq.command.Message)>(v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void messageSent(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v);
label:
return v;
}
private void checkUsage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.ProducerBrokerExchange, org.apache.activemq.command.Message) throws javax.jms.ResourceAllocationException, java.io.IOException, java.lang.InterruptedException
{
org.apache.activemq.usage.TempUsage v, v, v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.usage.SystemUsage v, v, v, v, v, v, v, v;
boolean v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.ActiveMQDestination v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v;
org.apache.activemq.broker.ProducerBrokerExchange v;
long v, v;
int v, v, v, v;
java.lang.String v, v, v, v;
org.apache.activemq.store.MessageStore v;
org.apache.activemq.command.ProducerId v, v;
org.apache.activemq.usage.StoreUsage v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.ProducerBrokerExchange;
v := @parameter: org.apache.activemq.command.Message;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isPersistent()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.StoreUsage getStoreUsage()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getStoreUsageHighWaterMark()>();
v = virtualinvoke v.<org.apache.activemq.usage.StoreUsage: boolean isFull(int)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getStoreUsageHighWaterMark()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.StoreUsage getStoreUsage()>();
v = virtualinvoke v.<org.apache.activemq.usage.StoreUsage: long getLimit()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.ProducerId getProducerId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,long,org.apache.activemq.command.ProducerId,java.lang.String)>(v, 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[])>("Persistent store is Full, \u0001% of \u. Stopping producer (\u) to prevent flooding \u. See http://activemq.apache.org/producer-flow-control.html for more info");
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.StoreUsage getStoreUsage()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getStoreUsageHighWaterMark()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void waitForSpace(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.ProducerBrokerExchange,org.apache.activemq.usage.Usage,int,java.lang.String)>(v, v, v, v, v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: org.apache.activemq.usage.SystemUsage getSystemUsage()>();
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
v = virtualinvoke v.<org.apache.activemq.usage.TempUsage: boolean isFull()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
v = virtualinvoke v.<org.apache.activemq.usage.TempUsage: int getPercentUsage()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
v = virtualinvoke v.<org.apache.activemq.usage.TempUsage: long getLimit()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.ProducerId getProducerId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,long,org.apache.activemq.command.ProducerId,java.lang.String)>(v, 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[])>("Temp Store is Full (\u0001% of \u). Stopping producer (\u) to prevent flooding \u. See http://activemq.apache.org/producer-flow-control.html for more info");
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: org.apache.activemq.usage.SystemUsage getSystemUsage()>();
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void waitForSpace(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.ProducerBrokerExchange,org.apache.activemq.usage.Usage,java.lang.String)>(v, v, v, v);
label:
return;
}
private void expireMessages()
{
org.slf4j.Logger v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.ActiveMQDestination v, v;
int v;
java.lang.String v, v;
org.apache.activemq.broker.util.InsertionCountList v;
v := @this: org.apache.activemq.broker.region.Queue;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("{} expiring messages ..", v);
v = new org.apache.activemq.broker.util.InsertionCountList;
specialinvoke v.<org.apache.activemq.broker.util.InsertionCountList: void <init>()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxExpirePageSize()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void doBrowse(java.util.List,int)>(v, v);
specialinvoke v.<org.apache.activemq.broker.region.Queue: void asyncWakeup()>();
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("{} expiring messages done.", v);
return;
}
public void gc()
{
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
return;
}
public void acknowledge(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription, org.apache.activemq.command.MessageAck, org.apache.activemq.broker.region.MessageReference) throws java.io.IOException
{
org.apache.activemq.store.MessageStore v, v;
org.apache.activemq.broker.region.MessageReference v;
org.apache.activemq.command.MessageAck v, v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.ConnectionContext v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: org.apache.activemq.command.MessageAck;
v := @parameter: org.apache.activemq.broker.region.MessageReference;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void messageConsumed(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: boolean isPersistent()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.MessageAck convertToNonRangedAck(org.apache.activemq.command.MessageAck,org.apache.activemq.broker.region.MessageReference)>(v, v);
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void removeAsyncMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.MessageAck)>(v, v);
label:
return;
}
org.apache.activemq.command.Message loadMessage(org.apache.activemq.command.MessageId) throws java.io.IOException
{
org.apache.activemq.store.MessageStore v, v;
org.apache.activemq.command.Message v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.MessageId;
v = null;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
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;
virtualinvoke v.<org.apache.activemq.command.Message: void setRegionDestination(org.apache.activemq.command.Message$MessageDestination)>(v);
label:
return v;
}
public long getPendingMessageSize()
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Queue v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: long messageSize()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public long getPendingMessageCount()
{
org.apache.activemq.management.CountStatisticImpl v;
org.apache.activemq.broker.region.Queue v;
long v;
org.apache.activemq.broker.region.DestinationStatistics v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
return v;
}
public java.lang.String toString()
{
org.apache.activemq.broker.region.Queue v;
long v;
org.apache.activemq.command.ActiveMQDestination v;
java.util.List v;
org.apache.activemq.management.CountStatisticImpl v;
int v, v, v;
org.apache.activemq.usage.MemoryUsage v;
java.lang.String v, v;
java.util.LinkedList v;
org.apache.activemq.broker.region.DestinationStatistics v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: int getPercentUsage()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.LinkedList indexOrderedCursorUpdates>;
v = virtualinvoke v.<java.util.LinkedList: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,int,long,int)>(v, v, 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, subscriptions=\u, memory=\u0001%, size=\u, pending=\u0001");
return v;
}
public void start() throws java.lang.Exception
{
org.apache.activemq.usage.TempUsage v, v;
java.util.concurrent.atomic.AtomicBoolean v;
long v, v;
java.lang.Runnable v;
byte v;
org.apache.activemq.usage.MemoryUsage v, v, v;
org.apache.activemq.usage.SystemUsage v, v, v, v, v;
boolean v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.usage.StoreUsage v, v;
org.apache.activemq.thread.Scheduler v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void start()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.StoreUsage getStoreUsage()>();
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.StoreUsage getStoreUsage()>();
virtualinvoke v.<org.apache.activemq.usage.StoreUsage: void start()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
virtualinvoke v.<org.apache.activemq.usage.TempUsage: void start()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.MemoryUsage getMemoryUsage()>();
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void addUsageListener(org.apache.activemq.usage.UsageListener)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void start()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: long getExpireMessagesPeriod()>();
v = v cmp 0L;
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.Scheduler scheduler>;
v = v.<org.apache.activemq.broker.region.Queue: java.lang.Runnable expireMessagesTask>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: long getExpireMessagesPeriod()>();
virtualinvoke v.<org.apache.activemq.thread.Scheduler: void executePeriodically(java.lang.Runnable,long)>(v, v);
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPageIn(boolean)>(0);
label:
return;
}
public void stop() throws java.lang.Exception
{
org.apache.activemq.usage.TempUsage v, v;
java.lang.Runnable v;
org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask v, v;
org.apache.activemq.usage.MemoryUsage v, v, v;
org.apache.activemq.usage.SystemUsage v, v, v, v, v;
boolean v, v, v;
org.apache.activemq.broker.region.Queue v;
java.util.Collection v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v;
org.apache.activemq.broker.region.cursors.PendingList v, v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.ExecutorService v, v;
org.apache.activemq.store.MessageStore v, v;
java.util.Iterator v;
org.apache.activemq.thread.TaskRunner v, v;
org.apache.activemq.usage.StoreUsage v, v;
org.apache.activemq.thread.Scheduler v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(1, 0);
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.TaskRunner taskRunner>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.TaskRunner taskRunner>;
interfaceinvoke v.<org.apache.activemq.thread.TaskRunner: void shutdown()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ExecutorService executor>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ExecutorService executor>;
staticinvoke <org.apache.activemq.util.ThreadPoolUtils: java.util.List shutdownNow(java.util.concurrent.ExecutorService)>(v);
v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ExecutorService executor> = null;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.Scheduler scheduler>;
v = v.<org.apache.activemq.broker.region.Queue: java.lang.Runnable expireMessagesTask>;
virtualinvoke v.<org.apache.activemq.thread.Scheduler: void cancel(java.lang.Runnable)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask flowControlTimeoutTask>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask: boolean isAlive()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask flowControlTimeoutTask>;
virtualinvoke v.<org.apache.activemq.broker.region.Queue$FlowControlTimeoutTask: void interrupt()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void stop()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: int decrementReferenceCount()>();
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: void clear()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.MemoryUsage getMemoryUsage()>();
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void removeUsageListener(org.apache.activemq.usage.UsageListener)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void stop()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.StoreUsage getStoreUsage()>();
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.StoreUsage getStoreUsage()>();
virtualinvoke v.<org.apache.activemq.usage.StoreUsage: void stop()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.TempUsage getTempUsage()>();
virtualinvoke v.<org.apache.activemq.usage.TempUsage: void stop()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void stop()>();
label:
return;
}
public org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()
{
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
return v;
}
public org.apache.activemq.broker.region.group.MessageGroupMap getMessageGroupOwners()
{
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.region.group.MessageGroupMap v, v, v, v;
org.apache.activemq.broker.region.group.MessageGroupMapFactory v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMap messageGroupOwners>;
if v != null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMapFactory getMessageGroupMapFactory()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.group.MessageGroupMapFactory: org.apache.activemq.broker.region.group.MessageGroupMap createMessageGroupMap()>();
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMap messageGroupOwners> = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMap messageGroupOwners>;
interfaceinvoke v.<org.apache.activemq.broker.region.group.MessageGroupMap: void setDestination(org.apache.activemq.broker.region.Destination)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMap messageGroupOwners>;
return v;
}
public org.apache.activemq.broker.region.policy.DispatchPolicy getDispatchPolicy()
{
org.apache.activemq.broker.region.policy.DispatchPolicy v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy>;
return v;
}
public void setDispatchPolicy(org.apache.activemq.broker.region.policy.DispatchPolicy)
{
org.apache.activemq.broker.region.policy.DispatchPolicy v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.policy.DispatchPolicy;
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy> = v;
return;
}
public org.apache.activemq.broker.region.group.MessageGroupMapFactory getMessageGroupMapFactory()
{
org.apache.activemq.broker.region.group.MessageGroupMapFactory v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMapFactory messageGroupMapFactory>;
return v;
}
public void setMessageGroupMapFactory(org.apache.activemq.broker.region.group.MessageGroupMapFactory)
{
org.apache.activemq.broker.region.group.MessageGroupMapFactory v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.group.MessageGroupMapFactory;
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMapFactory messageGroupMapFactory> = v;
return;
}
public org.apache.activemq.broker.region.cursors.PendingMessageCursor getMessages()
{
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
return v;
}
public void setMessages(org.apache.activemq.broker.region.cursors.PendingMessageCursor)
{
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.cursors.PendingMessageCursor;
v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages> = v;
return;
}
public boolean isUseConsumerPriority()
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: boolean useConsumerPriority>;
return v;
}
public void setUseConsumerPriority(boolean)
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v.<org.apache.activemq.broker.region.Queue: boolean useConsumerPriority> = v;
return;
}
public boolean isStrictOrderDispatch()
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: boolean strictOrderDispatch>;
return v;
}
public void setStrictOrderDispatch(boolean)
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v.<org.apache.activemq.broker.region.Queue: boolean strictOrderDispatch> = v;
return;
}
public boolean isOptimizedDispatch()
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch>;
return v;
}
public void setOptimizedDispatch(boolean)
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch> = v;
return;
}
public int getTimeBeforeDispatchStarts()
{
int v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts>;
return v;
}
public void setTimeBeforeDispatchStarts(int)
{
int v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: int;
v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts> = v;
return;
}
public int getConsumersBeforeDispatchStarts()
{
int v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: int consumersBeforeDispatchStarts>;
return v;
}
public void setConsumersBeforeDispatchStarts(int)
{
int v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: int;
v.<org.apache.activemq.broker.region.Queue: int consumersBeforeDispatchStarts> = v;
return;
}
public void setAllConsumersExclusiveByDefault(boolean)
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v.<org.apache.activemq.broker.region.Queue: boolean allConsumersExclusiveByDefault> = v;
return;
}
public boolean isAllConsumersExclusiveByDefault()
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: boolean allConsumersExclusiveByDefault>;
return v;
}
public boolean isResetNeeded()
{
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: boolean resetNeeded>;
return v;
}
private org.apache.activemq.broker.region.QueueMessageReference createMessageReference(org.apache.activemq.command.Message)
{
org.apache.activemq.command.Message v;
org.apache.activemq.broker.region.IndirectMessageReference v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.Message;
v = new org.apache.activemq.broker.region.IndirectMessageReference;
specialinvoke v.<org.apache.activemq.broker.region.IndirectMessageReference: void <init>(org.apache.activemq.command.Message)>(v);
return v;
}
public org.apache.activemq.command.Message[] browse()
{
java.lang.Object[] v;
org.apache.activemq.command.Message[] v;
org.apache.activemq.broker.region.Queue v;
int v, v;
java.util.ArrayList v;
v := @this: org.apache.activemq.broker.region.Queue;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxBrowsePageSize()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void doBrowse(java.util.List,int)>(v, v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (org.apache.activemq.command.Message)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
public void doBrowse(java.util.List, int)
{
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v;
org.apache.activemq.broker.region.cursors.PendingList v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v;
org.apache.activemq.broker.ConnectionContext v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v, v, v, v, v;
org.apache.activemq.usage.MemoryUsage v;
boolean v, v, v;
org.slf4j.Logger v;
org.apache.activemq.broker.BrokerStoppedException v;
org.apache.activemq.broker.region.Queue v;
java.lang.Exception v;
java.util.List v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.util.List;
v := @parameter: int;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.ConnectionContext createConnectionContext()>();
label:
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: int size()>();
v = v / v;
v = 1 + v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: boolean shouldPageInMoreForBrowse(int)>(v);
if v == 0 goto label;
v = v;
v = v - 1;
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: boolean isFull(int)>(110);
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void pageInMessages(boolean,int)>(v, v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void doBrowseList(java.util.List,int,org.apache.activemq.broker.region.cursors.PendingList,java.util.concurrent.locks.ReentrantReadWriteLock,org.apache.activemq.broker.ConnectionContext,java.lang.String)>(v, v, v, v, v, "redeliveredWaitingDispatch+pagedInPendingDispatch");
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void doBrowseList(java.util.List,int,org.apache.activemq.broker.region.cursors.PendingList,java.util.concurrent.locks.ReentrantReadWriteLock,org.apache.activemq.broker.ConnectionContext,java.lang.String)>(v, v, v, v, v, "pagedInMessages");
label:
goto label;
label:
v := @caughtexception;
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Problem retrieving message for browse", v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch org.apache.activemq.broker.BrokerStoppedException from label to label with label;
catch java.lang.Exception from label to label with label;
}
protected void doBrowseList(java.util.List, int, org.apache.activemq.broker.region.cursors.PendingList, java.util.concurrent.locks.ReentrantReadWriteLock, org.apache.activemq.broker.ConnectionContext, java.lang.String) throws java.lang.Exception
{
java.lang.Throwable v, v;
org.apache.activemq.broker.region.cursors.PendingList v;
java.util.concurrent.locks.ReentrantReadWriteLock v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.Broker v;
org.apache.activemq.broker.ConnectionContext v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v;
java.lang.String v;
boolean v, v;
org.slf4j.Logger v;
java.util.Iterator v;
org.apache.activemq.broker.region.Queue v;
java.util.Collection v;
java.util.List v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.util.List;
v := @parameter: int;
v := @parameter: org.apache.activemq.broker.region.cursors.PendingList;
v := @parameter: java.util.concurrent.locks.ReentrantReadWriteLock;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: java.lang.String;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: java.util.Collection values()>();
specialinvoke v.<org.apache.activemq.broker.region.Queue: void addAll(java.util.Collection,java.util.List,int,java.util.List)>(v, v, v, v);
label:
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = interfaceinvoke v.<java.util.List: 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.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: boolean isExpired(org.apache.activemq.broker.region.MessageReference)>(v);
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("expiring from {}: {}", v, v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void messageExpired(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
goto label;
label:
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: org.apache.activemq.broker.region.cursors.PendingNode remove(org.apache.activemq.broker.region.MessageReference)>(v);
label:
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: int decrementReferenceCount()>();
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private boolean shouldPageInMoreForBrowse(int)
{
java.lang.Integer v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v, v, v;
org.apache.activemq.usage.MemoryUsage v;
boolean v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v;
java.lang.Throwable v, v;
java.lang.Object[] v;
org.apache.activemq.broker.region.cursors.PendingList v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v;
int v, v, v, v, v;
org.slf4j.Logger v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: int;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: int size()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: int size()>();
v = v + v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[4];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[2] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: int getPercentUsage()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[3] = v;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object[])>("max {}, alreadyPagedIn {}, messagesCount {}, memoryUsage {}%", v);
if v == 0 goto label;
if v >= v goto label;
if v >= v goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean hasSpace()>();
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void addAll(java.util.Collection, java.util.List, int, java.util.List) throws java.lang.Exception
{
java.util.Iterator v;
org.apache.activemq.broker.region.Queue v;
java.util.Collection v;
java.util.List v, v;
org.apache.activemq.broker.region.LockOwner v;
org.apache.activemq.command.Message v, v;
int v, v;
java.lang.Object v;
boolean v, v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.util.Collection;
v := @parameter: java.util.List;
v := @parameter: int;
v := @parameter: java.util.List;
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: boolean isExpired()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.broker.region.LockOwner getLockOwner()>();
if v != null goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: boolean isAcked()>();
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
return;
}
public org.apache.activemq.broker.region.QueueMessageReference getMessage(java.lang.String)
{
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v;
org.apache.activemq.command.Message v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v;
boolean v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v, v, v, v, v, v;
java.lang.Throwable v, v, v;
org.apache.activemq.broker.region.cursors.PendingList v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v, v, v;
java.lang.String v;
org.apache.activemq.broker.region.QueueMessageReference v;
org.apache.activemq.broker.region.MessageReference v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.lang.String;
v = new org.apache.activemq.command.MessageId;
specialinvoke v.<org.apache.activemq.command.MessageId: void <init>(java.lang.String)>(v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: org.apache.activemq.broker.region.MessageReference get(org.apache.activemq.command.MessageId)>(v);
if v == null goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void reset()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean hasNext()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: org.apache.activemq.broker.region.MessageReference next()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.Message getMessage()>();
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueMessageReference createMessageReference(org.apache.activemq.command.Message)>(v);
interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: int decrementReferenceCount()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void rollback(org.apache.activemq.command.MessageId)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void release()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return v;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void release()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void release()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return null;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void purge() throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v, v, v, v;
byte v, v;
java.lang.Long v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
boolean v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
java.util.Collection v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
org.apache.activemq.broker.region.DestinationStatistics v, v, v, v;
java.lang.Throwable v, v;
java.lang.Object[] v;
org.apache.activemq.broker.region.cursors.PendingList v;
long v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.ArrayList v;
int v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReference v;
org.slf4j.Logger v;
java.util.Iterator v;
java.io.IOException v;
java.util.concurrent.locks.Lock v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.ConnectionContext createConnectionContext()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.Lock sendLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxPageSize()>();
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPageIn(boolean,boolean,int)>(1, 0, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = new java.util.ArrayList;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: java.util.Collection values()>();
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
label:
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.QueueMessageReference)>(v, v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void rollback(org.apache.activemq.command.MessageId)>(v);
label:
goto label;
label:
v := @caughtexception;
goto label;
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = v cmp 0L;
if v > 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = v cmp 0L;
if v <= 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v[0] = v;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[1] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object[])>("{} after purge of {} messages, message count stats report: {}", v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.Lock sendLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.Lock sendLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void clearPendingMessages(int)
{
java.lang.Throwable v;
org.apache.activemq.command.ActiveMQMessage v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
int v, v;
boolean v;
org.slf4j.Logger v;
org.apache.activemq.broker.region.Queue v;
java.lang.Exception v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: int;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = new org.apache.activemq.command.ActiveMQMessage;
specialinvoke v.<org.apache.activemq.command.ActiveMQMessage: void <init>()>();
virtualinvoke v.<org.apache.activemq.command.ActiveMQMessage: void setPersistent(boolean)>(1);
v = 0;
label:
if v >= v goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void addMessageFirst(org.apache.activemq.broker.region.MessageReference)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("Unexpected exception on tracking pending message additions", v);
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: boolean resetNeeded>;
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void gc()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void reset()>();
v.<org.apache.activemq.broker.region.Queue: boolean resetNeeded> = 0;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void rebase()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void asyncWakeup()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public boolean removeMessage(java.lang.String) throws java.lang.Exception
{
org.apache.activemq.broker.region.Queue v;
int v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.MessageReferenceFilter createMessageIdFilter(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int removeMatchingMessages(org.apache.activemq.broker.region.MessageReferenceFilter,int)>(v, 1);
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public int removeMatchingMessages(java.lang.String) throws java.lang.Exception
{
org.apache.activemq.broker.region.Queue v;
int v, v;
java.lang.String v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.lang.String;
v = (int) -1;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int removeMatchingMessages(java.lang.String,int)>(v, v);
return v;
}
public int removeMatchingMessages(java.lang.String, int) throws java.lang.Exception
{
org.apache.activemq.broker.region.Queue v;
int v, v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.lang.String;
v := @parameter: int;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.MessageReferenceFilter createSelectorFilter(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int removeMatchingMessages(org.apache.activemq.broker.region.MessageReferenceFilter,int)>(v, v);
return v;
}
public int removeMatchingMessages(org.apache.activemq.broker.region.MessageReferenceFilter, int) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.PendingList v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v;
byte v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v;
int v, v, v;
java.util.LinkedHashSet v;
boolean v, v, v;
org.apache.activemq.broker.region.MessageReference v;
java.util.Iterator v;
org.apache.activemq.broker.region.Queue v;
java.util.Collection v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
org.apache.activemq.broker.region.DestinationStatistics v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.MessageReferenceFilter;
v := @parameter: int;
v = 0;
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.ConnectionContext createConnectionContext()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPageIn(boolean)>(1);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
if v != 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReferenceFilter: boolean evaluate(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.QueueMessageReference)>(v, v);
interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
v = v + 1;
if v < v goto label;
if v <= 0 goto label;
return v;
label:
v = interfaceinvoke v.<java.util.Set: int size()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = v cmp v;
if v < 0 goto label;
return v;
catch java.lang.Throwable from label to label with label;
}
public boolean copyMessageTo(org.apache.activemq.broker.ConnectionContext, java.lang.String, org.apache.activemq.command.ActiveMQDestination) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Queue v;
int v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
boolean v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.MessageReferenceFilter createMessageIdFilter(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int copyMatchingMessages(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReferenceFilter,org.apache.activemq.command.ActiveMQDestination,int)>(v, v, v, 1);
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public int copyMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext, java.lang.String, org.apache.activemq.command.ActiveMQDestination) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Queue v;
int v, v;
java.lang.String v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v = (int) -1;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int copyMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext,java.lang.String,org.apache.activemq.command.ActiveMQDestination,int)>(v, v, v, v);
return v;
}
public int copyMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext, java.lang.String, org.apache.activemq.command.ActiveMQDestination, int) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Queue v;
int v, v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: int;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.MessageReferenceFilter createSelectorFilter(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int copyMatchingMessages(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReferenceFilter,org.apache.activemq.command.ActiveMQDestination,int)>(v, v, v, v);
return v;
}
public int copyMatchingMessages(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.MessageReferenceFilter, org.apache.activemq.command.ActiveMQDestination, int) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.management.CountStatisticImpl v;
byte v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v;
boolean v, v, v, v, v, v;
org.apache.activemq.broker.BrokerService v;
org.apache.activemq.broker.region.Queue v;
java.util.Collection v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
org.apache.activemq.command.ActiveMQDestination v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v;
org.apache.activemq.broker.region.DestinationStatistics v;
java.lang.Throwable v, v;
org.apache.activemq.broker.region.cursors.PendingList v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.Broker v;
int v, v, v, v;
java.util.LinkedHashSet v;
org.apache.activemq.broker.region.MessageReference v;
java.util.Iterator v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.MessageReferenceFilter;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: int;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
return 0;
label:
v = 0;
v = 0;
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean isCacheEnabled()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: org.apache.activemq.broker.BrokerService getBrokerService()>();
v = virtualinvoke v.<org.apache.activemq.broker.BrokerService: boolean isPersistent()>();
if v != 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: int size()>();
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxBrowsePageSize()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPageIn(boolean,boolean,int)>(1, 0, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
if v != 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReferenceFilter: boolean evaluate(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.IndirectMessageReference: int incrementReferenceCount()>();
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.IndirectMessageReference: org.apache.activemq.command.Message getMessage()>();
staticinvoke <org.apache.activemq.util.BrokerSupport: void resend(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message,org.apache.activemq.command.ActiveMQDestination)>(v, v, v);
v = v + 1;
if v < v goto label;
if v <= 0 goto label;
label:
virtualinvoke v.<org.apache.activemq.broker.region.IndirectMessageReference: int decrementReferenceCount()>();
return v;
label:
virtualinvoke v.<org.apache.activemq.broker.region.IndirectMessageReference: int decrementReferenceCount()>();
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.broker.region.IndirectMessageReference: int decrementReferenceCount()>();
throw v;
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = v cmp v;
if v < 0 goto label;
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public boolean moveMessageTo(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.QueueMessageReference, org.apache.activemq.command.ActiveMQDestination) throws java.lang.Exception
{
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v, v, v;
org.apache.activemq.broker.region.policy.DeadLetterStrategy v;
boolean v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
java.util.Set v, v;
org.apache.activemq.command.ActiveMQDestination v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
org.apache.activemq.broker.region.Destination v, v, v;
java.lang.Throwable v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
org.apache.activemq.broker.Broker v, v;
org.apache.activemq.broker.region.QueueMessageReference v;
java.util.Iterator v, v, v, v;
java.lang.Object v, v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.QueueMessageReference;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker regionBroker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: java.util.Set getDestinations(org.apache.activemq.command.ActiveMQDestination)>(v);
label:
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 = v instanceof org.apache.activemq.broker.region.Queue;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void pauseDispatch()>();
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
staticinvoke <org.apache.activemq.util.BrokerSupport: void resend(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message,org.apache.activemq.command.ActiveMQDestination)>(v, v, v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.QueueMessageReference)>(v, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void rollback(org.apache.activemq.command.MessageId)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isDLQ()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.ActiveMQDestination getOriginalDestination()>();
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker regionBroker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: java.util.Set getDestinations(org.apache.activemq.command.ActiveMQDestination)>(v);
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.<org.apache.activemq.broker.region.Destination: org.apache.activemq.broker.region.policy.DeadLetterStrategy getDeadLetterStrategy()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
interfaceinvoke v.<org.apache.activemq.broker.region.policy.DeadLetterStrategy: void rollback(org.apache.activemq.command.Message)>(v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
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 = v instanceof org.apache.activemq.broker.region.Queue;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void resumeDispatch()>();
goto label;
label:
v := @caughtexception;
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 = v instanceof org.apache.activemq.broker.region.Queue;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void resumeDispatch()>();
goto label;
label:
throw v;
label:
return 1;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public boolean moveMessageTo(org.apache.activemq.broker.ConnectionContext, java.lang.String, org.apache.activemq.command.ActiveMQDestination) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Queue v;
int v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
boolean v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.MessageReferenceFilter createMessageIdFilter(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int moveMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReferenceFilter,org.apache.activemq.command.ActiveMQDestination,int)>(v, v, v, 1);
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public int moveMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext, java.lang.String, org.apache.activemq.command.ActiveMQDestination) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Queue v;
int v;
java.lang.String v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int moveMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext,java.lang.String,org.apache.activemq.command.ActiveMQDestination,int)>(v, v, v, 2147483647);
return v;
}
public int moveMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext, java.lang.String, org.apache.activemq.command.ActiveMQDestination, int) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Queue v;
int v, v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: int;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.MessageReferenceFilter createSelectorFilter(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int moveMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReferenceFilter,org.apache.activemq.command.ActiveMQDestination,int)>(v, v, v, v);
return v;
}
public int moveMatchingMessagesTo(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.MessageReferenceFilter, org.apache.activemq.command.ActiveMQDestination, int) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v;
byte v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v;
boolean v, v, v, v;
org.apache.activemq.broker.region.Queue v;
java.util.Collection v;
org.apache.activemq.broker.region.MessageReferenceFilter v;
org.apache.activemq.command.ActiveMQDestination v, v;
org.apache.activemq.broker.region.DestinationStatistics v;
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.PendingList v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.util.ArrayList v;
int v, v, v, v;
java.util.LinkedHashSet v;
org.apache.activemq.broker.region.MessageReference v;
java.util.Iterator v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.MessageReferenceFilter;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: int;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
return 0;
label:
v = 0;
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPageIn(boolean)>(1);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
if v != 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.List: 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.<org.apache.activemq.broker.region.MessageReferenceFilter: boolean evaluate(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean moveMessageTo(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.QueueMessageReference,org.apache.activemq.command.ActiveMQDestination)>(v, v, v);
interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
v = v + 1;
if v < v goto label;
if v <= 0 goto label;
return v;
label:
v = interfaceinvoke v.<java.util.Set: int size()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = v cmp v;
if v >= 0 goto label;
v = interfaceinvoke v.<java.util.Set: int size()>();
if v < v goto label;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public int retryMessages(org.apache.activemq.broker.ConnectionContext, int) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v, v;
org.apache.activemq.management.CountStatisticImpl v, v;
byte v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v;
boolean v, v, v;
org.apache.activemq.broker.region.Queue v;
java.util.Collection v;
java.lang.Exception v;
org.apache.activemq.command.ActiveMQDestination v, v;
org.apache.activemq.broker.region.DestinationStatistics v, v;
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.PendingList v;
long v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.util.ArrayList v;
int v, v, v;
java.util.LinkedHashSet v;
org.apache.activemq.broker.region.MessageReference v;
java.util.Iterator v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: int;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isDLQ()>();
if v != 0 goto label;
v = new java.lang.Exception;
specialinvoke v.<java.lang.Exception: void <init>(java.lang.String)>("Retry of message is only possible on Dead Letter Queues!");
throw v;
label:
v = 0;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPageIn(boolean)>(1);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
if v != 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.List: 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 - 1L;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.Message getMessage()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.ActiveMQDestination getOriginalDestination()>();
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.Message getMessage()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.ActiveMQDestination getOriginalDestination()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean moveMessageTo(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.QueueMessageReference,org.apache.activemq.command.ActiveMQDestination)>(v, v, v);
interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
v = v + 1;
if v < v goto label;
if v <= 0 goto label;
return v;
label:
v = v cmp 0L;
if v <= 0 goto label;
v = interfaceinvoke v.<java.util.Set: int size()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = v cmp v;
if v < 0 goto label;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public boolean iterate()
{
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v, v;
org.apache.activemq.filter.NonCachedMessageEvaluationContext v;
java.lang.Integer v, v, v, v, v;
byte v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v, v, v, v, v, v;
java.util.Map v, v;
java.lang.Exception v, v;
java.util.concurrent.CountDownLatch v;
java.lang.Throwable v, v, v, v, v, v;
org.apache.activemq.broker.region.cursors.PendingList v, v, v;
long v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v, v, v, v;
java.lang.String v, v;
java.util.concurrent.atomic.AtomicLong v, v, v;
org.apache.activemq.usage.MemoryUsage v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
java.util.Collection v;
org.apache.activemq.command.ActiveMQDestination v;
java.util.List v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
java.util.concurrent.ConcurrentLinkedQueue v, v;
int v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.cursors.OrderedPendingList v;
org.apache.activemq.broker.region.MessageReference v;
org.slf4j.Logger v, v, v, v, v, v, v;
java.util.Iterator v, v, v;
org.apache.activemq.broker.region.cursors.PrioritizedPendingList v;
java.util.concurrent.TimeUnit v;
java.lang.Object v, v, v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: java.lang.String getName()>();
staticinvoke <org.slf4j.MDC: void put(java.lang.String,java.lang.String)>("activemq.destination", v);
v = v.<org.apache.activemq.broker.region.Queue: java.lang.Object iteratingMutex>;
entermonitor v;
label:
v.<org.apache.activemq.broker.region.Queue: boolean iterationRunning> = 1;
v = v.<org.apache.activemq.broker.region.Queue: java.util.Map messagesWaitingForSpace>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.Map messagesWaitingForSpace>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: boolean isFull()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
interfaceinvoke v.<java.util.Iterator: void remove()>();
interfaceinvoke v.<java.lang.Runnable: void run()>();
goto label;
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void registerCallbackForNotFullNotification()>();
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: boolean firstConsumer>;
if v == 0 goto label;
v.<org.apache.activemq.broker.region.Queue: boolean firstConsumer> = 0;
label:
v = v.<org.apache.activemq.broker.region.Queue: int consumersBeforeDispatchStarts>;
if v <= 0 goto label;
v = 1000;
v = v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts>;
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts>;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.CountDownLatch consumersBeforeStartsLatch>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = virtualinvoke v.<java.util.concurrent.CountDownLatch: boolean await(long,java.util.concurrent.TimeUnit)>(v, v);
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("{} consumers subscribed. Starting dispatch.", v);
goto label;
label:
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("{} ms elapsed and {} consumers subscribed. Starting dispatch.", v, v);
label:
v = v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts>;
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: int consumersBeforeDispatchStarts>;
if v > 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.lang.Object iteratingMutex>;
v = v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts>;
virtualinvoke v.<java.lang.Object: void wait(long)>(v);
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.broker.region.Queue: int timeBeforeDispatchStarts>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("{} ms elapsed. Starting dispatch.", v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String toString()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = 0 | v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v | v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ConcurrentLinkedQueue browserSubscriptions>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
if v != 0 goto label;
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean hasRedeliveries()>();
if v != 0 goto label;
label:
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxBrowsePageSize()>();
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxPageSize()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void pageInMessages(boolean,int)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Failed to page in more queue messages ", v);
label:
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isPrioritizedMessages()>();
if v == 0 goto label;
v = new org.apache.activemq.broker.region.cursors.PrioritizedPendingList;
v = v;
specialinvoke v.<org.apache.activemq.broker.region.cursors.PrioritizedPendingList: void <init>()>();
goto label;
label:
v = new org.apache.activemq.broker.region.cursors.OrderedPendingList;
v = v;
specialinvoke v.<org.apache.activemq.broker.region.cursors.OrderedPendingList: void <init>()>();
label:
v = v;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: void addAll(org.apache.activemq.broker.region.cursors.PendingList)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ConcurrentLinkedQueue browserSubscriptions>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: 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()>();
label:
v = new org.apache.activemq.filter.NonCachedMessageEvaluationContext;
specialinvoke v.<org.apache.activemq.filter.NonCachedMessageEvaluationContext: void <init>()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
virtualinvoke v.<org.apache.activemq.filter.MessageEvaluationContext: void setDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("dispatch to browser: {}, already dispatched/paged count: {}", v, v);
v = 0;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: 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.<org.apache.activemq.broker.region.QueueMessageReference: boolean isAcked()>();
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: boolean isDuplicate(org.apache.activemq.command.MessageId)>(v);
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: boolean atMax()>();
if v != 0 goto label;
virtualinvoke v.<org.apache.activemq.filter.MessageEvaluationContext: void setMessageReference(org.apache.activemq.broker.region.MessageReference)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: boolean matches(org.apache.activemq.broker.region.MessageReference,org.apache.activemq.filter.MessageEvaluationContext)>(v, v);
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: void add(org.apache.activemq.broker.region.MessageReference)>(v);
v = 1;
goto label;
label:
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: boolean atMax()>();
if v == 0 goto label;
label:
virtualinvoke v.<org.apache.activemq.broker.region.QueueBrowserSubscription: void decrementQueueRef()>();
interfaceinvoke v.<java.util.Iterator: void remove()>();
goto label;
label:
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void wakeup()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("exception on dispatch to browser: {}", v, v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicLong pendingWakeups>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp 0L;
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicLong pendingWakeups>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long decrementAndGet()>();
label:
staticinvoke <org.slf4j.MDC: void remove(java.lang.String)>("activemq.destination");
v.<org.apache.activemq.broker.region.Queue: boolean iterationRunning> = 0;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicLong pendingWakeups>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp 0L;
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void pauseDispatch()
{
org.apache.activemq.broker.region.QueueDispatchSelector v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: void pause()>();
return;
}
public void resumeDispatch()
{
org.apache.activemq.broker.region.QueueDispatchSelector v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: void resume()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void wakeup()>();
return;
}
public boolean isDispatchPaused()
{
org.apache.activemq.broker.region.QueueDispatchSelector v;
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: boolean isPaused()>();
return v;
}
protected org.apache.activemq.broker.region.MessageReferenceFilter createMessageIdFilter(java.lang.String)
{
org.apache.activemq.broker.region.Queue$6 v;
java.lang.String v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.lang.String;
v = new org.apache.activemq.broker.region.Queue$6;
specialinvoke v.<org.apache.activemq.broker.region.Queue$6: void <init>(org.apache.activemq.broker.region.Queue,java.lang.String)>(v, v);
return v;
}
protected org.apache.activemq.broker.region.MessageReferenceFilter createSelectorFilter(java.lang.String) throws javax.jms.InvalidSelectorException
{
org.apache.activemq.broker.region.Queue$7 v;
org.apache.activemq.broker.region.Queue$8 v;
org.apache.activemq.broker.region.Queue v;
java.lang.String v;
org.apache.activemq.filter.BooleanExpression v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
v = new org.apache.activemq.broker.region.Queue$7;
specialinvoke v.<org.apache.activemq.broker.region.Queue$7: void <init>(org.apache.activemq.broker.region.Queue)>(v);
return v;
label:
v = staticinvoke <org.apache.activemq.selector.SelectorParser: org.apache.activemq.filter.BooleanExpression parse(java.lang.String)>(v);
v = new org.apache.activemq.broker.region.Queue$8;
specialinvoke v.<org.apache.activemq.broker.region.Queue$8: void <init>(org.apache.activemq.broker.region.Queue,org.apache.activemq.filter.BooleanExpression)>(v, v);
return v;
}
protected void removeMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.QueueMessageReference) throws java.io.IOException
{
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v;
org.apache.activemq.broker.region.Queue v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.QueueMessageReference v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.QueueMessageReference;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.QueueMessageReference)>(v, null, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: org.apache.activemq.broker.region.cursors.PendingNode remove(org.apache.activemq.broker.region.MessageReference)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
protected void removeMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription, org.apache.activemq.broker.region.QueueMessageReference) throws java.io.IOException
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.MessageAck v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
org.apache.activemq.broker.region.QueueMessageReference v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: org.apache.activemq.broker.region.QueueMessageReference;
v = new org.apache.activemq.command.MessageAck;
specialinvoke v.<org.apache.activemq.command.MessageAck: void <init>()>();
virtualinvoke v.<org.apache.activemq.command.MessageAck: void setAckType(byte)>(2);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
virtualinvoke v.<org.apache.activemq.command.MessageAck: void setDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
virtualinvoke v.<org.apache.activemq.command.MessageAck: void setMessageID(org.apache.activemq.command.MessageId)>(v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.QueueMessageReference,org.apache.activemq.command.MessageAck)>(v, v, v, v);
return;
}
protected void removeMessage(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription, org.apache.activemq.broker.region.QueueMessageReference, org.apache.activemq.command.MessageAck) throws java.io.IOException
{
java.lang.Throwable v, v;
org.apache.activemq.broker.region.Subscription v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v;
org.apache.activemq.broker.region.QueueMessageReference v;
org.apache.activemq.command.ConsumerInfo v, v;
boolean v, v, v, v;
org.apache.activemq.command.MessageAck v;
org.slf4j.Logger v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v;
org.apache.activemq.broker.region.Queue$9 v, v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
org.apache.activemq.broker.region.DestinationStatistics v;
org.apache.activemq.transaction.Transaction v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: org.apache.activemq.broker.region.QueueMessageReference;
v := @parameter: org.apache.activemq.command.MessageAck;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("ack of {} with {}", v, v);
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: boolean isInTransaction()>();
if v != 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void acknowledge(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,org.apache.activemq.command.MessageAck,org.apache.activemq.broker.region.MessageReference)>(v, v, v, v);
specialinvoke v.<org.apache.activemq.broker.region.Queue: void dropMessage(org.apache.activemq.broker.region.QueueMessageReference)>(v);
goto label;
label:
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void acknowledge(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,org.apache.activemq.command.MessageAck,org.apache.activemq.broker.region.MessageReference)>(v, v, v, v);
label:
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.transaction.Transaction getTransaction()>();
v = new org.apache.activemq.broker.region.Queue$9;
specialinvoke v.<org.apache.activemq.broker.region.Queue$9: void <init>(org.apache.activemq.broker.region.Queue,org.apache.activemq.broker.region.QueueMessageReference)>(v, v);
virtualinvoke v.<org.apache.activemq.transaction.Transaction: void addSynchronization(org.apache.activemq.transaction.Synchronization)>(v);
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.transaction.Transaction getTransaction()>();
v = new org.apache.activemq.broker.region.Queue$9;
specialinvoke v.<org.apache.activemq.broker.region.Queue$9: void <init>(org.apache.activemq.broker.region.Queue,org.apache.activemq.broker.region.QueueMessageReference)>(v, v);
virtualinvoke v.<org.apache.activemq.transaction.Transaction: void addSynchronization(org.apache.activemq.transaction.Synchronization)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.command.MessageAck: boolean isPoisonAck()>();
if v != 0 goto label;
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isNetworkSubscription()>();
if v == 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void rollback(org.apache.activemq.command.MessageId)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isNetworkSubscription()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getForwards()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
label:
interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: void setAcked(boolean)>(1);
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void dropMessage(org.apache.activemq.broker.region.QueueMessageReference)
{
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.PendingList v;
org.apache.activemq.broker.region.Queue v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.management.CountStatisticImpl v, v;
org.apache.activemq.broker.region.DestinationStatistics v, v;
org.apache.activemq.broker.region.QueueMessageReference v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.QueueMessageReference;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: boolean dropIfLive()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getDequeues()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void decrement()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: org.apache.activemq.broker.region.cursors.PendingNode remove(org.apache.activemq.broker.region.MessageReference)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void messageExpired(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.MessageReference)
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.MessageReference v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.MessageReference;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void messageExpired(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.MessageReference)>(v, null, v);
return;
}
public void messageExpired(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription, org.apache.activemq.broker.region.MessageReference)
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Subscription v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.Broker v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v;
org.apache.activemq.broker.region.MessageReference v;
org.slf4j.Logger v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
java.io.IOException v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
org.apache.activemq.broker.region.DestinationStatistics v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: org.apache.activemq.broker.region.MessageReference;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("message expired: {}", v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
interfaceinvoke v.<org.apache.activemq.broker.Broker: void messageExpired(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference,org.apache.activemq.broker.region.Subscription)>(v, v, v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getExpired()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
label:
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.QueueMessageReference)>(v, v, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void rollback(org.apache.activemq.command.MessageId)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Failed to remove expired Message from the store ", v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
private final boolean cursorAdd(org.apache.activemq.command.Message) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Queue v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.command.Message v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.Message;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean addMessageLast(org.apache.activemq.broker.region.MessageReference)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
private final boolean tryCursorAdd(org.apache.activemq.command.Message) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Queue v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.command.Message v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.Message;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean tryAddMessageLast(org.apache.activemq.broker.region.MessageReference,long)>(v, 50L);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
final void messageSent(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.Message) throws java.lang.Exception
{
java.lang.Throwable v;
java.lang.Object[] v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
org.apache.activemq.broker.Broker v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.management.CountStatisticImpl v, v;
java.util.concurrent.atomic.AtomicInteger v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v;
java.lang.String v;
boolean v;
org.slf4j.Logger v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
org.apache.activemq.management.SizeStatisticImpl v;
org.apache.activemq.command.ActiveMQDestination v;
java.util.List v;
org.apache.activemq.broker.region.DestinationStatistics v, v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.Message;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicInteger pendingSends>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getEnqueues()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getMessages()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.SizeStatisticImpl getMessageSize()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: int getSize()>();
virtualinvoke v.<org.apache.activemq.management.SizeStatisticImpl: void addSize(long)>(v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void messageDelivered(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void onMessageWithNoConsumers(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: java.lang.String getBrokerName()>();
v[0] = v;
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v[1] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("{} Message {} sent to {}", v);
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void wakeup()>();
return;
catch java.lang.Throwable from label to label with label;
}
public void wakeup()
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.broker.region.Queue v;
boolean v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: boolean optimizedDispatch>;
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: boolean iterationRunning>;
if v != 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean iterate()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicLong pendingWakeups>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long incrementAndGet()>();
goto label;
label:
specialinvoke v.<org.apache.activemq.broker.region.Queue: void asyncWakeup()>();
label:
return;
}
private void asyncWakeup()
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.activemq.thread.TaskRunner v;
org.slf4j.Logger v;
java.lang.InterruptedException v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.atomic.AtomicLong pendingWakeups>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long incrementAndGet()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.thread.TaskRunner taskRunner>;
interfaceinvoke v.<org.apache.activemq.thread.TaskRunner: void wakeup()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Async task runner failed to wakeup ", v);
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
private void doPageIn(boolean) throws java.lang.Exception
{
int v;
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxPageSize()>();
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doPageIn(boolean,boolean,int)>(v, 1, v);
return;
}
private void doPageIn(boolean, boolean, int) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v, v, v, v;
org.apache.activemq.broker.region.cursors.PendingList v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
int v;
boolean v, v, v, v, v;
java.util.Iterator v;
org.apache.activemq.broker.region.Queue v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: int;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList doPageInForDispatch(boolean,boolean,int)>(v, v, v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean isEmpty()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: void addAll(org.apache.activemq.broker.region.cursors.PendingList)>(v);
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: 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.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean contains(org.apache.activemq.broker.region.MessageReference)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: org.apache.activemq.broker.region.cursors.PendingNode addMessageLast(org.apache.activemq.broker.region.MessageReference)>(v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private org.apache.activemq.broker.region.cursors.PendingList doPageInForDispatch(boolean, boolean, int) throws java.lang.Exception
{
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v;
java.lang.Integer v, v, v, v;
org.apache.activemq.broker.ConnectionContext v, v;
org.apache.activemq.command.Message v, v, v, v, v, v;
java.lang.Long v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v, v, v;
org.apache.activemq.usage.SystemUsage v, v;
java.lang.Throwable v, v, v, v, v, v;
java.lang.Object[] v, v;
org.apache.activemq.broker.region.cursors.PendingList v, v, v, v, v;
long v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v, v, v, v, v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.Broker v, v, v;
java.lang.String v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v, v, v;
org.apache.activemq.management.CountStatisticImpl v, v, v;
org.apache.activemq.usage.MemoryUsage v, v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.DestinationStatistics v, v, v;
int v, v, v, v, v, v, v;
java.lang.Boolean v;
org.apache.activemq.broker.region.cursors.OrderedPendingList v, v;
org.apache.activemq.broker.region.QueueMessageReference v;
org.apache.activemq.store.MessageStore v, v;
org.apache.activemq.broker.region.MessageReference v;
org.apache.activemq.command.MessageAck v;
org.slf4j.Logger v, v, v, v, v, v;
java.util.Iterator v;
org.apache.activemq.broker.region.cursors.PrioritizedPendingList v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: int;
v = null;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: int size()>();
v = staticinvoke <java.lang.Math: int min(int,int)>(v, v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: int size()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isLazyDispatch()>();
if v == 0 goto label;
if v != 0 goto label;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: int getConsumerMessageCountBeforeFull()>();
v = staticinvoke <java.lang.Math: int min(int,int)>(v, v);
label:
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[10];
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[2] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getInflight()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[3] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[4] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[5] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getEnqueues()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[6] = v;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getDequeues()>();
v = virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: long getCount()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[7] = v;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.MemoryUsage getMemoryUsage()>();
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: long getUsage()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[8] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[9] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("{} toPageIn: {}, force:{}, Inflight: {}, pagedInMessages.size {}, pagedInPendingDispatch.size {}, enqueueCount: {}, dequeueCount: {}, memUsage:{}, maxPageSize:{}", v);
label:
if v <= 0 goto label;
if v != 0 goto label;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: boolean haveRealConsumer()>();
if v == 0 goto label;
if v >= v goto label;
label:
v = 0;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setMaxBatchSize(int)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void reset()>();
label:
if v >= v goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean hasNext()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: org.apache.activemq.broker.region.MessageReference next()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void remove()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.Message getMessage()>();
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueMessageReference createMessageReference(org.apache.activemq.command.Message)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: boolean isExpired()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: boolean isExpired(org.apache.activemq.broker.region.MessageReference)>(v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.ConnectionContext createConnectionContext()>();
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void messageExpired(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
goto label;
label:
interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: int decrementReferenceCount()>();
goto label;
label:
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void release()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void release()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
if v <= 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isPrioritizedMessages()>();
if v == 0 goto label;
v = new org.apache.activemq.broker.region.cursors.PrioritizedPendingList;
specialinvoke v.<org.apache.activemq.broker.region.cursors.PrioritizedPendingList: void <init>()>();
v = v;
goto label;
label:
v = new org.apache.activemq.broker.region.cursors.OrderedPendingList;
specialinvoke v.<org.apache.activemq.broker.region.cursors.OrderedPendingList: void <init>()>();
v = v;
label:
v = interfaceinvoke v.<java.util.List: 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.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: boolean contains(org.apache.activemq.broker.region.MessageReference)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: org.apache.activemq.broker.region.cursors.PendingNode addMessageLast(org.apache.activemq.broker.region.MessageReference)>(v);
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: org.apache.activemq.broker.region.cursors.PendingNode addMessageLast(org.apache.activemq.broker.region.MessageReference)>(v);
goto label;
label:
interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: int decrementReferenceCount()>();
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v[1] = v;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
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 getFutureOrSequenceLong()>();
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object[])>("{}, duplicate message {} - {} from cursor, is cursor audit disabled or too constrained? Redirecting to dlq", v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.ConnectionContext createConnectionContext()>();
specialinvoke v.<org.apache.activemq.broker.region.Queue: void dropMessage(org.apache.activemq.broker.region.QueueMessageReference)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
v = staticinvoke <org.apache.activemq.broker.region.cursors.AbstractStoreCursor: boolean gotToTheStore(org.apache.activemq.command.Message)>(v);
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Duplicate message {} from cursor, removing from store", v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.store.MessageStore store>;
v = new org.apache.activemq.command.MessageAck;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
specialinvoke v.<org.apache.activemq.command.MessageAck: void <init>(org.apache.activemq.command.Message,byte,int)>(v, 1, 1);
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void removeMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.MessageAck)>(v, v);
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.Broker broker>;
v = interfaceinvoke v.<org.apache.activemq.broker.Broker: org.apache.activemq.broker.Broker getRoot()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: org.apache.activemq.command.Message getMessage()>();
v = new java.lang.Throwable;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.ActiveMQDestination)>(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[])>("duplicate paged in from cursor for \u0001");
specialinvoke v.<java.lang.Throwable: void <init>(java.lang.String)>(v);
interfaceinvoke v.<org.apache.activemq.broker.Broker: boolean sendToDeadLetterQueue(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference,org.apache.activemq.broker.region.Subscription,java.lang.Throwable)>(v, v, null, v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean hasSpace()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isFlowControlLogRequired()>();
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.MemoryUsage getMemoryUsage()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("{} cursor blocked, no space available to page in messages; usage: {}", v, v);
goto label;
label:
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: org.apache.activemq.usage.MemoryUsage getMemoryUsage()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("{} cursor blocked, no space available to page in messages; usage: {}", v, v);
label:
if v == null goto label;
v = v;
goto label;
label:
v = new org.apache.activemq.broker.region.cursors.OrderedPendingList;
v = v;
specialinvoke v.<org.apache.activemq.broker.region.cursors.OrderedPendingList: void <init>()>();
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private final boolean haveRealConsumer()
{
java.util.List v;
org.apache.activemq.broker.region.Queue v;
int v, v, v;
boolean v;
java.util.concurrent.ConcurrentLinkedQueue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.ConcurrentLinkedQueue browserSubscriptions>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: int size()>();
v = v - v;
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private void doDispatch(org.apache.activemq.broker.region.cursors.PendingList) throws java.lang.Exception
{
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v, v, v, v, v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
boolean v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
java.lang.Throwable v;
org.apache.activemq.broker.region.cursors.PendingList v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.Iterator v, v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.cursors.PendingList;
v = 0;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isPrioritizedMessages()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean isEmpty()>();
if v != 0 goto label;
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: 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.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean contains(org.apache.activemq.broker.region.MessageReference)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: org.apache.activemq.broker.region.cursors.PendingNode addMessageLast(org.apache.activemq.broker.region.MessageReference)>(v);
goto label;
label:
v = null;
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList doActualDispatch(org.apache.activemq.broker.region.cursors.PendingList)>(v);
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean isEmpty()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList doActualDispatch(org.apache.activemq.broker.region.cursors.PendingList)>(v);
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: void addAll(org.apache.activemq.broker.region.cursors.PendingList)>(v);
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: 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.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: boolean contains(org.apache.activemq.broker.region.MessageReference)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: org.apache.activemq.broker.region.cursors.PendingNode addMessageLast(org.apache.activemq.broker.region.MessageReference)>(v);
goto label;
label:
v = 1;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
if v == 0 goto label;
specialinvoke v.<org.apache.activemq.broker.region.Queue: void asyncWakeup()>();
label:
return;
catch java.lang.Throwable from label to label with label;
}
private org.apache.activemq.broker.region.cursors.PendingList doActualDispatch(org.apache.activemq.broker.region.cursors.PendingList) throws java.lang.Exception
{
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.command.ConsumerId v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v;
java.util.List v, v, v, v;
org.apache.activemq.broker.region.QueueDispatchSelector v, v;
java.lang.Throwable v, v;
org.apache.activemq.broker.region.cursors.PendingList v;
org.apache.activemq.broker.region.Subscription v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v, v;
java.util.ArrayList v, v, v;
java.util.HashSet v;
int v, v, v, v;
org.apache.activemq.command.ConsumerInfo v;
org.apache.activemq.broker.region.MessageReference v;
org.slf4j.Logger v, v;
java.util.Iterator v, v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.cursors.PendingList;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
return v;
label:
v = new java.util.ArrayList;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
v = new java.util.HashSet;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: int size()>();
specialinvoke v.<java.util.HashSet: void <init>(int)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: 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 = null;
v = interfaceinvoke v.<java.util.List: 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 instanceof org.apache.activemq.broker.region.QueueBrowserSubscription;
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: boolean isFull()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: boolean canSelect(org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.MessageReference)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean assignMessageGroup(org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.QueueMessageReference)>(v, v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: boolean isAcked()>();
if v != 0 goto label;
interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: void add(org.apache.activemq.broker.region.MessageReference)>(v);
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: org.apache.activemq.command.ConsumerId getConsumerId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("assigned {} to consumer {}", v, v);
interfaceinvoke v.<java.util.Iterator: void remove()>();
v = v;
goto label;
label:
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Subscription full {}", v);
goto label;
label:
if v != null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: boolean isDropped()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: void remove()>();
label:
if v != null goto label;
v = interfaceinvoke v.<java.util.List: int size()>();
v = interfaceinvoke v.<java.util.Set: int size()>();
if v != v goto label;
return v;
label:
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Queue: boolean strictOrderDispatch>;
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 1 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueDispatchSelector dispatchSelector>;
v = virtualinvoke v.<org.apache.activemq.broker.region.QueueDispatchSelector: boolean isExclusiveConsumer(org.apache.activemq.broker.region.Subscription)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: boolean removeFromConsumerList(org.apache.activemq.broker.region.Subscription)>(v);
if v == 0 goto label;
specialinvoke v.<org.apache.activemq.broker.region.Queue: void addToConsumerList(org.apache.activemq.broker.region.Subscription)>(v);
v = new java.util.ArrayList;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
v = v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
protected boolean assignMessageGroup(org.apache.activemq.broker.region.Subscription, org.apache.activemq.broker.region.QueueMessageReference) throws java.lang.Exception
{
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.region.group.MessageGroupMap v;
org.apache.activemq.command.ConsumerId v, v;
org.apache.activemq.command.ActiveMQDestination v;
int v;
java.lang.String v;
org.apache.activemq.broker.region.QueueMessageReference v;
org.apache.activemq.command.ConsumerInfo v, v;
boolean v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: org.apache.activemq.broker.region.QueueMessageReference;
v = 1;
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: java.lang.String getGroupID()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.QueueMessageReference: int getGroupSequence()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.group.MessageGroupMap getMessageGroupOwners()>();
if v != 1 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void assignGroup(org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.group.MessageGroupMap,org.apache.activemq.broker.region.MessageReference,java.lang.String)>(v, v, v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.group.MessageGroupMap: org.apache.activemq.command.ConsumerId get(java.lang.String)>(v);
if v != null goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Queue: void assignGroup(org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.group.MessageGroupMap,org.apache.activemq.broker.region.MessageReference,java.lang.String)>(v, v, v, v);
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: org.apache.activemq.command.ConsumerId getConsumerId()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerId: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
if v >= 0 goto label;
interfaceinvoke v.<org.apache.activemq.broker.region.group.MessageGroupMap: org.apache.activemq.command.ConsumerId removeGroup(java.lang.String)>(v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: void decrementAssignedGroupCount(org.apache.activemq.command.ActiveMQDestination)>(v);
goto label;
label:
v = 0;
label:
return v;
}
protected void assignGroup(org.apache.activemq.broker.region.Subscription, org.apache.activemq.broker.region.group.MessageGroupMap, org.apache.activemq.broker.region.MessageReference, java.lang.String) throws java.io.IOException
{
org.apache.activemq.broker.region.MessageReference v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.region.group.MessageGroupMap v;
org.apache.activemq.command.ConsumerId v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.command.Message v;
java.lang.String v;
org.apache.activemq.command.ConsumerInfo v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: org.apache.activemq.broker.region.group.MessageGroupMap;
v := @parameter: org.apache.activemq.broker.region.MessageReference;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: org.apache.activemq.command.ConsumerId getConsumerId()>();
interfaceinvoke v.<org.apache.activemq.broker.region.group.MessageGroupMap: void put(java.lang.String,org.apache.activemq.command.ConsumerId)>(v, v);
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.Message getMessage()>();
virtualinvoke v.<org.apache.activemq.command.Message: void setJMSXGroupFirstForConsumer(boolean)>(1);
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.ActiveMQDestination destination>;
virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: void incrementAssignedGroupCount(org.apache.activemq.command.ActiveMQDestination)>(v);
return;
}
protected void pageInMessages(boolean, int) throws java.lang.Exception
{
org.apache.activemq.broker.region.cursors.PendingList v;
org.apache.activemq.broker.region.Queue v;
int v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: boolean;
v := @parameter: int;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList doPageInForDispatch(boolean,boolean,int)>(v, 1, v);
specialinvoke v.<org.apache.activemq.broker.region.Queue: void doDispatch(org.apache.activemq.broker.region.cursors.PendingList)>(v);
return;
}
private void addToConsumerList(org.apache.activemq.broker.region.Subscription)
{
java.util.List v, v, v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.broker.region.Queue v;
java.util.Comparator v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v = v.<org.apache.activemq.broker.region.Queue: boolean useConsumerPriority>;
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = v.<org.apache.activemq.broker.region.Queue: java.util.Comparator orderedCompare>;
staticinvoke <java.util.Collections: void sort(java.util.List,java.util.Comparator)>(v, v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
return;
}
private boolean removeFromConsumerList(org.apache.activemq.broker.region.Subscription)
{
java.util.List v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.broker.region.Queue v;
boolean v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
return v;
}
private int getConsumerMessageCountBeforeFull() throws java.lang.Exception
{
java.lang.Throwable v;
java.util.Iterator v;
org.apache.activemq.broker.region.Queue v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.List v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v, v;
java.lang.Object v;
boolean v, v;
v := @this: org.apache.activemq.broker.region.Queue;
v = 0;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: 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.<org.apache.activemq.broker.region.Subscription: boolean isBrowser()>();
if v != 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: int countBeforeFull()>();
v = v + v;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public void processDispatchNotification(org.apache.activemq.command.MessageDispatchNotification) throws java.lang.Exception
{
org.apache.activemq.command.MessageDispatchNotification v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.broker.region.QueueMessageReference v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.MessageDispatchNotification;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.Subscription getMatchingSubscription(org.apache.activemq.command.MessageDispatchNotification)>(v);
if v == null goto label;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueMessageReference getMatchingMessage(org.apache.activemq.command.MessageDispatchNotification)>(v);
interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: void add(org.apache.activemq.broker.region.MessageReference)>(v);
interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: void processMessageDispatchNotification(org.apache.activemq.command.MessageDispatchNotification)>(v);
label:
return;
}
private org.apache.activemq.broker.region.QueueMessageReference getMatchingMessage(org.apache.activemq.command.MessageDispatchNotification) throws java.lang.Exception
{
org.apache.activemq.broker.region.cursors.QueueDispatchPendingList v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v, v, v;
org.apache.activemq.command.ConsumerId v;
org.apache.activemq.command.Message v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
boolean v, v, v, v;
org.apache.activemq.broker.region.Queue v;
org.apache.activemq.command.MessageId v, v, v, v;
javax.jms.JMSException v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v, v, v, v, v, v;
java.lang.Throwable v, v, v, v;
org.apache.activemq.broker.region.cursors.PendingList v;
org.apache.activemq.command.MessageDispatchNotification v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v, v, v, v, v;
int v, v;
java.lang.String v;
org.apache.activemq.broker.region.MessageReference v, v;
java.util.Iterator v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.MessageDispatchNotification;
v = virtualinvoke v.<org.apache.activemq.command.MessageDispatchNotification: org.apache.activemq.command.MessageId getMessageId()>();
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: 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.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: org.apache.activemq.broker.region.cursors.PendingNode remove(org.apache.activemq.broker.region.MessageReference)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInPendingDispatchLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
if v != null goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingList pagedInMessages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingList: org.apache.activemq.broker.region.MessageReference get(org.apache.activemq.command.MessageId)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock pagedInMessagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
if v != null goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getMaxPageSize()>();
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void setMaxBatchSize(int)>(v);
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void reset()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: boolean hasNext()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: org.apache.activemq.broker.region.MessageReference next()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void remove()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageId: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.Message getMessage()>();
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueMessageReference createMessageReference(org.apache.activemq.command.Message)>(v);
label:
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void release()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.PendingMessageCursor messages>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void release()>();
throw v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock messagesLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
if v != null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.command.Message loadMessage(org.apache.activemq.command.MessageId)>(v);
if v == null goto label;
v = specialinvoke v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.QueueMessageReference createMessageReference(org.apache.activemq.command.Message)>(v);
label:
if v != null goto label;
v = new javax.jms.JMSException;
v = virtualinvoke v.<org.apache.activemq.command.MessageDispatchNotification: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageDispatchNotification: org.apache.activemq.command.ActiveMQDestination getDestination()>();
v = v.<org.apache.activemq.broker.region.Queue: org.apache.activemq.broker.region.cursors.QueueDispatchPendingList dispatchPendingList>;
v = virtualinvoke v.<org.apache.activemq.broker.region.cursors.QueueDispatchPendingList: int size()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageDispatchNotification: org.apache.activemq.command.ConsumerId getConsumerId()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.activemq.command.MessageId,org.apache.activemq.command.ActiveMQDestination,int,org.apache.activemq.command.ConsumerId)>(v, 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[])>("Slave broker out of sync with master - Message: \u on \u does not exist among pending(\u) for subscription: \u0001");
specialinvoke v.<javax.jms.JMSException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private org.apache.activemq.broker.region.Subscription getMatchingSubscription(org.apache.activemq.command.MessageDispatchNotification) throws javax.jms.JMSException
{
java.lang.Throwable v;
org.apache.activemq.command.MessageDispatchNotification v;
org.apache.activemq.broker.region.Subscription v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
org.apache.activemq.command.ConsumerId v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
org.apache.activemq.command.ConsumerInfo v;
boolean v, v;
java.util.Iterator v;
org.apache.activemq.broker.region.Queue v;
java.util.List v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.command.MessageDispatchNotification;
v = null;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.command.MessageDispatchNotification: org.apache.activemq.command.ConsumerId getConsumerId()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: org.apache.activemq.command.ConsumerId getConsumerId()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerId: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = v;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public void onUsageChanged(org.apache.activemq.usage.Usage, int, int)
{
org.apache.activemq.broker.region.Queue v;
int v, v;
org.apache.activemq.usage.Usage v;
v := @this: org.apache.activemq.broker.region.Queue;
v := @parameter: org.apache.activemq.usage.Usage;
v := @parameter: int;
v := @parameter: int;
if v <= v goto label;
specialinvoke v.<org.apache.activemq.broker.region.Queue: void asyncWakeup()>();
label:
return;
}
protected org.slf4j.Logger getLog()
{
org.slf4j.Logger v;
org.apache.activemq.broker.region.Queue v;
v := @this: org.apache.activemq.broker.region.Queue;
v = <org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG>;
return v;
}
protected boolean isOptimizeStorage()
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v, v, v;
boolean v, v, v, v, v;
java.util.Iterator v;
org.apache.activemq.broker.region.Queue v;
java.util.List v, v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Queue;
v = 0;
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: boolean isDoOptimzeMessageStorage()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
v = v.<org.apache.activemq.broker.region.Queue: java.util.List consumers>;
v = interfaceinvoke v.<java.util.List: 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.<org.apache.activemq.broker.region.Subscription: int getPrefetchSize()>();
if v != 0 goto label;
v = 0;
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: boolean isSlowConsumer()>();
if v == 0 goto label;
v = 0;
goto label;
label:
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: int getInFlightUsage()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Queue: int getOptimizeMessageStoreInFlightLimit()>();
if v <= v goto label;
v = 0;
label:
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Queue: java.util.concurrent.locks.ReentrantReadWriteLock consumersLock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/broker/region/Queue;");
<org.apache.activemq.broker.region.Queue: org.slf4j.Logger LOG> = v;
return;
}
}