public class org.apache.logging.log4j.util.Activator extends java.lang.Object implements org.osgi.framework.BundleActivator, org.osgi.framework.SynchronousBundleListener
{
private static final java.lang.SecurityManager SECURITY_MANAGER;
private static final org.apache.logging.log4j.Logger LOGGER;
private boolean lockingProviderUtil;
public void <init>()
{
org.apache.logging.log4j.util.Activator v;
v := @this: org.apache.logging.log4j.util.Activator;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
private static void checkPermission(java.security.Permission)
{
java.security.Permission v;
java.lang.SecurityManager v, v;
v := @parameter: java.security.Permission;
v = <org.apache.logging.log4j.util.Activator: java.lang.SecurityManager SECURITY_MANAGER>;
if v == null goto label;
v = <org.apache.logging.log4j.util.Activator: java.lang.SecurityManager SECURITY_MANAGER>;
virtualinvoke v.<java.lang.SecurityManager: void checkPermission(java.security.Permission)>(v);
label:
return;
}
private void loadProvider(org.osgi.framework.Bundle)
{
org.apache.logging.log4j.util.Activator v;
org.osgi.framework.AdminPermission v;
int v, v;
java.lang.SecurityException v;
java.lang.String v, v, v, v, v;
org.osgi.framework.Bundle v;
java.lang.Exception v;
org.osgi.framework.BundleContext v;
org.apache.logging.log4j.Logger v, v, v;
java.lang.Class v;
java.lang.Object v;
org.osgi.framework.AdaptPermission v;
v := @this: org.apache.logging.log4j.util.Activator;
v := @parameter: org.osgi.framework.Bundle;
v = interfaceinvoke v.<org.osgi.framework.Bundle: int getState()>();
if v != 1 goto label;
return;
label:
v = new org.osgi.framework.AdminPermission;
specialinvoke v.<org.osgi.framework.AdminPermission: void <init>(org.osgi.framework.Bundle,java.lang.String)>(v, "resource");
staticinvoke <org.apache.logging.log4j.util.Activator: void checkPermission(java.security.Permission)>(v);
v = new org.osgi.framework.AdaptPermission;
v = class "Lorg/osgi/framework/wiring/BundleWiring;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
specialinvoke v.<org.osgi.framework.AdaptPermission: void <init>(java.lang.String,org.osgi.framework.Bundle,java.lang.String)>(v, v, "adapt");
staticinvoke <org.apache.logging.log4j.util.Activator: void checkPermission(java.security.Permission)>(v);
v = interfaceinvoke v.<org.osgi.framework.Bundle: org.osgi.framework.BundleContext getBundleContext()>();
if v != null goto label;
v = <org.apache.logging.log4j.util.Activator: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.osgi.framework.Bundle: java.lang.String getSymbolicName()>();
v = interfaceinvoke v.<org.osgi.framework.Bundle: int getState()>();
v = specialinvoke v.<org.apache.logging.log4j.util.Activator: java.lang.String toStateString(int)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Bundle {} has no context (state={}), skipping loading provider", v, v);
goto label;
label:
v = interfaceinvoke v.<org.osgi.framework.Bundle: java.lang.Object adapt(java.lang.Class)>(class "Lorg/osgi/framework/wiring/BundleWiring;");
specialinvoke v.<org.apache.logging.log4j.util.Activator: void loadProvider(org.osgi.framework.BundleContext,org.osgi.framework.wiring.BundleWiring)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.util.Activator: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.osgi.framework.Bundle: java.lang.String getSymbolicName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Cannot access bundle [{}] contents. Ignoring.", v, v);
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.util.Activator: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.osgi.framework.Bundle: java.lang.String getSymbolicName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Problem checking bundle {} for Log4j 2 provider.", v, v);
label:
return;
catch java.lang.SecurityException from label to label with label;
catch java.lang.Exception from label to label with label;
}
private java.lang.String toStateString(int)
{
int v;
java.lang.String v;
org.apache.logging.log4j.util.Activator v;
v := @this: org.apache.logging.log4j.util.Activator;
v := @parameter: int;
lookupswitch(v)
{
case 1: goto label;
case 2: goto label;
case 4: goto label;
case 8: goto label;
case 16: goto label;
case 32: goto label;
default: goto label;
};
label:
return "UNINSTALLED";
label:
return "INSTALLED";
label:
return "RESOLVED";
label:
return "STARTING";
label:
return "STOPPING";
label:
return "ACTIVE";
label:
v = staticinvoke <java.lang.Integer: java.lang.String toString(int)>(v);
return v;
}
private void loadProvider(org.osgi.framework.BundleContext, org.osgi.framework.wiring.BundleWiring)
{
java.lang.Throwable v;
org.apache.logging.log4j.spi.Provider v;
java.lang.Integer v, v;
org.apache.logging.log4j.util.Activator v;
int v, v;
boolean v, v;
org.osgi.framework.wiring.BundleWiring v;
java.util.Iterator v, v;
java.util.Collection v;
org.osgi.framework.BundleContext v;
java.util.List v;
org.apache.logging.log4j.Logger v;
java.lang.Object v, v, v;
java.lang.ClassLoader v;
v := @this: org.apache.logging.log4j.util.Activator;
v := @parameter: org.osgi.framework.BundleContext;
v := @parameter: org.osgi.framework.wiring.BundleWiring;
label:
v = interfaceinvoke v.<org.osgi.framework.BundleContext: java.util.Collection getServiceReferences(java.lang.Class,java.lang.String)>(class "Lorg/apache/logging/log4j/spi/Provider;", "(APIVersion>=2.6.0)");
v = null;
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 = interfaceinvoke v.<org.osgi.framework.BundleContext: java.lang.Object getService(org.osgi.framework.ServiceReference)>(v);
if v == null goto label;
v = virtualinvoke v.<org.apache.logging.log4j.spi.Provider: java.lang.Integer getPriority()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = virtualinvoke v.<org.apache.logging.log4j.spi.Provider: java.lang.Integer getPriority()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v <= v goto label;
label:
v = v;
goto label;
label:
if v == null goto label;
staticinvoke <org.apache.logging.log4j.util.ProviderUtil: void addProvider(org.apache.logging.log4j.spi.Provider)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.util.Activator: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Invalid service filter: (APIVersion>=2.6.0)", v);
label:
v = interfaceinvoke v.<org.osgi.framework.wiring.BundleWiring: java.util.List findEntries(java.lang.String,java.lang.String,int)>("META-INF", "log4j-provider.properties", 0);
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.osgi.framework.wiring.BundleWiring: java.lang.ClassLoader getClassLoader()>();
staticinvoke <org.apache.logging.log4j.util.ProviderUtil: void loadProvider(java.net.URL,java.lang.ClassLoader)>(v, v);
goto label;
label:
return;
catch org.osgi.framework.InvalidSyntaxException from label to label with label;
}
public void start(org.osgi.framework.BundleContext) throws java.lang.Exception
{
org.apache.logging.log4j.util.Activator v;
int v, v;
java.lang.String v;
org.osgi.framework.Bundle v, v;
boolean v;
org.osgi.framework.wiring.BundleWiring v;
java.util.Iterator v;
org.osgi.framework.Bundle[] v;
org.osgi.framework.BundleContext v;
java.util.List v;
java.util.concurrent.locks.Lock v;
java.lang.Class v;
java.lang.Object v, v;
v := @this: org.apache.logging.log4j.util.Activator;
v := @parameter: org.osgi.framework.BundleContext;
v = <org.apache.logging.log4j.util.ProviderUtil: java.util.concurrent.locks.Lock STARTUP_LOCK>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v.<org.apache.logging.log4j.util.Activator: boolean lockingProviderUtil> = 1;
v = interfaceinvoke v.<org.osgi.framework.BundleContext: org.osgi.framework.Bundle getBundle()>();
v = interfaceinvoke v.<org.osgi.framework.Bundle: java.lang.Object adapt(java.lang.Class)>(class "Lorg/osgi/framework/wiring/BundleWiring;");
v = class "Lorg/apache/logging/log4j/spi/LoggerContextFactory;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = interfaceinvoke v.<org.osgi.framework.wiring.BundleWiring: java.util.List getRequiredWires(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.osgi.framework.wiring.BundleWire: org.osgi.framework.wiring.BundleWiring getProviderWiring()>();
specialinvoke v.<org.apache.logging.log4j.util.Activator: void loadProvider(org.osgi.framework.BundleContext,org.osgi.framework.wiring.BundleWiring)>(v, v);
goto label;
label:
interfaceinvoke v.<org.osgi.framework.BundleContext: void addBundleListener(org.osgi.framework.BundleListener)>(v);
v = interfaceinvoke v.<org.osgi.framework.BundleContext: org.osgi.framework.Bundle[] getBundles()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
specialinvoke v.<org.apache.logging.log4j.util.Activator: void loadProvider(org.osgi.framework.Bundle)>(v);
v = v + 1;
goto label;
label:
specialinvoke v.<org.apache.logging.log4j.util.Activator: void unlockIfReady()>();
return;
}
private void unlockIfReady()
{
java.util.concurrent.locks.Lock v;
org.apache.logging.log4j.util.Activator v;
java.util.Collection v;
boolean v, v;
v := @this: org.apache.logging.log4j.util.Activator;
v = v.<org.apache.logging.log4j.util.Activator: boolean lockingProviderUtil>;
if v == 0 goto label;
v = <org.apache.logging.log4j.util.ProviderUtil: java.util.Collection PROVIDERS>;
v = interfaceinvoke v.<java.util.Collection: boolean isEmpty()>();
if v != 0 goto label;
v = <org.apache.logging.log4j.util.ProviderUtil: java.util.concurrent.locks.Lock STARTUP_LOCK>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
v.<org.apache.logging.log4j.util.Activator: boolean lockingProviderUtil> = 0;
label:
return;
}
public void stop(org.osgi.framework.BundleContext) throws java.lang.Exception
{
org.apache.logging.log4j.util.Activator v;
org.osgi.framework.BundleContext v;
v := @this: org.apache.logging.log4j.util.Activator;
v := @parameter: org.osgi.framework.BundleContext;
interfaceinvoke v.<org.osgi.framework.BundleContext: void removeBundleListener(org.osgi.framework.BundleListener)>(v);
specialinvoke v.<org.apache.logging.log4j.util.Activator: void unlockIfReady()>();
return;
}
public void bundleChanged(org.osgi.framework.BundleEvent)
{
org.apache.logging.log4j.util.Activator v;
int v;
org.osgi.framework.Bundle v;
org.osgi.framework.BundleEvent v;
v := @this: org.apache.logging.log4j.util.Activator;
v := @parameter: org.osgi.framework.BundleEvent;
v = virtualinvoke v.<org.osgi.framework.BundleEvent: int getType()>();
lookupswitch(v)
{
case 2: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<org.osgi.framework.BundleEvent: org.osgi.framework.Bundle getBundle()>();
specialinvoke v.<org.apache.logging.log4j.util.Activator: void loadProvider(org.osgi.framework.Bundle)>(v);
specialinvoke v.<org.apache.logging.log4j.util.Activator: void unlockIfReady()>();
label:
return;
}
static void <clinit>()
{
org.apache.logging.log4j.status.StatusLogger v;
java.lang.SecurityManager v;
v = staticinvoke <java.lang.System: java.lang.SecurityManager getSecurityManager()>();
<org.apache.logging.log4j.util.Activator: java.lang.SecurityManager SECURITY_MANAGER> = v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.util.Activator: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}