public class org.apache.activemq.util.ConsumerThread extends java.lang.Thread
{
private static final org.slf4j.Logger LOG;
int messageCount;
int receiveTimeOut;
javax.jms.Destination destination;
javax.jms.Session session;
boolean durable;
boolean breakOnNull;
int sleep;
int batchSize;
int received;
int transactions;
boolean running;
java.util.concurrent.CountDownLatch finished;
boolean bytesAsText;
public void <init>(javax.jms.Session, javax.jms.Destination)
{
javax.jms.Session v;
javax.jms.Destination v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: javax.jms.Session;
v := @parameter: javax.jms.Destination;
specialinvoke v.<java.lang.Thread: void <init>()>();
v.<org.apache.activemq.util.ConsumerThread: int messageCount> = 1000;
v.<org.apache.activemq.util.ConsumerThread: int receiveTimeOut> = 3000;
v.<org.apache.activemq.util.ConsumerThread: boolean breakOnNull> = 1;
v.<org.apache.activemq.util.ConsumerThread: int received> = 0;
v.<org.apache.activemq.util.ConsumerThread: int transactions> = 0;
v.<org.apache.activemq.util.ConsumerThread: boolean running> = 0;
v.<org.apache.activemq.util.ConsumerThread: javax.jms.Destination destination> = v;
v.<org.apache.activemq.util.ConsumerThread: javax.jms.Session session> = v;
return;
}
public void run()
{
byte[] v;
javax.jms.Session v, v, v, v, v;
java.lang.Thread v;
java.lang.Exception v;
java.util.concurrent.CountDownLatch v, v, v, v, v, v;
java.lang.Throwable v, v, v, v;
long v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v;
javax.jms.Message v;
boolean v, v, v, v, v, v, v, v;
javax.jms.Destination v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v, v, v, v;
org.apache.activemq.util.ConsumerThread v;
java.lang.Object v;
v := @this: org.apache.activemq.util.ConsumerThread;
v.<org.apache.activemq.util.ConsumerThread: boolean running> = 1;
v = null;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.String getName()>();
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.util.ConsumerThread: int messageCount>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u wait until \u messages are consumed");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
label:
v = v.<org.apache.activemq.util.ConsumerThread: boolean durable>;
if v == 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Destination destination>;
v = v instanceof javax.jms.Topic;
if v == 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Session session>;
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Destination destination>;
v = virtualinvoke v.<org.apache.activemq.util.ConsumerThread: java.lang.String getName()>();
v = interfaceinvoke v.<javax.jms.Session: javax.jms.TopicSubscriber createDurableSubscriber(javax.jms.Topic,java.lang.String)>(v, v);
goto label;
label:
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Session session>;
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Destination destination>;
v = interfaceinvoke v.<javax.jms.Session: javax.jms.MessageConsumer createConsumer(javax.jms.Destination)>(v);
label:
v = v.<org.apache.activemq.util.ConsumerThread: boolean running>;
if v == 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
v = v.<org.apache.activemq.util.ConsumerThread: int messageCount>;
if v >= v goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int receiveTimeOut>;
v = interfaceinvoke v.<javax.jms.MessageConsumer: javax.jms.Message receive(long)>(v);
if v == null goto label;
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = v instanceof javax.jms.TextMessage;
if v == 0 goto label;
v = interfaceinvoke v.<javax.jms.TextMessage: java.lang.String getText()>();
goto label;
label:
v = interfaceinvoke v.<javax.jms.Message: java.lang.String getJMSMessageID()>();
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Received \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
v = v.<org.apache.activemq.util.ConsumerThread: boolean bytesAsText>;
if v == 0 goto label;
v = v instanceof javax.jms.BytesMessage;
if v == 0 goto label;
v = interfaceinvoke v.<javax.jms.BytesMessage: long getBodyLength()>();
v = newarray (byte)[v];
interfaceinvoke v.<javax.jms.BytesMessage: int readBytes(byte[])>(v);
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = new java.lang.String;
specialinvoke v.<java.lang.String: void <init>(byte[])>(v);
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[])>("BytesMessage as text string: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
label:
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
v = v + 1;
v.<org.apache.activemq.util.ConsumerThread: int received> = v;
goto label;
label:
v = v.<org.apache.activemq.util.ConsumerThread: boolean breakOnNull>;
if v != 0 goto label;
label:
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Session session>;
v = interfaceinvoke v.<javax.jms.Session: boolean getTransacted()>();
if v == 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int batchSize>;
if v <= 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
if v <= 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
v = v.<org.apache.activemq.util.ConsumerThread: int batchSize>;
v = v % v;
if v != 0 goto label;
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.util.ConsumerThread: int transactions>;
v = v + 1;
v.<org.apache.activemq.util.ConsumerThread: int transactions> = v;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Committing transaction: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Session session>;
interfaceinvoke v.<javax.jms.Session: void commit()>();
goto label;
label:
v = v.<org.apache.activemq.util.ConsumerThread: javax.jms.Session session>;
v = interfaceinvoke v.<javax.jms.Session: int getAcknowledgeMode()>();
if v != 2 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int batchSize>;
if v <= 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
if v <= 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
v = v.<org.apache.activemq.util.ConsumerThread: int batchSize>;
v = v % v;
if v != 0 goto label;
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.util.ConsumerThread: int batchSize>;
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,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[])>("Acknowledging last \u messages; messages so far = \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
interfaceinvoke v.<javax.jms.Message: void acknowledge()>();
label:
v = v.<org.apache.activemq.util.ConsumerThread: int sleep>;
if v <= 0 goto label;
v = v.<org.apache.activemq.util.ConsumerThread: int sleep>;
staticinvoke <java.lang.Thread: void sleep(long)>(v);
goto label;
label:
v = v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished>;
if v == null goto label;
v = v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished>;
virtualinvoke v.<java.util.concurrent.CountDownLatch: void countDown()>();
label:
if v == null goto label;
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.util.ConsumerThread: int getReceived()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Consumed: \u messages");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
label:
interfaceinvoke v.<javax.jms.MessageConsumer: void close()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<javax.jms.JMSException: void printStackTrace()>();
goto label;
label:
v := @caughtexception;
virtualinvoke v.<java.lang.Exception: void printStackTrace()>();
label:
v = v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished>;
if v == null goto label;
v = v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished>;
virtualinvoke v.<java.util.concurrent.CountDownLatch: void countDown()>();
label:
if v == null goto label;
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.util.ConsumerThread: int getReceived()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Consumed: \u messages");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
label:
interfaceinvoke v.<javax.jms.MessageConsumer: void close()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<javax.jms.JMSException: void printStackTrace()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished>;
if v == null goto label;
v = v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished>;
virtualinvoke v.<java.util.concurrent.CountDownLatch: void countDown()>();
label:
if v == null goto label;
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.util.ConsumerThread: int getReceived()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Consumed: \u messages");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
label:
interfaceinvoke v.<javax.jms.MessageConsumer: void close()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<javax.jms.JMSException: void printStackTrace()>();
label:
throw v;
label:
v = <org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Consumer thread finished");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
return;
catch javax.jms.JMSException from label to label with label;
catch java.lang.Exception from label to label with label;
catch javax.jms.JMSException 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 javax.jms.JMSException from label to label with label;
}
public int getReceived()
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: int received>;
return v;
}
public boolean isDurable()
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: boolean durable>;
return v;
}
public void setDurable(boolean)
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: boolean;
v.<org.apache.activemq.util.ConsumerThread: boolean durable> = v;
return;
}
public void setMessageCount(int)
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: int;
v.<org.apache.activemq.util.ConsumerThread: int messageCount> = v;
return;
}
public void setBreakOnNull(boolean)
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: boolean;
v.<org.apache.activemq.util.ConsumerThread: boolean breakOnNull> = v;
return;
}
public int getBatchSize()
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: int batchSize>;
return v;
}
public void setBatchSize(int)
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: int;
v.<org.apache.activemq.util.ConsumerThread: int batchSize> = v;
return;
}
public int getMessageCount()
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: int messageCount>;
return v;
}
public boolean isBreakOnNull()
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: boolean breakOnNull>;
return v;
}
public int getReceiveTimeOut()
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: int receiveTimeOut>;
return v;
}
public void setReceiveTimeOut(int)
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: int;
v.<org.apache.activemq.util.ConsumerThread: int receiveTimeOut> = v;
return;
}
public boolean isRunning()
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: boolean running>;
return v;
}
public void setRunning(boolean)
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: boolean;
v.<org.apache.activemq.util.ConsumerThread: boolean running> = v;
return;
}
public int getSleep()
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: int sleep>;
return v;
}
public void setSleep(int)
{
int v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: int;
v.<org.apache.activemq.util.ConsumerThread: int sleep> = v;
return;
}
public java.util.concurrent.CountDownLatch getFinished()
{
java.util.concurrent.CountDownLatch v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished>;
return v;
}
public void setFinished(java.util.concurrent.CountDownLatch)
{
java.util.concurrent.CountDownLatch v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: java.util.concurrent.CountDownLatch;
v.<org.apache.activemq.util.ConsumerThread: java.util.concurrent.CountDownLatch finished> = v;
return;
}
public boolean isBytesAsText()
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v = v.<org.apache.activemq.util.ConsumerThread: boolean bytesAsText>;
return v;
}
public void setBytesAsText(boolean)
{
boolean v;
org.apache.activemq.util.ConsumerThread v;
v := @this: org.apache.activemq.util.ConsumerThread;
v := @parameter: boolean;
v.<org.apache.activemq.util.ConsumerThread: boolean bytesAsText> = v;
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/util/ConsumerThread;");
<org.apache.activemq.util.ConsumerThread: org.slf4j.Logger LOG> = v;
return;
}
}