public class org.apache.activemq.broker.region.Topic extends org.apache.activemq.broker.region.BaseDestination implements org.apache.activemq.thread.Task
{
protected static final org.slf4j.Logger LOG;
private final org.apache.activemq.store.TopicMessageStore topicStore;
protected final java.util.concurrent.CopyOnWriteArrayList consumers;
private final java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock;
private org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy;
private org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy;
private final java.util.concurrent.ConcurrentMap durableSubscribers;
private final org.apache.activemq.thread.TaskRunner taskRunner;
private final org.apache.activemq.thread.TaskRunnerFactory taskRunnerFactor;
private final java.util.LinkedList messagesWaitingForSpace;
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;
public void <init>(org.apache.activemq.broker.BrokerService, org.apache.activemq.command.ActiveMQDestination, org.apache.activemq.store.TopicMessageStore, org.apache.activemq.broker.region.DestinationStatistics, org.apache.activemq.thread.TaskRunnerFactory) throws java.lang.Exception
{
org.apache.activemq.broker.region.Topic$1 v;
org.apache.activemq.broker.region.Topic$7 v;
org.apache.activemq.broker.region.Topic$6 v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.locks.ReentrantReadWriteLock v;
org.apache.activemq.broker.region.policy.RetainedMessageSubscriptionRecoveryPolicy v;
java.lang.String v, v;
java.util.LinkedList v;
org.apache.activemq.broker.BrokerService v;
org.apache.activemq.broker.region.Topic v;
java.util.concurrent.ConcurrentHashMap v;
org.apache.activemq.broker.region.policy.SimpleDispatchPolicy v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.store.TopicMessageStore v;
org.apache.activemq.thread.TaskRunner v;
org.apache.activemq.thread.TaskRunnerFactory v;
org.apache.activemq.broker.region.DestinationStatistics v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.BrokerService;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: org.apache.activemq.store.TopicMessageStore;
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.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers> = v;
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock> = v;
v = new org.apache.activemq.broker.region.policy.SimpleDispatchPolicy;
specialinvoke v.<org.apache.activemq.broker.region.policy.SimpleDispatchPolicy: void <init>()>();
v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.ConcurrentMap durableSubscribers> = v;
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v.<org.apache.activemq.broker.region.Topic: java.util.LinkedList messagesWaitingForSpace> = v;
v = new org.apache.activemq.broker.region.Topic$1;
specialinvoke v.<org.apache.activemq.broker.region.Topic$1: void <init>(org.apache.activemq.broker.region.Topic)>(v);
v.<org.apache.activemq.broker.region.Topic: 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.Topic: java.util.concurrent.atomic.AtomicBoolean expiryTaskInProgress> = v;
v = new org.apache.activemq.broker.region.Topic$6;
specialinvoke v.<org.apache.activemq.broker.region.Topic$6: void <init>(org.apache.activemq.broker.region.Topic)>(v);
v.<org.apache.activemq.broker.region.Topic: java.lang.Runnable expireMessagesWork> = v;
v = new org.apache.activemq.broker.region.Topic$7;
specialinvoke v.<org.apache.activemq.broker.region.Topic$7: void <init>(org.apache.activemq.broker.region.Topic)>(v);
v.<org.apache.activemq.broker.region.Topic: java.lang.Runnable expireMessagesTask> = v;
v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore> = v;
v = new org.apache.activemq.broker.region.policy.RetainedMessageSubscriptionRecoveryPolicy;
specialinvoke v.<org.apache.activemq.broker.region.policy.RetainedMessageSubscriptionRecoveryPolicy: void <init>(org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy)>(null);
v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy> = v;
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[])>("Topic  \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.Topic: org.apache.activemq.thread.TaskRunner taskRunner> = v;
v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.thread.TaskRunnerFactory taskRunnerFactor> = v;
return;
}
public void initialize() throws java.lang.Exception
{
org.apache.activemq.store.MessageStore v, v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.broker.region.policy.LastImageSubscriptionRecoveryPolicy v;
boolean v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Topic;
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void initialize()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination destination>;
v = staticinvoke <org.apache.activemq.advisory.AdvisorySupport: boolean isMasterBrokerAdvisoryTopic(org.apache.activemq.command.ActiveMQDestination)>(v);
if v == 0 goto label;
v = new org.apache.activemq.broker.region.policy.LastImageSubscriptionRecoveryPolicy;
specialinvoke v.<org.apache.activemq.broker.region.policy.LastImageSubscriptionRecoveryPolicy: void <init>()>();
v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy> = v;
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void setAlwaysRetroactive(boolean)>(1);
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.MessageStore store>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.MessageStore store>;
interfaceinvoke v.<org.apache.activemq.store.MessageStore: void start()>();
label:
return;
}
public java.util.List getConsumers()
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Topic v;
java.util.ArrayList v;
java.util.concurrent.CopyOnWriteArrayList v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = new java.util.ArrayList;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
public boolean lock(org.apache.activemq.broker.region.MessageReference, org.apache.activemq.broker.region.LockOwner)
{
org.apache.activemq.broker.region.LockOwner v;
org.apache.activemq.broker.region.MessageReference v;
org.apache.activemq.broker.region.Topic v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.region.MessageReference;
v := @parameter: org.apache.activemq.broker.region.LockOwner;
return 1;
}
public void addSubscription(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription) throws java.lang.Exception
{
org.apache.activemq.util.SubscriptionKey v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.ConnectionContext v;
boolean v, v, v, v, v, v, v, v, v, v, v;
java.util.concurrent.CopyOnWriteArrayList v, v, v, v, v, v, v, v, v, v;
java.lang.Throwable v, v, v, v;
org.apache.activemq.broker.region.Subscription v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.ConcurrentMap v;
int v;
org.apache.activemq.command.ConsumerInfo v, v, v;
org.apache.activemq.broker.region.Topic v;
java.util.Iterator v;
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isDurable()>();
if v != 0 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 isRetroactive()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: boolean isAlwaysRetroactive()>();
if v == 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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 = 0;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean contains(java.lang.Object)>(v);
if v != 0 goto 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.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean add(java.lang.Object)>(v);
v = 1;
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void addSubscription(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription)>(v, v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
interfaceinvoke v.<org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy: void recover(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Topic,org.apache.activemq.broker.region.SubscriptionRecovery)>(v, v, v);
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean contains(java.lang.Object)>(v);
if v != 0 goto 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.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean add(java.lang.Object)>(v);
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void addSubscription(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription)>(v, v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
specialinvoke v.<org.apache.activemq.broker.region.BaseDestination: void addSubscription(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription)>(v, v);
interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: void add(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Destination)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: boolean isActive()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = 0;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: int size()>();
if v != 0 goto label;
v = 0;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: 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 isDurable()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.util.SubscriptionKey getSubscriptionKey()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.util.SubscriptionKey getSubscriptionKey()>();
v = virtualinvoke v.<org.apache.activemq.util.SubscriptionKey: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = 1;
label:
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean add(java.lang.Object)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.util.SubscriptionKey getSubscriptionKey()>();
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
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
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.broker.region.Subscription v;
long v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.ConsumerInfo v;
boolean v, v;
java.util.concurrent.CopyOnWriteArrayList v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: long;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isDurable()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean remove(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v == 0 goto label;
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);
label:
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);
return;
catch java.lang.Throwable from label to label with label;
}
public void deleteSubscription(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.util.SubscriptionKey) throws java.lang.Exception
{
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.util.SubscriptionKey v;
java.util.concurrent.ConcurrentMap v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v;
org.apache.activemq.store.TopicMessageStore v, v;
java.lang.Object v;
java.lang.String v, v;
org.apache.activemq.broker.region.DestinationStatistics v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.util.SubscriptionKey;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = v.<org.apache.activemq.util.SubscriptionKey: java.lang.String clientId>;
v = v.<org.apache.activemq.util.SubscriptionKey: java.lang.String subscriptionName>;
interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: void deleteSubscription(java.lang.String,java.lang.String)>(v, v);
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.DestinationStatistics destinationStatistics>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getConsumers()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void decrement()>();
virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: void deactivate(boolean,long)>(0, 0L);
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean remove(java.lang.Object)>(v);
label:
return;
}
private boolean hasDurableSubChanged(org.apache.activemq.command.SubscriptionInfo, org.apache.activemq.command.ConsumerInfo) throws java.io.IOException
{
org.apache.activemq.command.SubscriptionInfo v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.command.ConsumerInfo v;
boolean v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.command.SubscriptionInfo;
v := @parameter: org.apache.activemq.command.ConsumerInfo;
v = specialinvoke v.<org.apache.activemq.broker.region.Topic: boolean hasSelectorChanged(org.apache.activemq.command.SubscriptionInfo,org.apache.activemq.command.ConsumerInfo)>(v, v);
if v == 0 goto label;
return 1;
label:
v = specialinvoke v.<org.apache.activemq.broker.region.Topic: boolean hasNoLocalChanged(org.apache.activemq.command.SubscriptionInfo,org.apache.activemq.command.ConsumerInfo)>(v, v);
return v;
}
private boolean hasNoLocalChanged(org.apache.activemq.command.SubscriptionInfo, org.apache.activemq.command.ConsumerInfo) throws java.io.IOException
{
org.apache.activemq.broker.BrokerService v;
org.apache.activemq.command.SubscriptionInfo v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.broker.Broker v;
org.apache.activemq.store.PersistenceAdapter v;
org.apache.activemq.command.ConsumerInfo v;
boolean v, v, v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.command.SubscriptionInfo;
v := @parameter: org.apache.activemq.command.ConsumerInfo;
v = v.<org.apache.activemq.broker.region.Topic: 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: org.apache.activemq.store.PersistenceAdapter getPersistenceAdapter()>();
v = v instanceof org.apache.activemq.store.NoLocalSubscriptionAware;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: boolean isNoLocal()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isNoLocal()>();
v = v ^ v;
if v == 0 goto label;
return 1;
label:
return 0;
}
private boolean hasSelectorChanged(org.apache.activemq.command.SubscriptionInfo, org.apache.activemq.command.ConsumerInfo)
{
org.apache.activemq.command.SubscriptionInfo v;
org.apache.activemq.broker.region.Topic v;
java.lang.String v, v, v, v, v;
org.apache.activemq.command.ConsumerInfo v;
boolean v, v, v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.command.SubscriptionInfo;
v := @parameter: org.apache.activemq.command.ConsumerInfo;
v = virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: java.lang.String getSelector()>();
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: java.lang.String getSelector()>();
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v ^ v;
if v == 0 goto label;
return 1;
label:
v = virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: java.lang.String getSelector()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: java.lang.String getSelector()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: java.lang.String getSelector()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
return 1;
label:
return 0;
}
public void activate(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.DurableTopicSubscription) throws java.lang.Exception
{
org.apache.activemq.broker.region.Topic$2 v;
org.apache.activemq.filter.NonCachedMessageEvaluationContext v;
org.apache.activemq.util.SubscriptionKey v, v;
org.apache.activemq.broker.region.DurableTopicSubscription v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v;
org.apache.activemq.broker.ConnectionContext v;
boolean v, v, v, v, v;
org.apache.activemq.command.ActiveMQDestination v, v, v;
java.util.concurrent.CopyOnWriteArrayList v, v, v, v, v, v, v;
java.lang.Throwable v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.lang.String v, v, v, v;
org.apache.activemq.command.ConsumerInfo v, v, v, v, v, v;
org.apache.activemq.command.SubscriptionInfo v, v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.store.TopicMessageStore v, v, v, v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.DurableTopicSubscription;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
if v != null goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.util.SubscriptionKey getSubscriptionKey()>();
v = virtualinvoke v.<org.apache.activemq.util.SubscriptionKey: java.lang.String getClientId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.util.SubscriptionKey getSubscriptionKey()>();
v = virtualinvoke v.<org.apache.activemq.util.SubscriptionKey: java.lang.String getSubscriptionName()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: org.apache.activemq.command.SubscriptionInfo lookupSubscription(java.lang.String,java.lang.String)>(v, v);
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = specialinvoke v.<org.apache.activemq.broker.region.Topic: boolean hasDurableSubChanged(org.apache.activemq.command.SubscriptionInfo,org.apache.activemq.command.ConsumerInfo)>(v, v);
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: void deleteSubscription(java.lang.String,java.lang.String)>(v, v);
v = null;
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: java.lang.String getSelector()>();
virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: void setSelector(java.lang.String)>(v);
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean remove(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean add(java.lang.Object)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v != null goto label;
v = new org.apache.activemq.command.SubscriptionInfo;
specialinvoke v.<org.apache.activemq.command.SubscriptionInfo: void <init>()>();
virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: void setClientId(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: java.lang.String getSelector()>();
virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: void setSelector(java.lang.String)>(v);
virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: void setSubscriptionName(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: void setDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isNoLocal()>();
virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: void setNoLocal(boolean)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: org.apache.activemq.command.ActiveMQDestination getDestination()>();
virtualinvoke v.<org.apache.activemq.command.SubscriptionInfo: void setSubscribedDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean add(java.lang.Object)>(v);
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isRetroactive()>();
interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: void addSubscription(org.apache.activemq.command.SubscriptionInfo,boolean)>(v, v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = new org.apache.activemq.filter.NonCachedMessageEvaluationContext;
specialinvoke v.<org.apache.activemq.filter.NonCachedMessageEvaluationContext: void <init>()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination destination>;
virtualinvoke v.<org.apache.activemq.filter.MessageEvaluationContext: void setDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: boolean isRecoveryRequired()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = new org.apache.activemq.broker.region.Topic$2;
specialinvoke v.<org.apache.activemq.broker.region.Topic$2: void <init>(org.apache.activemq.broker.region.Topic,org.apache.activemq.filter.MessageEvaluationContext,org.apache.activemq.broker.region.DurableTopicSubscription)>(v, v, v);
interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: void recoverSubscription(java.lang.String,java.lang.String,org.apache.activemq.store.MessageRecoveryListener)>(v, v, v);
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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;
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 deactivate(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.DurableTopicSubscription, java.util.List) throws java.lang.Exception
{
java.lang.Throwable v;
java.util.List v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.broker.region.DurableTopicSubscription v;
java.util.concurrent.CopyOnWriteArrayList v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.DurableTopicSubscription;
v := @parameter: java.util.List;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean remove(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: java.util.List remove(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Destination,java.util.List)>(v, v, v);
return;
catch java.lang.Throwable from label to label with label;
}
public void recoverRetroactiveMessages(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription) throws java.lang.Exception
{
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.command.ConsumerInfo v;
boolean v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v = interfaceinvoke v.<org.apache.activemq.broker.region.Subscription: org.apache.activemq.command.ConsumerInfo getConsumerInfo()>();
v = virtualinvoke v.<org.apache.activemq.command.ConsumerInfo: boolean isRetroactive()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
interfaceinvoke v.<org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy: void recover(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Topic,org.apache.activemq.broker.region.SubscriptionRecovery)>(v, v, v);
label:
return;
}
public void send(org.apache.activemq.broker.ProducerBrokerExchange, org.apache.activemq.command.Message) throws java.lang.Exception
{
org.apache.activemq.broker.region.Topic$3 v;
java.lang.Integer v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.state.ProducerState v;
java.lang.Long v, v;
org.apache.activemq.usage.SystemUsage v;
org.apache.activemq.command.ProducerAck v, v;
org.apache.activemq.broker.ProducerBrokerExchange v;
java.lang.Throwable v;
long v, v, v;
org.apache.activemq.broker.Broker v;
java.lang.String v, v, v, v, v, v;
org.apache.activemq.broker.Connection v, v;
java.io.IOException v;
org.apache.activemq.command.ProducerId v, v, v, v;
org.apache.activemq.management.CountStatisticImpl v, v;
org.apache.activemq.usage.MemoryUsage v, v, v, v, v, v, v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
javax.jms.ResourceAllocationException v;
org.apache.activemq.command.ActiveMQDestination v, v, v, v;
org.apache.activemq.broker.region.DestinationStatistics v, v;
java.util.concurrent.atomic.AtomicBoolean v;
int v, v, v, v, v, v;
java.util.LinkedList v, v;
org.apache.activemq.broker.region.Topic v;
org.slf4j.Logger v, v, v, v;
org.apache.activemq.command.ProducerInfo v;
org.apache.activemq.transaction.Transaction v;
v := @this: org.apache.activemq.broker.region.Topic;
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 = 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()>();
virtualinvoke v.<org.apache.activemq.broker.ProducerBrokerExchange: void incrementSend()>();
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;
virtualinvoke v.<org.apache.activemq.command.Message: void setRegionDestination(org.apache.activemq.command.Message$MessageDestination)>(v);
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isExpired()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: 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, null);
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getExpired()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
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.Topic: 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.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void isFull(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.usage.Usage)>(v, v);
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void fastProducer(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ProducerInfo)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: 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.Topic: boolean isFlowControlLogRequired()>();
if v == 0 goto label;
v = <org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = v.<org.apache.activemq.broker.region.Topic: 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);
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("{}, Usage Manager memory limit reached {}. 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, v);
goto label;
label:
v = <org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = v.<org.apache.activemq.broker.region.Topic: 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);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("{}, Usage Manager memory limit reached {}. 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, v);
label:
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isNetworkConnection()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: boolean isSendFailIfNoSpace()>();
if v == 0 goto label;
v = new javax.jms.ResourceAllocationException;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: long getLimit()>();
v = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.ProducerId getProducerId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getQualifiedName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,org.apache.activemq.command.ProducerId,java.lang.String)>(v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Usage Manager memory limit (\u) reached. Rejecting send for producer (\u) to prevent flooding \u. See http://activemq.apache.org/producer-flow-control.html for more info");
specialinvoke v.<javax.jms.ResourceAllocationException: void <init>(java.lang.String)>(v);
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 = v.<org.apache.activemq.broker.region.Topic: java.util.LinkedList messagesWaitingForSpace>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.LinkedList messagesWaitingForSpace>;
v = new org.apache.activemq.broker.region.Topic$3;
specialinvoke v.<org.apache.activemq.broker.region.Topic$3: void <init>(org.apache.activemq.broker.region.Topic,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);
virtualinvoke v.<java.util.LinkedList: boolean add(java.lang.Object)>(v);
specialinvoke v.<org.apache.activemq.broker.region.Topic: 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.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: boolean isFull()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isInTransaction()>();
if v == 0 goto label;
v = 0;
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: boolean waitForSpace(long)>(1000L);
if v != 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: java.util.concurrent.atomic.AtomicBoolean getStopping()>();
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v == 0 goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("Connection closed, send aborted.");
throw v;
label:
if v <= 2 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isInTransaction()>();
if v == 0 goto label;
v = 0;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.transaction.Transaction getTransaction()>();
v = virtualinvoke v.<org.apache.activemq.transaction.Transaction: int size()>();
v = <org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Waiting for space to send transacted message - transaction elements = {} need more space to commit. Message = {}", v, v);
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: 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 Usage limit reached. Stopping producer (\u) to prevent flooding \u. See http://activemq.apache.org/producer-flow-control.html for more info");
virtualinvoke v.<org.apache.activemq.broker.region.Topic: 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 = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.DestinationStatistics getDestinationStatistics()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DestinationStatistics: org.apache.activemq.management.CountStatisticImpl getExpired()>();
virtualinvoke v.<org.apache.activemq.management.CountStatisticImpl: void increment()>();
v = <org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Expired message: {}", v);
return;
label:
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void doMessageSend(org.apache.activemq.broker.ProducerBrokerExchange,org.apache.activemq.command.Message)>(v, v);
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void messageDelivered(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(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;
}
synchronized void doMessageSend(org.apache.activemq.broker.ProducerBrokerExchange, org.apache.activemq.command.Message) throws java.io.IOException, java.lang.Exception
{
org.apache.activemq.broker.region.Topic$4 v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.usage.SystemUsage v, v, v, v;
boolean v, v, v, v, v, v, v, v;
java.util.concurrent.CancellationException v;
org.apache.activemq.command.MessageId v;
javax.jms.ResourceAllocationException v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.broker.ProducerBrokerExchange v;
java.lang.Throwable v;
long v, v;
org.apache.activemq.store.ListenableFuture v;
int v, v, v;
java.lang.String v, v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.command.ProducerId v;
org.apache.activemq.store.TopicMessageStore v, v;
org.apache.activemq.usage.StoreUsage v, v, v;
org.apache.activemq.transaction.Transaction v, v;
v := @this: org.apache.activemq.broker.region.Topic;
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 = virtualinvoke v.<org.apache.activemq.command.Message: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: long getDestinationSequenceId()>();
virtualinvoke v.<org.apache.activemq.command.MessageId: void setBrokerSequenceId(long)>(v);
v = null;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.command.Message: boolean isPersistent()>();
if v == 0 goto label;
v = specialinvoke v.<org.apache.activemq.broker.region.Topic: boolean canOptimizeOutPersistence()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: 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.Topic: int getStoreUsageHighWaterMark()>();
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: 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 = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: boolean isNetworkConnection()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.SystemUsage systemUsage>;
v = virtualinvoke v.<org.apache.activemq.usage.SystemUsage: boolean isSendFailIfNoSpace()>();
if v == 0 goto label;
v = new javax.jms.ResourceAllocationException;
specialinvoke v.<javax.jms.ResourceAllocationException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: int getStoreUsageHighWaterMark()>();
virtualinvoke v.<org.apache.activemq.broker.region.Topic: 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);
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: boolean isOptimizeStorage()>();
v = interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: org.apache.activemq.store.ListenableFuture asyncAddTopicMessage(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message,boolean)>(v, v, v);
label:
virtualinvoke v.<org.apache.activemq.command.Message: int incrementReferenceCount()>();
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()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.transaction.Transaction getTransaction()>();
v = new org.apache.activemq.broker.region.Topic$4;
specialinvoke v.<org.apache.activemq.broker.region.Topic$4: void <init>(org.apache.activemq.broker.region.Topic,org.apache.activemq.command.Message,org.apache.activemq.broker.ConnectionContext)>(v, v, v);
virtualinvoke v.<org.apache.activemq.transaction.Transaction: void addSynchronization(org.apache.activemq.transaction.Synchronization)>(v);
goto label;
label:
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void dispatch(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v);
label:
virtualinvoke v.<org.apache.activemq.command.Message: int decrementReferenceCount()>();
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.activemq.command.Message: int decrementReferenceCount()>();
throw v;
label:
if v == null goto label;
v = interfaceinvoke v.<java.util.concurrent.Future: boolean isCancelled()>();
if v != 0 goto label;
label:
interfaceinvoke v.<java.util.concurrent.Future: java.lang.Object get()>();
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.util.concurrent.CancellationException from label to label with label;
}
private boolean canOptimizeOutPersistence()
{
org.apache.activemq.broker.region.Topic v;
int v;
boolean v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public java.lang.String toString()
{
org.apache.activemq.broker.region.Topic v;
int v;
java.lang.String v, v;
java.util.concurrent.CopyOnWriteArrayList v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination destination>;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getPhysicalName()>();
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Topic: destination=\u, subscriptions=\u0001");
return v;
}
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.broker.region.MessageReference v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.command.MessageAck v, v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.command.MessageId v;
org.apache.activemq.util.SubscriptionKey v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.store.TopicMessageStore v, v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.activemq.broker.region.Topic;
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;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
if v == null goto label;
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: boolean isPersistent()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.util.SubscriptionKey getSubscriptionKey()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = virtualinvoke v.<org.apache.activemq.util.SubscriptionKey: java.lang.String getClientId()>();
v = virtualinvoke v.<org.apache.activemq.util.SubscriptionKey: java.lang.String getSubscriptionName()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: 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.TopicMessageStore: void acknowledge(org.apache.activemq.broker.ConnectionContext,java.lang.String,java.lang.String,org.apache.activemq.command.MessageId,org.apache.activemq.command.MessageAck)>(v, v, v, v, v);
label:
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void messageConsumed(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
return;
}
public void gc()
{
org.apache.activemq.broker.region.Topic v;
v := @this: org.apache.activemq.broker.region.Topic;
return;
}
public org.apache.activemq.command.Message loadMessage(org.apache.activemq.command.MessageId) throws java.io.IOException
{
org.apache.activemq.command.Message v;
org.apache.activemq.store.TopicMessageStore v, v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.command.MessageId v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.command.MessageId;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: org.apache.activemq.command.Message getMessage(org.apache.activemq.command.MessageId)>(v);
goto label;
label:
v = null;
label:
return v;
}
public void start() throws java.lang.Exception
{
org.apache.activemq.broker.region.Topic v;
java.util.concurrent.atomic.AtomicBoolean v;
long v, v;
java.lang.Runnable v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v;
byte v;
org.apache.activemq.thread.Scheduler v;
org.apache.activemq.usage.MemoryUsage v, v;
boolean v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
interfaceinvoke v.<org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy: void start()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void start()>();
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: long getExpireMessagesPeriod()>();
v = v cmp 0L;
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = staticinvoke <org.apache.activemq.advisory.AdvisorySupport: boolean isAdvisoryTopic(org.apache.activemq.command.ActiveMQDestination)>(v);
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.thread.Scheduler scheduler>;
v = v.<org.apache.activemq.broker.region.Topic: java.lang.Runnable expireMessagesTask>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: long getExpireMessagesPeriod()>();
virtualinvoke v.<org.apache.activemq.thread.Scheduler: void executePeriodically(java.lang.Runnable,long)>(v, v);
label:
return;
}
public void stop() throws java.lang.Exception
{
org.apache.activemq.broker.region.Topic v;
java.util.concurrent.atomic.AtomicBoolean v;
java.lang.Runnable v;
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v;
org.apache.activemq.store.TopicMessageStore v, v;
org.apache.activemq.thread.TaskRunner v, v;
org.apache.activemq.thread.Scheduler v;
org.apache.activemq.usage.MemoryUsage v, v;
boolean v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: org.apache.activemq.thread.TaskRunner taskRunner>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.thread.TaskRunner taskRunner>;
interfaceinvoke v.<org.apache.activemq.thread.TaskRunner: void shutdown()>();
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
interfaceinvoke v.<org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy: void stop()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
virtualinvoke v.<org.apache.activemq.usage.MemoryUsage: void stop()>();
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: void stop()>();
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.thread.Scheduler scheduler>;
v = v.<org.apache.activemq.broker.region.Topic: java.lang.Runnable expireMessagesTask>;
virtualinvoke v.<org.apache.activemq.thread.Scheduler: void cancel(java.lang.Runnable)>(v);
label:
return;
}
public org.apache.activemq.command.Message[] browse()
{
java.lang.Object[] v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.command.Message[] v;
int v, v;
java.util.ArrayList v;
v := @this: org.apache.activemq.broker.region.Topic;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: int getMaxBrowsePageSize()>();
virtualinvoke v.<org.apache.activemq.broker.region.Topic: 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.Topic$5 v;
java.util.ArrayList v;
java.util.concurrent.ConcurrentMap v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
int v, v, v, v;
java.lang.String v;
boolean v, v, v, v;
org.apache.activemq.broker.region.Topic v;
org.slf4j.Logger v;
java.util.Iterator v, v;
org.apache.activemq.command.Message[] v;
java.util.Collection v;
org.apache.activemq.command.ActiveMQDestination v, v;
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v;
java.util.List v;
org.apache.activemq.store.TopicMessageStore v, v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: java.util.List;
v := @parameter: int;
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
if v == null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.store.TopicMessageStore topicStore>;
v = new org.apache.activemq.broker.region.Topic$5;
specialinvoke v.<org.apache.activemq.broker.region.Topic$5: void <init>(org.apache.activemq.broker.region.Topic,java.util.List,java.util.List,int)>(v, v, v, v);
interfaceinvoke v.<org.apache.activemq.store.TopicMessageStore: void recover(org.apache.activemq.store.MessageRecoveryListener)>(v);
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.ConnectionContext createConnectionContext()>();
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.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: boolean isActive()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: boolean isEnableMessageExpirationOnActiveDurableSubs()>();
if v == 0 goto label;
label:
virtualinvoke v.<org.apache.activemq.command.Message: void setRegionDestination(org.apache.activemq.command.Message$MessageDestination)>(v);
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void messageExpired(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.Subscription,org.apache.activemq.broker.region.MessageReference)>(v, v, v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = interfaceinvoke v.<org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy: org.apache.activemq.command.Message[] browse(org.apache.activemq.command.ActiveMQDestination)>(v);
if v == null goto label;
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = v[v];
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination getActiveMQDestination()>();
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getPhysicalName()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Failed to browse Topic: {}", v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
public boolean iterate()
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Topic v;
java.lang.Object v;
org.apache.activemq.usage.MemoryUsage v;
java.util.LinkedList v, v, v, v;
boolean v, v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: java.util.LinkedList messagesWaitingForSpace>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: java.util.LinkedList messagesWaitingForSpace>;
v = virtualinvoke v.<java.util.LinkedList: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: java.util.LinkedList messagesWaitingForSpace>;
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object removeFirst()>();
interfaceinvoke v.<java.lang.Runnable: void run()>();
goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.LinkedList messagesWaitingForSpace>;
v = virtualinvoke v.<java.util.LinkedList: boolean isEmpty()>();
if v != 0 goto label;
specialinvoke v.<org.apache.activemq.broker.region.Topic: void registerCallbackForNotFullNotification()>();
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return 0;
catch java.lang.Throwable from label to label with label;
}
private void registerCallbackForNotFullNotification()
{
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.usage.MemoryUsage v;
java.lang.Runnable v, v;
boolean v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.usage.MemoryUsage memoryUsage>;
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: java.lang.Runnable sendMessagesWaitingForSpaceTask>;
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
return;
}
public org.apache.activemq.broker.region.policy.DispatchPolicy getDispatchPolicy()
{
org.apache.activemq.broker.region.policy.DispatchPolicy v;
org.apache.activemq.broker.region.Topic v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.region.policy.DispatchPolicy;
v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy> = v;
return;
}
public org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy getSubscriptionRecoveryPolicy()
{
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v;
org.apache.activemq.broker.region.Topic v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
return v;
}
public void setSubscriptionRecoveryPolicy(org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy)
{
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v, v, v, v;
org.apache.activemq.broker.region.Topic v;
boolean v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
if v == null goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
v = v instanceof org.apache.activemq.broker.region.policy.RetainedMessageSubscriptionRecoveryPolicy;
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
virtualinvoke v.<org.apache.activemq.broker.region.policy.RetainedMessageSubscriptionRecoveryPolicy: void setWrapped(org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy)>(v);
goto label;
label:
v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy> = v;
label:
return;
}
public final void wakeup()
{
org.apache.activemq.broker.region.Topic v;
v := @this: org.apache.activemq.broker.region.Topic;
return;
}
protected void dispatch(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.Message) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.Message v;
org.apache.activemq.management.CountStatisticImpl v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v, v, v;
org.apache.activemq.filter.MessageEvaluationContext v;
boolean v, v, v, v, v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.broker.region.DestinationStatistics v, v;
java.util.concurrent.CopyOnWriteArrayList v, v, v;
java.lang.Throwable v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v, v;
int v;
org.apache.activemq.broker.region.policy.DispatchPolicy v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.management.SizeStatisticImpl v;
org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.Message;
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: 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);
v = null;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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.Topic: org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy subscriptionRecoveryPolicy>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.policy.SubscriptionRecoveryPolicy: boolean add(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.broker.region.MessageReference)>(v, v);
if v != 0 goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = virtualinvoke v.<java.util.concurrent.CopyOnWriteArrayList: boolean isEmpty()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void onMessageWithNoConsumers(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v);
exitmonitor v;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: 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 = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.filter.MessageEvaluationContext getMessageEvaluationContext()>();
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination destination>;
virtualinvoke v.<org.apache.activemq.filter.MessageEvaluationContext: void setDestination(org.apache.activemq.command.ActiveMQDestination)>(v);
virtualinvoke v.<org.apache.activemq.filter.MessageEvaluationContext: void setMessageReference(org.apache.activemq.broker.region.MessageReference)>(v);
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.broker.region.policy.DispatchPolicy dispatchPolicy>;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.CopyOnWriteArrayList consumers>;
v = interfaceinvoke v.<org.apache.activemq.broker.region.policy.DispatchPolicy: boolean dispatch(org.apache.activemq.broker.region.MessageReference,org.apache.activemq.filter.MessageEvaluationContext,java.util.List)>(v, v, v);
if v != 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.Topic: void onMessageWithNoConsumers(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.Message)>(v, v);
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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()>();
virtualinvoke v.<org.apache.activemq.filter.MessageEvaluationContext: void clear()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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()>();
if v == null goto label;
virtualinvoke v.<org.apache.activemq.filter.MessageEvaluationContext: void clear()>();
label:
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void messageExpired(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.broker.region.Subscription, org.apache.activemq.broker.region.MessageReference)
{
org.apache.activemq.broker.region.MessageReference v;
org.apache.activemq.broker.region.Topic v;
org.apache.activemq.command.MessageAck v;
org.slf4j.Logger v;
org.apache.activemq.broker.region.Subscription v;
org.apache.activemq.command.MessageId v;
java.lang.Exception v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.broker.Broker v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.management.CountStatisticImpl v;
org.apache.activemq.broker.region.DestinationStatistics v;
boolean v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.broker.region.Subscription;
v := @parameter: org.apache.activemq.broker.region.MessageReference;
v = v.<org.apache.activemq.broker.region.Topic: 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.Topic: 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()>();
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.Topic: 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.MessageReference: org.apache.activemq.command.MessageId getMessageId()>();
virtualinvoke v.<org.apache.activemq.command.MessageAck: void setMessageID(org.apache.activemq.command.MessageId)>(v);
label:
v = v instanceof org.apache.activemq.broker.region.DurableTopicSubscription;
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: void removePending(org.apache.activemq.broker.region.MessageReference)>(v);
label:
virtualinvoke v.<org.apache.activemq.broker.region.Topic: 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:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Topic: 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.Exception from label to label with label;
}
protected org.slf4j.Logger getLog()
{
org.apache.activemq.broker.region.Topic v;
org.slf4j.Logger v;
v := @this: org.apache.activemq.broker.region.Topic;
v = <org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG>;
return v;
}
protected boolean isOptimizeStorage()
{
org.apache.activemq.broker.region.Topic v;
java.util.Iterator v;
java.util.Collection v;
java.util.concurrent.ConcurrentMap v, v;
int v, v, v;
java.lang.Object v;
boolean v, v, v, v, v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v = 0;
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: boolean isDoOptimzeMessageStorage()>();
if v == 0 goto label;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: boolean isActive()>();
if v != 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: int getPrefetchSize()>();
if v != 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: boolean isSlowConsumer()>();
if v == 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: int getInFlightUsage()>();
v = virtualinvoke v.<org.apache.activemq.broker.region.Topic: int getOptimizeMessageStoreInFlightLimit()>();
if v <= v goto label;
v = 0;
label:
return v;
}
public void clearPendingMessages(int)
{
java.lang.Throwable v;
org.apache.activemq.broker.region.Topic v;
java.util.Iterator v;
java.util.Collection v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.ConcurrentMap v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
int v;
java.lang.Object v;
boolean v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: int;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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()>();
specialinvoke v.<org.apache.activemq.broker.region.Topic: void clearPendingAndDispatch(org.apache.activemq.broker.region.DurableTopicSubscription)>(v);
goto label;
label:
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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.Topic: java.util.concurrent.locks.ReentrantReadWriteLock dispatchLock>;
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;
catch java.lang.Throwable from label to label with label;
}
private void clearPendingAndDispatch(org.apache.activemq.broker.region.DurableTopicSubscription)
{
java.lang.Throwable v;
java.lang.Object[] v;
org.apache.activemq.broker.region.Topic v;
org.slf4j.Logger v;
java.io.IOException v;
org.apache.activemq.broker.region.DurableTopicSubscription v;
org.apache.activemq.command.ActiveMQDestination v;
java.lang.Object v;
org.apache.activemq.broker.region.cursors.PendingMessageCursor v, v;
v := @this: org.apache.activemq.broker.region.Topic;
v := @parameter: org.apache.activemq.broker.region.DurableTopicSubscription;
v = v.<org.apache.activemq.broker.region.DurableTopicSubscription: java.lang.Object pendingLock>;
entermonitor v;
label:
v = v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.broker.region.cursors.PendingMessageCursor pending>;
interfaceinvoke v.<org.apache.activemq.broker.region.cursors.PendingMessageCursor: void clear()>();
label:
virtualinvoke v.<org.apache.activemq.broker.region.DurableTopicSubscription: void dispatchPending()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[4];
v[0] = v;
v = v.<org.apache.activemq.broker.region.Topic: org.apache.activemq.command.ActiveMQDestination destination>;
v[1] = v;
v = v.<org.apache.activemq.broker.region.DurableTopicSubscription: org.apache.activemq.broker.region.cursors.PendingMessageCursor pending>;
v[2] = v;
v[3] = v;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object[])>("After clear of pending, failed to dispatch to: {}, for: {}, pending: {}, exception: {}", v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public java.util.Map getDurableTopicSubs()
{
org.apache.activemq.broker.region.Topic v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.activemq.broker.region.Topic;
v = v.<org.apache.activemq.broker.region.Topic: java.util.concurrent.ConcurrentMap durableSubscribers>;
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/broker/region/Topic;");
<org.apache.activemq.broker.region.Topic: org.slf4j.Logger LOG> = v;
return;
}
}