public class org.glassfish.pfl.tf.tools.enhancer.Transformer implements org.glassfish.pfl.basic.func.UnaryFunction<byte[], byte[]>
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.glassfish.pfl.tf.tools.enhancer.Transformer
super_class: java.lang.Object
{
private final org.glassfish.pfl.tf.spi.Util util;
descriptor: Lorg/glassfish/pfl/tf/spi/Util;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode mode;
descriptor: Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor tip;
descriptor: Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.Set<java.lang.String> annotationNames;
descriptor: Ljava/util/Set;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Set<Ljava/lang/String;>;
private org.glassfish.pfl.tf.spi.EnhancedClassData ecd;
descriptor: Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
flags: (0x0002) ACC_PRIVATE
void <init>(org.glassfish.pfl.tf.spi.Util, org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode, org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor, java.util.Set<java.lang.String>);
descriptor: (Lorg/glassfish/pfl/tf/spi/Util;Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;Ljava/util/Set;)V
flags: (0x0000)
Code:
stack=2, locals=5, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aconst_null
putfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
2: aload 0
aload 1
putfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
3: aload 0
aload 2
putfield org.glassfish.pfl.tf.tools.enhancer.Transformer.mode:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
4: aload 0
aload 3
putfield org.glassfish.pfl.tf.tools.enhancer.Transformer.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
5: aload 0
aload 4
putfield org.glassfish.pfl.tf.tools.enhancer.Transformer.annotationNames:Ljava/util/Set;
6: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;
0 7 1 util Lorg/glassfish/pfl/tf/spi/Util;
0 7 2 mode Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
0 7 3 tip Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
0 7 4 anames Ljava/util/Set<Ljava/lang/String;>;
Signature: (Lorg/glassfish/pfl/tf/spi/Util;Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;Ljava/util/Set<Ljava/lang/String;>;)V
MethodParameters:
Name Flags
util
mode
tip
anames
private boolean hasAccess(int, int);
descriptor: (II)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: iload 1
iload 2
iand
iload 2
if_icmpne 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;
0 2 1 access I
0 2 2 flag I
MethodParameters:
Name Flags
access
flag
private java.lang.String getSuffix(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: aload 1
astore 2
start local 2 1: aload 1
bipush 47
invokevirtual java.lang.String.lastIndexOf:(I)I
istore 3
start local 3 2: iload 3
iflt 4
3: aload 2
iload 3
iconst_1
iadd
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
astore 2
4: StackMap locals: java.lang.String int
StackMap stack:
aload 2
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;
0 5 1 str Ljava/lang/String;
1 5 2 result Ljava/lang/String;
2 5 3 index I
MethodParameters:
Name Flags
str
private void processTimers();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=14, args_size=1
start local 0 0: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
invokeinterface org.glassfish.pfl.tf.spi.EnhancedClassData.getDescriptions:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
1: astore 1
start local 1 2: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
invokeinterface org.glassfish.pfl.tf.spi.EnhancedClassData.getTimingPointNames:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
3: astore 2
start local 2 4: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
invokeinterface org.glassfish.pfl.tf.spi.EnhancedClassData.getTimingPointTypes:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
5: astore 3
start local 3 6: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
invokeinterface org.glassfish.pfl.tf.spi.EnhancedClassData.getMethodMMAnnotationName:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
7: astore 4
start local 4 8: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
invokeinterface org.glassfish.pfl.tf.spi.EnhancedClassData.getAnnotationToHolderName:()Ljava/util/Map;
invokeinterface java.util.Map.keySet:()Ljava/util/Set;
9: astore 5
start local 5 10: goto 28
11: StackMap locals: org.glassfish.pfl.tf.tools.enhancer.Transformer java.util.Iterator java.util.Iterator java.util.Iterator java.util.Iterator java.util.Set
StackMap stack:
aload 1
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 6
start local 6 12: aload 2
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 7
start local 7 13: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.glassfish.pfl.tf.spi.TimingPointType
astore 8
start local 8 14: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 9
start local 9 15: aload 8
getstatic org.glassfish.pfl.tf.spi.TimingPointType.NONE:Lorg/glassfish/pfl/tf/spi/TimingPointType;
if_acmpeq 28
16: aload 0
aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
invokeinterface org.glassfish.pfl.tf.spi.EnhancedClassData.getClassName:()Ljava/lang/String;
invokevirtual org.glassfish.pfl.tf.tools.enhancer.Transformer.getSuffix:(Ljava/lang/String;)Ljava/lang/String;
astore 10
start local 10 17: aload 10
18: aload 7
19: invokestatic org.glassfish.pfl.tf.timer.spi.TimerFactoryBuilder.getTimerName:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
astore 11
start local 11 20: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
aload 11
aload 6
invokevirtual org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor.addTimer:(Ljava/lang/String;Ljava/lang/String;)V
21: aload 9
ifnonnull 27
22: aload 5
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 13
goto 25
StackMap locals: org.glassfish.pfl.tf.tools.enhancer.Transformer java.util.Iterator java.util.Iterator java.util.Iterator java.util.Iterator java.util.Set java.lang.String java.lang.String org.glassfish.pfl.tf.spi.TimingPointType java.lang.String java.lang.String java.lang.String top java.util.Iterator
StackMap stack:
23: aload 13
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 12
start local 12 24: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
aload 11
aload 0
aload 12
invokevirtual org.glassfish.pfl.tf.tools.enhancer.Transformer.getSuffix:(Ljava/lang/String;)Ljava/lang/String;
invokevirtual org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor.containedIn:(Ljava/lang/String;Ljava/lang/String;)V
end local 12 25: StackMap locals:
StackMap stack:
aload 13
invokeinterface java.util.Iterator.hasNext:()Z
ifne 23
26: goto 28
27: StackMap locals: org.glassfish.pfl.tf.tools.enhancer.Transformer java.util.Iterator java.util.Iterator java.util.Iterator java.util.Iterator java.util.Set java.lang.String java.lang.String org.glassfish.pfl.tf.spi.TimingPointType java.lang.String java.lang.String java.lang.String
StackMap stack:
aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
aload 11
aload 0
aload 9
invokevirtual org.glassfish.pfl.tf.tools.enhancer.Transformer.getSuffix:(Ljava/lang/String;)Ljava/lang/String;
invokevirtual org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor.containedIn:(Ljava/lang/String;Ljava/lang/String;)V
end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 28: StackMap locals: org.glassfish.pfl.tf.tools.enhancer.Transformer java.util.Iterator java.util.Iterator java.util.Iterator java.util.Iterator java.util.Set
StackMap stack:
aload 1
invokeinterface java.util.Iterator.hasNext:()Z
ifne 11
29: return
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 30 0 this Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;
2 30 1 descriptions Ljava/util/Iterator<Ljava/lang/String;>;
4 30 2 names Ljava/util/Iterator<Ljava/lang/String;>;
6 30 3 tpts Ljava/util/Iterator<Lorg/glassfish/pfl/tf/spi/TimingPointType;>;
8 30 4 groups Ljava/util/Iterator<Ljava/lang/String;>;
10 30 5 classAnnoNames Ljava/util/Set<Ljava/lang/String;>;
12 28 6 desc Ljava/lang/String;
13 28 7 name Ljava/lang/String;
14 28 8 tpt Lorg/glassfish/pfl/tf/spi/TimingPointType;
15 28 9 group Ljava/lang/String;
17 28 10 cname Ljava/lang/String;
20 28 11 timerName Ljava/lang/String;
24 25 12 str Ljava/lang/String;
public byte[] evaluate(byte[]);
descriptor: ([B)[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=6, args_size=2
start local 0 start local 1 0: new org.glassfish.pfl.objectweb.asm.tree.ClassNode
dup
invokespecial org.glassfish.pfl.objectweb.asm.tree.ClassNode.<init>:()V
astore 2
start local 2 1: new org.glassfish.pfl.objectweb.asm.ClassReader
dup
aload 1
invokespecial org.glassfish.pfl.objectweb.asm.ClassReader.<init>:([B)V
astore 3
start local 3 2: aload 3
aload 2
iconst_4
invokevirtual org.glassfish.pfl.objectweb.asm.ClassReader.accept:(Lorg/glassfish/pfl/objectweb/asm/ClassVisitor;I)V
3: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
aload 2
getfield org.glassfish.pfl.objectweb.asm.tree.ClassNode.access:I
sipush 8192
invokevirtual org.glassfish.pfl.tf.spi.Util.hasAccess:(II)Z
ifne 5
4: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
aload 2
getfield org.glassfish.pfl.objectweb.asm.tree.ClassNode.access:I
sipush 512
invokevirtual org.glassfish.pfl.tf.spi.Util.hasAccess:(II)Z
ifeq 6
5: StackMap locals: org.glassfish.pfl.objectweb.asm.tree.ClassNode org.glassfish.pfl.objectweb.asm.ClassReader
StackMap stack:
aconst_null
areturn
6: StackMap locals:
StackMap stack:
aload 0
new org.glassfish.pfl.tf.spi.EnhancedClassDataASMImpl
dup
aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.annotationNames:Ljava/util/Set;
aload 2
invokespecial org.glassfish.pfl.tf.spi.EnhancedClassDataASMImpl.<init>:(Lorg/glassfish/pfl/tf/spi/Util;Ljava/util/Set;Lorg/glassfish/pfl/objectweb/asm/tree/ClassNode;)V
putfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
7: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.ecd:Lorg/glassfish/pfl/tf/spi/EnhancedClassData;
invokeinterface org.glassfish.pfl.tf.spi.EnhancedClassData.isTracedClass:()Z
ifne 9
8: aconst_null
areturn
9: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.glassfish.pfl.tf.tools.enhancer.Transformer.processTimers:()V
10: aconst_null
astore 4
start local 4 11: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.mode:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
getstatic org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode.UpdateSchemas:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
if_acmpeq 13
12: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.mode:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
getstatic org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode.TraceEnhance:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
if_acmpne 16
13: StackMap locals: byte[]
StackMap stack:
aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
iconst_0
aload 1
14: new org.glassfish.pfl.tf.tools.enhancer.Transformer$1
dup
aload 0
invokespecial org.glassfish.pfl.tf.tools.enhancer.Transformer$1.<init>:(Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;)V
15: invokevirtual org.glassfish.pfl.tf.spi.Util.transform:(Z[BLorg/glassfish/pfl/basic/func/UnaryFunction;)[B
astore 4
16: StackMap locals:
StackMap stack:
aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.mode:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
getstatic org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode.TraceEnhance:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
if_acmpne 22
17: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
invokevirtual org.glassfish.pfl.tf.spi.Util.getDebug:()Z
aload 4
18: new org.glassfish.pfl.tf.tools.enhancer.Transformer$2
dup
aload 0
invokespecial org.glassfish.pfl.tf.tools.enhancer.Transformer$2.<init>:(Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;)V
19: invokevirtual org.glassfish.pfl.tf.spi.Util.transform:(Z[BLorg/glassfish/pfl/basic/func/UnaryFunction;)[B
astore 5
start local 5 20: aload 5
21: areturn
end local 5 22: StackMap locals:
StackMap stack:
aload 4
23: areturn
end local 4 24: StackMap locals: org.glassfish.pfl.tf.tools.enhancer.Transformer byte[] org.glassfish.pfl.objectweb.asm.tree.ClassNode org.glassfish.pfl.objectweb.asm.ClassReader
StackMap stack: org.glassfish.pfl.tf.spi.TraceEnhancementException
astore 4
start local 4 25: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
invokevirtual org.glassfish.pfl.tf.spi.Util.getDebug:()Z
ifeq 27
26: aload 0
getfield org.glassfish.pfl.tf.tools.enhancer.Transformer.util:Lorg/glassfish/pfl/tf/spi/Util;
iconst_1
new java.lang.StringBuilder
dup
ldc "Could not enhance file: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual org.glassfish.pfl.tf.spi.Util.info:(ILjava/lang/String;)V
27: StackMap locals: org.glassfish.pfl.tf.spi.TraceEnhancementException
StackMap stack:
aconst_null
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;
0 28 1 arg [B
1 28 2 cn Lorg/glassfish/pfl/objectweb/asm/tree/ClassNode;
2 28 3 cr Lorg/glassfish/pfl/objectweb/asm/ClassReader;
11 24 4 phase1 [B
20 22 5 phase2 [B
25 28 4 exc Lorg/glassfish/pfl/tf/spi/TraceEnhancementException;
Exception table:
from to target type
6 8 24 Class org.glassfish.pfl.tf.spi.TraceEnhancementException
9 21 24 Class org.glassfish.pfl.tf.spi.TraceEnhancementException
22 23 24 Class org.glassfish.pfl.tf.spi.TraceEnhancementException
MethodParameters:
Name Flags
arg final
public java.lang.Object evaluate(java.lang.Object);
descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
0: aload 0
aload 1
checkcast byte[]
invokevirtual org.glassfish.pfl.tf.tools.enhancer.Transformer.evaluate:([B)[B
areturn
LocalVariableTable:
Start End Slot Name Signature
}
Signature: Ljava/lang/Object;Lorg/glassfish/pfl/basic/func/UnaryFunction<[B[B>;
SourceFile: "Transformer.java"
NestMembers:
org.glassfish.pfl.tf.tools.enhancer.Transformer$1 org.glassfish.pfl.tf.tools.enhancer.Transformer$2
InnerClasses:
public final ProcessingMode = org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode of org.glassfish.pfl.tf.tools.enhancer.EnhanceTool
org.glassfish.pfl.tf.tools.enhancer.Transformer$1
org.glassfish.pfl.tf.tools.enhancer.Transformer$2