public abstract class org.apache.activemq.util.JmsLogAppenderSupport extends org.apache.log4j.AppenderSkeleton
{
public static final int JMS_PUBLISH_ERROR_CODE;
private javax.jms.Connection connection;
private javax.jms.Session session;
private javax.jms.MessageProducer producer;
private boolean allowTextMessages;
private java.lang.String subjectPrefix;
private static final java.lang.ThreadLocal APPENDING;
public void <init>()
{
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
specialinvoke v.<org.apache.log4j.AppenderSkeleton: void <init>()>();
v.<org.apache.activemq.util.JmsLogAppenderSupport: boolean allowTextMessages> = 1;
v.<org.apache.activemq.util.JmsLogAppenderSupport: java.lang.String subjectPrefix> = "log4j.";
return;
}
public javax.jms.Connection getConnection() throws javax.jms.JMSException, javax.naming.NamingException
{
javax.jms.Connection v, v, v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection connection>;
if v != null goto label;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection createConnection()>();
v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection connection> = v;
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection connection>;
return v;
}
public void setConnection(javax.jms.Connection)
{
javax.jms.Connection v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v := @parameter: javax.jms.Connection;
v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection connection> = v;
return;
}
public javax.jms.Session getSession() throws javax.jms.JMSException, javax.naming.NamingException
{
javax.jms.Session v, v, v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session session>;
if v != null goto label;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session createSession()>();
v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session session> = v;
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session session>;
return v;
}
public void setSession(javax.jms.Session)
{
javax.jms.Session v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v := @parameter: javax.jms.Session;
v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session session> = v;
return;
}
public javax.jms.MessageProducer getProducer() throws javax.jms.JMSException, javax.naming.NamingException
{
javax.jms.MessageProducer v, v, v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer producer>;
if v != null goto label;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer createProducer()>();
v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer producer> = v;
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer producer>;
return v;
}
public void setProducer(javax.jms.MessageProducer)
{
javax.jms.MessageProducer v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v := @parameter: javax.jms.MessageProducer;
v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer producer> = v;
return;
}
public void close()
{
java.lang.Throwable v, v, v;
org.apache.activemq.util.JmsLogAppenderSupport v;
java.util.ArrayList v;
javax.jms.Session v, v;
int v;
java.lang.String v;
javax.jms.MessageProducer v, v;
boolean v;
javax.jms.Connection v, v;
java.util.Iterator v;
org.apache.log4j.spi.ErrorHandler v;
javax.jms.JMSException v;
java.lang.Object v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer producer>;
if v == null goto label;
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer producer>;
interfaceinvoke v.<javax.jms.MessageProducer: void close()>();
label:
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session session>;
if v == null goto label;
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session session>;
interfaceinvoke v.<javax.jms.Session: void close()>();
label:
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection connection>;
if v == null goto label;
label:
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection connection>;
interfaceinvoke v.<javax.jms.Connection: void close()>();
label:
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: org.apache.log4j.spi.ErrorHandler getErrorHandler()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (javax.jms.JMSException)>(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[])>("Error closing JMS resources: \u0001");
v = (int) 61616;
interfaceinvoke v.<org.apache.log4j.spi.ErrorHandler: void error(java.lang.String,java.lang.Exception,int)>(v, v, v);
goto label;
label:
return;
catch javax.jms.JMSException from label to label with label;
catch javax.jms.JMSException from label to label with label;
catch javax.jms.JMSException from label to label with label;
}
public boolean requiresLayout()
{
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
return 0;
}
public void activateOptions()
{
int v;
org.apache.log4j.spi.ErrorHandler v;
java.lang.String v;
java.lang.Exception v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
label:
virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer getProducer()>();
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: org.apache.log4j.spi.ErrorHandler getErrorHandler()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Exception)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Could not create JMS resources: \u0001");
v = (int) 61616;
interfaceinvoke v.<org.apache.log4j.spi.ErrorHandler: void error(java.lang.String,java.lang.Exception,int)>(v, v, v);
label:
return;
catch java.lang.Exception from label to label with label;
}
protected abstract javax.jms.Connection createConnection() throws javax.jms.JMSException, javax.naming.NamingException;
protected javax.jms.Session createSession() throws javax.jms.JMSException, javax.naming.NamingException
{
javax.jms.Connection v;
javax.jms.Session v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Connection getConnection()>();
v = interfaceinvoke v.<javax.jms.Connection: javax.jms.Session createSession(boolean,int)>(0, 1);
return v;
}
protected javax.jms.MessageProducer createProducer() throws javax.jms.JMSException, javax.naming.NamingException
{
javax.jms.Session v;
javax.jms.MessageProducer v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session getSession()>();
v = interfaceinvoke v.<javax.jms.Session: javax.jms.MessageProducer createProducer(javax.jms.Destination)>(null);
return v;
}
protected void append(org.apache.log4j.spi.LoggingEvent)
{
java.lang.Throwable v;
org.apache.activemq.util.JmsLogAppenderSupport v;
int v;
java.lang.Boolean v;
java.lang.String v;
javax.jms.MessageProducer v;
javax.jms.Message v;
java.lang.ThreadLocal v, v, v, v, v;
org.apache.log4j.spi.ErrorHandler v;
org.apache.log4j.spi.LoggingEvent v;
java.lang.Exception v;
javax.jms.Destination v;
java.lang.Object v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v := @parameter: org.apache.log4j.spi.LoggingEvent;
v = <org.apache.activemq.util.JmsLogAppenderSupport: java.lang.ThreadLocal APPENDING>;
v = virtualinvoke v.<java.lang.ThreadLocal: java.lang.Object get()>();
if v != null goto label;
v = <org.apache.activemq.util.JmsLogAppenderSupport: java.lang.ThreadLocal APPENDING>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(1);
virtualinvoke v.<java.lang.ThreadLocal: void set(java.lang.Object)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Message createMessage(org.apache.log4j.spi.LoggingEvent)>(v);
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Destination getDestination(org.apache.log4j.spi.LoggingEvent)>(v);
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.MessageProducer getProducer()>();
interfaceinvoke v.<javax.jms.MessageProducer: void send(javax.jms.Destination,javax.jms.Message)>(v, v);
label:
v = <org.apache.activemq.util.JmsLogAppenderSupport: java.lang.ThreadLocal APPENDING>;
virtualinvoke v.<java.lang.ThreadLocal: void remove()>();
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: org.apache.log4j.spi.ErrorHandler getErrorHandler()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Exception)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Could not send message due to: \u0001");
v = (int) 61616;
interfaceinvoke v.<org.apache.log4j.spi.ErrorHandler: void error(java.lang.String,java.lang.Exception,int,org.apache.log4j.spi.LoggingEvent)>(v, v, v, v);
label:
v = <org.apache.activemq.util.JmsLogAppenderSupport: java.lang.ThreadLocal APPENDING>;
virtualinvoke v.<java.lang.ThreadLocal: void remove()>();
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.util.JmsLogAppenderSupport: java.lang.ThreadLocal APPENDING>;
virtualinvoke v.<java.lang.ThreadLocal: void remove()>();
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
protected javax.jms.Message createMessage(org.apache.log4j.spi.LoggingEvent) throws javax.jms.JMSException, javax.naming.NamingException
{
org.apache.log4j.spi.LoggingEvent v;
org.apache.activemq.util.JmsLogAppenderSupport v;
javax.jms.Session v, v;
org.apache.log4j.Level v, v;
int v;
java.lang.Object v, v;
java.lang.String v, v;
boolean v, v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v := @parameter: org.apache.log4j.spi.LoggingEvent;
v = virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: java.lang.Object getMessage()>();
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: boolean allowTextMessages>;
if v == 0 goto label;
v = v instanceof java.lang.String;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session getSession()>();
v = interfaceinvoke v.<javax.jms.Session: javax.jms.TextMessage createTextMessage(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session getSession()>();
v = interfaceinvoke v.<javax.jms.Session: javax.jms.ObjectMessage createObjectMessage(java.io.Serializable)>(v);
label:
v = virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: org.apache.log4j.Level getLevel()>();
v = virtualinvoke v.<org.apache.log4j.Level: java.lang.String toString()>();
interfaceinvoke v.<javax.jms.Message: void setStringProperty(java.lang.String,java.lang.String)>("level", v);
v = virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: org.apache.log4j.Level getLevel()>();
v = virtualinvoke v.<org.apache.log4j.Level: int toInt()>();
interfaceinvoke v.<javax.jms.Message: void setIntProperty(java.lang.String,int)>("levelInt", v);
v = virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: java.lang.String getThreadName()>();
interfaceinvoke v.<javax.jms.Message: void setStringProperty(java.lang.String,java.lang.String)>("threadName", v);
return v;
}
protected javax.jms.Destination getDestination(org.apache.log4j.spi.LoggingEvent) throws javax.jms.JMSException, javax.naming.NamingException
{
javax.jms.Session v;
org.apache.log4j.spi.LoggingEvent v;
javax.jms.Topic v;
java.lang.String v, v, v;
org.apache.activemq.util.JmsLogAppenderSupport v;
v := @this: org.apache.activemq.util.JmsLogAppenderSupport;
v := @parameter: org.apache.log4j.spi.LoggingEvent;
v = v.<org.apache.activemq.util.JmsLogAppenderSupport: java.lang.String subjectPrefix>;
v = virtualinvoke v.<org.apache.log4j.spi.LoggingEvent: java.lang.String getLoggerName()>();
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[])>("\u0001\u0001");
v = virtualinvoke v.<org.apache.activemq.util.JmsLogAppenderSupport: javax.jms.Session getSession()>();
v = interfaceinvoke v.<javax.jms.Session: javax.jms.Topic createTopic(java.lang.String)>(v);
return v;
}
static void <clinit>()
{
java.lang.ThreadLocal v;
v = new java.lang.ThreadLocal;
specialinvoke v.<java.lang.ThreadLocal: void <init>()>();
<org.apache.activemq.util.JmsLogAppenderSupport: java.lang.ThreadLocal APPENDING> = v;
return;
}
}