public class org.apache.activemq.transport.TransportLoggerFactory extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
private static org.apache.activemq.transport.TransportLoggerFactory instance;
private static int lastId;
private static final org.apache.activemq.util.LogWriterFinder logWriterFinder;
public static java.lang.String defaultLogWriterName;
private static boolean defaultDynamicManagement;
private static boolean defaultInitialBehavior;
private boolean transportLoggerControlCreated;
private org.apache.activemq.broker.jmx.ManagementContext managementContext;
private javax.management.ObjectName objectName;
private void <init>()
{
org.apache.activemq.transport.TransportLoggerFactory v;
v := @this: org.apache.activemq.transport.TransportLoggerFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.activemq.transport.TransportLoggerFactory: boolean transportLoggerControlCreated> = 0;
return;
}
public static synchronized org.apache.activemq.transport.TransportLoggerFactory getInstance()
{
org.apache.activemq.transport.TransportLoggerFactory v, v, v;
v = <org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.transport.TransportLoggerFactory instance>;
if v != null goto label;
v = new org.apache.activemq.transport.TransportLoggerFactory;
specialinvoke v.<org.apache.activemq.transport.TransportLoggerFactory: void <init>()>();
<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.transport.TransportLoggerFactory instance> = v;
label:
v = <org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.transport.TransportLoggerFactory instance>;
return v;
}
public void stop()
{
org.apache.activemq.transport.TransportLoggerFactory v;
org.slf4j.Logger v;
javax.management.ObjectName v;
java.lang.Exception v;
org.apache.activemq.broker.jmx.ManagementContext v, v;
java.lang.String v;
boolean v;
v := @this: org.apache.activemq.transport.TransportLoggerFactory;
label:
v = v.<org.apache.activemq.transport.TransportLoggerFactory: boolean transportLoggerControlCreated>;
if v == 0 goto label;
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
v = v.<org.apache.activemq.transport.TransportLoggerFactory: javax.management.ObjectName objectName>;
virtualinvoke v.<org.apache.activemq.broker.jmx.ManagementContext: void unregisterMBean(javax.management.ObjectName)>(v);
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
virtualinvoke v.<org.apache.activemq.broker.jmx.ManagementContext: void stop()>();
v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext> = null;
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transport.TransportLoggerFactory: org.slf4j.Logger LOG>;
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[])>("TransportLoggerFactory could not be stopped, reason: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Exception from label to label with label;
}
public org.apache.activemq.transport.TransportLogger createTransportLogger(org.apache.activemq.transport.Transport) throws java.io.IOException
{
org.apache.activemq.transport.TransportLoggerFactory v;
org.apache.activemq.transport.TransportLogger v;
org.slf4j.Logger v;
org.apache.activemq.transport.Transport v;
int v, v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.activemq.transport.TransportLoggerFactory;
v := @parameter: org.apache.activemq.transport.Transport;
v = staticinvoke <org.apache.activemq.transport.TransportLoggerFactory: int getNextId()>();
v = staticinvoke <org.apache.activemq.transport.TransportLoggerFactory: org.slf4j.Logger createLog(int)>(v);
v = <org.apache.activemq.transport.TransportLoggerFactory: java.lang.String defaultLogWriterName>;
v = <org.apache.activemq.transport.TransportLoggerFactory: boolean defaultDynamicManagement>;
v = <org.apache.activemq.transport.TransportLoggerFactory: boolean defaultInitialBehavior>;
v = <org.apache.activemq.TransportLoggerSupport: int defaultJmxPort>;
v = virtualinvoke v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.transport.TransportLogger createTransportLogger(org.apache.activemq.transport.Transport,int,org.slf4j.Logger,java.lang.String,boolean,boolean,int)>(v, v, v, v, v, v, v);
return v;
}
public org.apache.activemq.transport.TransportLogger createTransportLogger(org.apache.activemq.transport.Transport, org.slf4j.Logger) throws java.io.IOException
{
org.apache.activemq.transport.TransportLoggerFactory v;
org.apache.activemq.transport.TransportLogger v;
org.slf4j.Logger v;
org.apache.activemq.transport.Transport v;
int v, v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.activemq.transport.TransportLoggerFactory;
v := @parameter: org.apache.activemq.transport.Transport;
v := @parameter: org.slf4j.Logger;
v = staticinvoke <org.apache.activemq.transport.TransportLoggerFactory: int getNextId()>();
v = <org.apache.activemq.transport.TransportLoggerFactory: java.lang.String defaultLogWriterName>;
v = <org.apache.activemq.transport.TransportLoggerFactory: boolean defaultDynamicManagement>;
v = <org.apache.activemq.transport.TransportLoggerFactory: boolean defaultInitialBehavior>;
v = <org.apache.activemq.TransportLoggerSupport: int defaultJmxPort>;
v = virtualinvoke v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.transport.TransportLogger createTransportLogger(org.apache.activemq.transport.Transport,int,org.slf4j.Logger,java.lang.String,boolean,boolean,int)>(v, v, v, v, v, v, v);
return v;
}
public org.apache.activemq.transport.TransportLogger createTransportLogger(org.apache.activemq.transport.Transport, java.lang.String, boolean, boolean, int) throws java.io.IOException
{
org.apache.activemq.transport.TransportLoggerFactory v;
org.apache.activemq.transport.TransportLogger v;
org.slf4j.Logger v;
org.apache.activemq.transport.Transport v;
int v, v, v, v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.activemq.transport.TransportLoggerFactory;
v := @parameter: org.apache.activemq.transport.Transport;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: int;
v = (int) -1;
v = v;
if v != 0 goto label;
v = <org.apache.activemq.TransportLoggerSupport: int defaultJmxPort>;
if v == v goto label;
v = staticinvoke <org.apache.activemq.transport.TransportLoggerFactory: int getNextId()>();
label:
v = staticinvoke <org.apache.activemq.transport.TransportLoggerFactory: org.slf4j.Logger createLog(int)>(v);
v = virtualinvoke v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.transport.TransportLogger createTransportLogger(org.apache.activemq.transport.Transport,int,org.slf4j.Logger,java.lang.String,boolean,boolean,int)>(v, v, v, v, v, v, v);
return v;
}
public org.apache.activemq.transport.TransportLogger createTransportLogger(org.apache.activemq.transport.Transport, int, org.slf4j.Logger, java.lang.String, boolean, boolean, int) throws java.io.IOException
{
java.lang.Throwable v, v;
java.lang.Object[] v;
java.lang.Integer v;
org.apache.activemq.transport.LogWriter v;
org.apache.activemq.broker.jmx.ManagementContext v;
int v, v, v, v;
java.lang.String v, v, v, v;
boolean v, v, v;
org.apache.activemq.transport.TransportLoggerFactory v;
org.apache.activemq.transport.TransportLogger v;
org.slf4j.Logger v;
java.io.IOException v;
org.apache.activemq.transport.Transport v;
org.apache.activemq.util.LogWriterFinder v;
org.apache.activemq.transport.TransportLoggerView v;
v := @this: org.apache.activemq.transport.TransportLoggerFactory;
v := @parameter: org.apache.activemq.transport.Transport;
v := @parameter: int;
v := @parameter: org.slf4j.Logger;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: int;
label:
v = <org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.util.LogWriterFinder logWriterFinder>;
v = virtualinvoke v.<org.apache.activemq.util.LogWriterFinder: org.apache.activemq.transport.LogWriter newInstance(java.lang.String)>(v);
v = (int) -1;
if v != v goto label;
v = newarray (java.lang.Object)[1];
v = staticinvoke <org.apache.activemq.transport.TransportLoggerFactory: int getNextId()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("%08X: ", v);
interfaceinvoke v.<org.apache.activemq.transport.LogWriter: void setPrefix(java.lang.String)>(v);
label:
v = new org.apache.activemq.transport.TransportLogger;
specialinvoke v.<org.apache.activemq.transport.TransportLogger: void <init>(org.apache.activemq.transport.Transport,org.slf4j.Logger,boolean,org.apache.activemq.transport.LogWriter)>(v, v, v, v);
if v == 0 goto label;
entermonitor v;
label:
v = v.<org.apache.activemq.transport.TransportLoggerFactory: boolean transportLoggerControlCreated>;
if v != 0 goto label;
specialinvoke v.<org.apache.activemq.transport.TransportLoggerFactory: void createTransportLoggerControl(int)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = new org.apache.activemq.transport.TransportLoggerView;
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
specialinvoke v.<org.apache.activemq.transport.TransportLoggerView: void <init>(org.apache.activemq.transport.TransportLogger,java.lang.String,int,org.apache.activemq.broker.jmx.ManagementContext)>(v, v, v, v);
virtualinvoke v.<org.apache.activemq.transport.TransportLogger: void setView(org.apache.activemq.transport.TransportLoggerView)>(v);
label:
return v;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.Throwable)>(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[])>("Could not create log writer object for: \u, reason: \u0001");
v = staticinvoke <org.apache.activemq.util.IOExceptionSupport: java.io.IOException create(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static synchronized int getNextId()
{
int v, v;
v = <org.apache.activemq.transport.TransportLoggerFactory: int lastId>;
v = v + 1;
<org.apache.activemq.transport.TransportLoggerFactory: int lastId> = v;
return v;
}
private static org.slf4j.Logger createLog(int)
{
org.slf4j.Logger v;
int v;
java.lang.Class v;
java.lang.String v, v, v;
v := @parameter: int;
v = class "Lorg/apache/activemq/transport/TransportLogger;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
if v <= 0 goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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");
goto label;
label:
v = "";
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.Connection\u0001");
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.String)>(v);
return v;
}
private void createTransportLoggerControl(int)
{
org.apache.activemq.broker.jmx.ManagementContext v, v, v, v, v, v;
int v;
java.lang.String v, v, v, v;
org.apache.activemq.transport.TransportLoggerFactory v;
org.slf4j.Logger v, v;
org.apache.activemq.transport.TransportLoggerControl v;
javax.management.ObjectName v, v;
java.lang.Exception v, v;
v := @this: org.apache.activemq.transport.TransportLoggerFactory;
v := @parameter: int;
label:
v = new org.apache.activemq.broker.jmx.ManagementContext;
specialinvoke v.<org.apache.activemq.broker.jmx.ManagementContext: void <init>()>();
v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext> = v;
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
virtualinvoke v.<org.apache.activemq.broker.jmx.ManagementContext: void setConnectorPort(int)>(v);
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
virtualinvoke v.<org.apache.activemq.broker.jmx.ManagementContext: void start()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transport.TransportLoggerFactory: org.slf4j.Logger LOG>;
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[])>("Management context could not be started, reason: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = new javax.management.ObjectName;
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
v = virtualinvoke v.<org.apache.activemq.broker.jmx.ManagementContext: java.lang.String getJmxDomainName()>();
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[])>("\u0001:Type=TransportLoggerControl");
specialinvoke v.<javax.management.ObjectName: void <init>(java.lang.String)>(v);
v.<org.apache.activemq.transport.TransportLoggerFactory: javax.management.ObjectName objectName> = v;
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
v = new org.apache.activemq.transport.TransportLoggerControl;
v = v.<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.broker.jmx.ManagementContext managementContext>;
specialinvoke v.<org.apache.activemq.transport.TransportLoggerControl: void <init>(org.apache.activemq.broker.jmx.ManagementContext)>(v);
v = v.<org.apache.activemq.transport.TransportLoggerFactory: javax.management.ObjectName objectName>;
staticinvoke <org.apache.activemq.broker.jmx.AnnotatedMBean: void registerMBean(org.apache.activemq.broker.jmx.ManagementContext,java.lang.Object,javax.management.ObjectName)>(v, v, v);
v.<org.apache.activemq.transport.TransportLoggerFactory: boolean transportLoggerControlCreated> = 1;
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.transport.TransportLoggerFactory: org.slf4j.Logger LOG>;
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[])>("TransportLoggerControlMBean could not be registered, reason: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
org.apache.activemq.util.LogWriterFinder v;
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/transport/TransportLoggerFactory;");
<org.apache.activemq.transport.TransportLoggerFactory: org.slf4j.Logger LOG> = v;
<org.apache.activemq.transport.TransportLoggerFactory: int lastId> = 0;
v = new org.apache.activemq.util.LogWriterFinder;
specialinvoke v.<org.apache.activemq.util.LogWriterFinder: void <init>(java.lang.String)>("META-INF/services/org/apache/activemq/transport/logwriters/");
<org.apache.activemq.transport.TransportLoggerFactory: org.apache.activemq.util.LogWriterFinder logWriterFinder> = v;
<org.apache.activemq.transport.TransportLoggerFactory: java.lang.String defaultLogWriterName> = "default";
<org.apache.activemq.transport.TransportLoggerFactory: boolean defaultDynamicManagement> = 0;
<org.apache.activemq.transport.TransportLoggerFactory: boolean defaultInitialBehavior> = 1;
return;
}
}