public class org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer extends java.lang.Object implements java.lang.instrument.ClassFileTransformer
{
private final java.lang.ref.WeakReference providerClassRef;
private java.lang.String providerClassName;
private java.util.Map probes;
private org.objectweb.asm.ClassWriter cw;
private volatile boolean enabled;
private boolean allProbesTransformed;
private boolean transformerAdded;
private int count;
private static java.util.Map instances;
private static final java.lang.instrument.Instrumentation instrumentation;
private static boolean _debug;
private static boolean emittedAttachUnavailableMessageAlready;
private static final java.lang.String AGENT_CLASSNAME;
private static final java.util.logging.Logger logger;
private void <init>(java.lang.Class)
{
java.lang.Class v;
java.util.HashMap v;
java.lang.String v;
java.lang.ref.WeakReference v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
v := @this: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
v := @parameter: java.lang.Class;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.String providerClassName> = null;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map probes> = v;
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean enabled> = 0;
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean allProbesTransformed> = 1;
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean transformerAdded> = 0;
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count> = 0;
v = new java.lang.ref.WeakReference;
specialinvoke v.<java.lang.ref.WeakReference: void <init>(java.lang.Object)>(v);
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.ref.WeakReference providerClassRef> = v;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.String providerClassName> = v;
return;
}
static org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer getInstance(java.lang.Class)
{
java.lang.Throwable v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
java.util.Map v, v, v, v;
java.lang.Class v;
java.lang.Object v;
boolean v;
v := @parameter: java.lang.Class;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
entermonitor v;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
v = new org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
specialinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void <init>(java.lang.Class)>(v);
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
exitmonitor v;
label:
return v;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
static void transformAll()
{
java.lang.Throwable v;
java.util.Iterator v;
java.util.Set v;
java.util.Map v, v;
java.lang.Object v, v;
boolean v;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
entermonitor v;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: 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.<java.util.Map$Entry: java.lang.Object getValue()>();
virtualinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void transform()>();
goto label;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
static void untransformAll()
{
java.lang.Throwable v;
java.util.Iterator v;
java.util.Set v;
java.util.Map v, v;
java.lang.Object v, v;
boolean v;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
entermonitor v;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: 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.<java.util.Map$Entry: java.lang.Object getValue()>();
virtualinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void untransform()>();
goto label;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
static void untransform(java.lang.Class)
{
java.lang.Class v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
v := @parameter: java.lang.Class;
v = staticinvoke <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer getInstance(java.lang.Class)>(v);
virtualinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void untransform()>();
return;
}
static void transform(java.lang.Class)
{
java.lang.Class v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
v := @parameter: java.lang.Class;
v = staticinvoke <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer getInstance(java.lang.Class)>(v);
virtualinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void transform()>();
return;
}
synchronized void addProbe(org.glassfish.flashlight.provider.FlashlightProbe) throws java.lang.NoSuchMethodException
{
java.util.Map v;
java.lang.String v, v, v;
java.lang.reflect.Method v;
org.glassfish.flashlight.provider.FlashlightProbe v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
v := @this: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
v := @parameter: org.glassfish.flashlight.provider.FlashlightProbe;
v = specialinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.reflect.Method getMethod(org.glassfish.flashlight.provider.FlashlightProbe)>(v);
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map probes>;
v = virtualinvoke v.<org.glassfish.flashlight.provider.FlashlightProbe: java.lang.String getProviderJavaMethodName()>();
v = staticinvoke <org.objectweb.asm.Type: java.lang.String getMethodDescriptor(java.lang.reflect.Method)>(v);
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");
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean allProbesTransformed> = 0;
return;
}
final synchronized void transform()
{
java.lang.Object[] v, v, v;
java.util.logging.Level v, v, v, v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
java.lang.String v;
java.lang.ref.WeakReference v;
boolean v, v, v, v, v;
java.lang.Class[] v;
java.util.logging.Logger v, v, v, v;
java.lang.Exception v;
java.lang.instrument.Instrumentation v, v;
java.lang.Object v;
v := @this: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.ref.WeakReference providerClassRef>;
v = virtualinvoke v.<java.lang.ref.WeakReference: java.lang.Object get()>();
if v != null goto label;
v = staticinvoke <org.glassfish.flashlight.impl.client.Log: java.util.logging.Logger getLogger()>();
v = <java.util.logging.Level: java.util.logging.Level FINER>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[1];
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.String providerClassName>;
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void finer(java.lang.String,java.lang.Object[])>("provider class was reclaimed, not.transformed", v);
label:
return;
label:
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean enabled>;
if v == 0 goto label;
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean allProbesTransformed>;
if v == 0 goto label;
v = staticinvoke <org.glassfish.flashlight.impl.client.Log: java.util.logging.Logger getLogger()>();
v = <java.util.logging.Level: java.util.logging.Level FINER>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[1];
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void finer(java.lang.String,java.lang.Object[])>("all probes already.transformed", v);
label:
return;
label:
v = staticinvoke <org.glassfish.flashlight.impl.client.Log: java.util.logging.Logger getLogger()>();
v = <java.util.logging.Level: java.util.logging.Level FINER>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[1];
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void finer(java.lang.String,java.lang.Object[])>("some probes need to be.transformed", v);
label:
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean allProbesTransformed> = 1;
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean enabled> = 1;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation>;
if v != null goto label;
return;
label:
specialinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void addTransformer()>();
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation>;
v = newarray (java.lang.Class)[1];
v[0] = v;
interfaceinvoke v.<java.lang.instrument.Instrumentation: void retransformClasses(java.lang.Class[])>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "NCLS-MON-00507", v);
label:
return;
catch java.lang.Exception from label to label with label;
}
final synchronized void untransform()
{
java.lang.Object[] v, v;
java.util.logging.Level v, v, v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
java.lang.String v;
java.lang.ref.WeakReference v;
boolean v, v, v;
java.lang.Class[] v;
java.util.logging.Logger v, v, v;
java.lang.instrument.Instrumentation v, v;
java.lang.Object v;
java.lang.instrument.UnmodifiableClassException v;
v := @this: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.ref.WeakReference providerClassRef>;
v = virtualinvoke v.<java.lang.ref.WeakReference: java.lang.Object get()>();
if v != null goto label;
v = staticinvoke <org.glassfish.flashlight.impl.client.Log: java.util.logging.Logger getLogger()>();
v = <java.util.logging.Level: java.util.logging.Level FINER>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[1];
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.String providerClassName>;
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void finer(java.lang.String,java.lang.Object[])>("provider class was reclaimed, not.untransformed", v);
label:
return;
label:
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean allProbesTransformed> = 0;
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean enabled>;
if v != 0 goto label;
v = staticinvoke <org.glassfish.flashlight.impl.client.Log: java.util.logging.Logger getLogger()>();
v = <java.util.logging.Level: java.util.logging.Level FINER>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[1];
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void finer(java.lang.String,java.lang.Object[])>("already.not.transformed", v);
label:
return;
label:
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean enabled> = 0;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation>;
if v != null goto label;
return;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation>;
v = newarray (java.lang.Class)[1];
v[0] = v;
interfaceinvoke v.<java.lang.instrument.Instrumentation: void retransformClasses(java.lang.Class[])>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "NCLS-MON-00507", v);
label:
return;
catch java.lang.instrument.UnmodifiableClassException from label to label with label;
}
public byte[] transform(java.lang.ClassLoader, java.lang.String, java.lang.Class, java.security.ProtectionDomain, byte[]) throws java.lang.instrument.IllegalClassFormatException
{
byte[] v, v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
boolean v, v, v, v, v;
java.util.logging.Logger v, v;
java.lang.Exception v;
org.objectweb.asm.ClassReader v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer$ProbeProviderClassVisitor v;
java.lang.ClassLoader v;
org.objectweb.asm.ClassWriter v, v, v;
java.lang.Object[] v, v, v;
java.util.logging.Level v, v;
int v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
java.lang.ref.WeakReference v;
java.security.ProtectionDomain v;
java.lang.Class v;
java.lang.Object v;
v := @this: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
v := @parameter: java.lang.ClassLoader;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
v := @parameter: java.security.ProtectionDomain;
v := @parameter: byte[];
v = null;
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.ref.WeakReference providerClassRef>;
v = virtualinvoke v.<java.lang.ref.WeakReference: java.lang.Object get()>();
if v != null goto label;
v = staticinvoke <org.glassfish.flashlight.impl.client.Log: java.util.logging.Logger getLogger()>();
v = <java.util.logging.Level: java.util.logging.Level FINER>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = newarray (java.lang.Object)[1];
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.String providerClassName>;
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void finer(java.lang.String,java.lang.Object[])>("provider class was reclaimed, not.transformed", v);
label:
return null;
label:
v = staticinvoke <org.glassfish.flashlight.impl.client.AgentAttacher: boolean canAttach()>();
if v != 0 goto label;
label:
return null;
label:
if v == v goto label;
label:
return null;
label:
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean enabled>;
if v == 0 goto label;
v = new org.objectweb.asm.ClassWriter;
specialinvoke v.<org.objectweb.asm.ClassWriter: void <init>(int)>(3);
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: org.objectweb.asm.ClassWriter cw> = v;
v = new org.objectweb.asm.ClassReader;
specialinvoke v.<org.objectweb.asm.ClassReader: void <init>(byte[])>(v);
v = new org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer$ProbeProviderClassVisitor;
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: org.objectweb.asm.ClassWriter cw>;
specialinvoke v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer$ProbeProviderClassVisitor: void <init>(org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer,org.objectweb.asm.ClassVisitor)>(v, v);
virtualinvoke v.<org.objectweb.asm.ClassReader: void accept(org.objectweb.asm.ClassVisitor,org.objectweb.asm.Attribute[],int)>(v, null, 0);
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: org.objectweb.asm.ClassWriter cw>;
v = virtualinvoke v.<org.objectweb.asm.ClassWriter: byte[] toByteArray()>();
v = newarray (java.lang.Object)[1];
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.String providerClassName>;
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void fine(java.lang.String,java.lang.Object[])>("transformed", v);
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean _debug>;
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int)>(47);
v = v + 1;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count>;
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[])>("\u0001supplied_\u0001");
staticinvoke <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void writeFile(java.lang.String,byte[])>(v, v);
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int)>(47);
v = v + 1;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count>;
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[])>("\u0001transformed_\u0001");
staticinvoke <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void writeFile(java.lang.String,byte[])>(v, v);
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count>;
v = v + 1;
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count> = v;
goto label;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean _debug>;
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int)>(47);
v = v + 1;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count>;
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[])>("\u0001supplied_\u0001");
staticinvoke <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: void writeFile(java.lang.String,byte[])>(v, v);
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count>;
v = v + 1;
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: int count> = v;
label:
v = null;
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void fine(java.lang.String,java.lang.Object[])>("untransformed", v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "NCLS-MON-00508", v);
label:
return v;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
private synchronized void addTransformer()
{
java.lang.instrument.Instrumentation v;
boolean v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
v := @this: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
v = v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean transformerAdded>;
if v != 0 goto label;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation>;
interfaceinvoke v.<java.lang.instrument.Instrumentation: void addTransformer(java.lang.instrument.ClassFileTransformer,boolean)>(v, 1);
v.<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean transformerAdded> = 1;
label:
return;
}
private static java.lang.String makeKey(java.lang.String, java.lang.String)
{
java.lang.String v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
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");
return v;
}
private static final void writeFile(java.lang.String, byte[])
{
java.lang.Throwable v, v;
byte[] v;
java.util.logging.Level v;
java.lang.String v, v, v, v;
boolean v, v;
java.io.FileOutputStream v, v;
java.lang.RuntimeException v;
java.util.logging.Logger v;
java.io.File v, v, v;
java.lang.Exception v, v, v;
v := @parameter: java.lang.String;
v := @parameter: byte[];
v = null;
label:
v = new java.io.File;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("com.sun.aas.installRoot");
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, "flashlight-generated");
v = virtualinvoke v.<java.io.File: boolean isDirectory()>();
if v != 0 goto label;
v = virtualinvoke v.<java.io.File: boolean mkdirs()>();
if v != 0 goto label;
v = new java.lang.RuntimeException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Can\'t create directory: \u0001");
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new java.io.FileOutputStream;
v = new java.io.File;
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.class");
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
v = v;
virtualinvoke v.<java.io.FileOutputStream: void write(byte[])>(v);
label:
virtualinvoke v.<java.io.FileOutputStream: void close()>();
label:
goto label;
label:
v := @caughtexception;
goto label;
label:
v := @caughtexception;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "NCLS-MON-00509", v);
label:
if v == null goto label;
virtualinvoke v.<java.io.FileOutputStream: void close()>();
label:
goto label;
label:
v := @caughtexception;
goto label;
label:
v := @caughtexception;
label:
if v == null goto label;
virtualinvoke v.<java.io.FileOutputStream: void close()>();
label:
goto label;
label:
v := @caughtexception;
label:
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.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Exception from label to label with label;
}
private java.lang.reflect.Method getMethod(org.glassfish.flashlight.provider.FlashlightProbe) throws java.lang.NoSuchMethodException
{
java.lang.Class[] v;
java.lang.Class v;
java.lang.String v;
java.lang.reflect.Method v;
org.glassfish.flashlight.provider.FlashlightProbe v;
org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer v;
v := @this: org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer;
v := @parameter: org.glassfish.flashlight.provider.FlashlightProbe;
v = virtualinvoke v.<org.glassfish.flashlight.provider.FlashlightProbe: java.lang.reflect.Method getProbeMethod()>();
if v != null goto label;
v = virtualinvoke v.<org.glassfish.flashlight.provider.FlashlightProbe: java.lang.Class getProviderClazz()>();
v = virtualinvoke v.<org.glassfish.flashlight.provider.FlashlightProbe: java.lang.String getProviderJavaMethodName()>();
v = virtualinvoke v.<org.glassfish.flashlight.provider.FlashlightProbe: java.lang.Class[] getParamTypes()>();
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getDeclaredMethod(java.lang.String,java.lang.Class[])>(v, v);
virtualinvoke v.<org.glassfish.flashlight.provider.FlashlightProbe: void setProbeMethod(java.lang.reflect.Method)>(v);
label:
return v;
}
static void <clinit>()
{
java.lang.Throwable v, v, v;
java.lang.Object[] v;
java.util.logging.Level v, v;
java.lang.String v;
java.lang.reflect.Method v;
java.util.WeakHashMap v;
boolean v, v, v;
java.util.logging.Logger v, v, v;
java.lang.instrument.Instrumentation v, v;
java.lang.Class v, v;
java.lang.Object v;
java.lang.ClassLoader v;
v = new java.util.WeakHashMap;
specialinvoke v.<java.util.WeakHashMap: void <init>()>();
<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.Map instances> = v;
v = staticinvoke <com.sun.enterprise.util.Utility: java.lang.String getEnvOrProp(java.lang.String)>("AS_DEBUG");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean _debug> = v;
<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: boolean emittedAttachUnavailableMessageAlready> = 0;
v = staticinvoke <org.glassfish.flashlight.FlashlightLoggerInfo: java.util.logging.Logger getLogger()>();
<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.logging.Logger logger> = v;
v = null;
v = 0;
v = staticinvoke <org.glassfish.flashlight.impl.client.AgentAttacher: boolean canAttach()>();
if v == 0 goto label;
v = 1;
label:
v = class "Lorg/glassfish/flashlight/impl/client/ProbeProviderClassFileTransformer;";
virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = staticinvoke <java.lang.ClassLoader: java.lang.ClassLoader getSystemClassLoader()>();
label:
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.Class loadClass(java.lang.String)>("org.glassfish.flashlight.agent.ProbeAgentMain");
label:
goto label;
label:
v := @caughtexception;
staticinvoke <org.glassfish.flashlight.impl.client.AgentAttacher: boolean attachAgent()>();
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.Class loadClass(java.lang.String)>("org.glassfish.flashlight.agent.ProbeAgentMain");
label:
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("getInstrumentation", null);
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(null, null);
label:
goto label;
label:
v := @caughtexception;
v = null;
v = v;
label:
<org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation> = v;
if v != 0 goto label;
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, "NCLS-MON-00510");
goto label;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation>;
if v == null goto label;
v = newarray (java.lang.Object)[1];
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.lang.instrument.Instrumentation instrumentation>;
v[0] = v;
staticinvoke <org.glassfish.flashlight.impl.client.Log: void info(java.lang.String,java.lang.Object[])>("yes.attach.api", v);
goto label;
label:
v = <org.glassfish.flashlight.impl.client.ProbeProviderClassFileTransformer: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Throwable)>(v, "NCLS-MON-00511", v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
}