public class org.glassfish.pfl.tf.tools.enhancer.EnhanceTool
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool
  super_class: java.lang.Object
{
  private static int errorCount;
    descriptor: I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private org.glassfish.pfl.tf.spi.Util util;
    descriptor: Lorg/glassfish/pfl/tf/spi/Util;
    flags: (0x0002) ACC_PRIVATE

  private org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments args;
    descriptor: Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
    flags: (0x0002) ACC_PRIVATE

  private org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor tip;
    descriptor: Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 50
            iconst_0
            putstatic org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.errorCount:I
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
         0: .line 49
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool;

  private void generatePropertiesFile(org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments, java.util.Set<java.lang.String>);
    descriptor: (Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;Ljava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=9, args_size=3
        start local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
        start local 1 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments args
        start local 2 // java.util.Set anames
         0: .line 160
            new org.glassfish.pfl.basic.tools.file.FileWrapper
            dup
            aload 1 /* args */
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.rf:()Ljava/io/File;
            invokespecial org.glassfish.pfl.basic.tools.file.FileWrapper.<init>:(Ljava/io/File;)V
            astore 3 /* fw */
        start local 3 // org.glassfish.pfl.basic.tools.file.FileWrapper fw
         1: .line 161
            aload 3 /* fw */
            getstatic org.glassfish.pfl.basic.tools.file.FileWrapper$OpenMode.WRITE_EMPTY:Lorg/glassfish/pfl/basic/tools/file/FileWrapper$OpenMode;
            invokevirtual org.glassfish.pfl.basic.tools.file.FileWrapper.open:(Lorg/glassfish/pfl/basic/tools/file/FileWrapper$OpenMode;)V
         2: .line 164
            aload 3 /* fw */
            ldc "# Trace Facility Annotations"
            invokevirtual org.glassfish.pfl.basic.tools.file.FileWrapper.writeLine:(Ljava/lang/String;)V
         3: .line 165
            aload 3 /* fw */
            new java.lang.StringBuilder
            dup
            ldc "# generated by EnhanceTool on "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.glassfish.pfl.basic.tools.file.FileWrapper.writeLine:(Ljava/lang/String;)V
         4: .line 166
            aload 3 /* fw */
            new java.lang.StringBuilder
            dup
            ldc "org.glassfish.tf.annotations.size="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         5: .line 167
            aload 2 /* anames */
            invokeinterface java.util.Set.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         6: .line 166
            invokevirtual org.glassfish.pfl.basic.tools.file.FileWrapper.writeLine:(Ljava/lang/String;)V
         7: .line 168
            iconst_1
            istore 4 /* ctr */
        start local 4 // int ctr
         8: .line 169
            aload 2 /* anames */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6
            goto 15
      StackMap locals: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments java.util.Set org.glassfish.pfl.basic.tools.file.FileWrapper int top java.util.Iterator
      StackMap stack:
         9: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* str */
        start local 5 // java.lang.String str
        10: .line 170
            aload 5 /* str */
            bipush 47
            bipush 46
            invokevirtual java.lang.String.replace:(CC)Ljava/lang/String;
            astore 7 /* cname */
        start local 7 // java.lang.String cname
        11: .line 171
            aload 3 /* fw */
            new java.lang.StringBuilder
            dup
            ldc "org.glassfish.tf.annotation."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        12: .line 172
            iload 4 /* ctr */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* cname */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 171
            invokevirtual org.glassfish.pfl.basic.tools.file.FileWrapper.writeLine:(Ljava/lang/String;)V
        14: .line 173
            iinc 4 /* ctr */ 1
        end local 7 // java.lang.String cname
        end local 5 // java.lang.String str
        15: .line 169
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        end local 4 // int ctr
        16: .line 175
            goto 20
      StackMap locals: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments java.util.Set org.glassfish.pfl.basic.tools.file.FileWrapper
      StackMap stack: java.lang.Throwable
        17: astore 8
        18: .line 176
            aload 3 /* fw */
            invokevirtual org.glassfish.pfl.basic.tools.file.FileWrapper.close:()V
        19: .line 177
            aload 8
            athrow
        20: .line 176
      StackMap locals:
      StackMap stack:
            aload 3 /* fw */
            invokevirtual org.glassfish.pfl.basic.tools.file.FileWrapper.close:()V
        21: .line 178
            return
        end local 3 // org.glassfish.pfl.basic.tools.file.FileWrapper fw
        end local 2 // java.util.Set anames
        end local 1 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments args
        end local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   22     0    this  Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool;
            0   22     1    args  Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            0   22     2  anames  Ljava/util/Set<Ljava/lang/String;>;
            1   22     3      fw  Lorg/glassfish/pfl/basic/tools/file/FileWrapper;
            8   16     4     ctr  I
           10   15     5     str  Ljava/lang/String;
           11   15     7   cname  Ljava/lang/String;
      Exception table:
        from    to  target  type
           2    17      17  any
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;Ljava/util/Set<Ljava/lang/String;>;)V
    MethodParameters:
        Name  Flags
      args    
      anames  

  private org.glassfish.pfl.basic.tools.file.Scanner$Action makeIgnoreAction(boolean);
    descriptor: (Z)Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
        start local 1 // boolean trace
         0: .line 183
            new org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$1
            dup
            aload 0 /* this */
            iload 1 /* trace */
            invokespecial org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$1.<init>:(Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool;Z)V
            areturn
        end local 1 // boolean trace
        end local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool;
            0    1     1  trace  Z
    MethodParameters:
       Name  Flags
      trace  final

  private void doScan(org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments, org.glassfish.pfl.basic.tools.file.ActionFactory, org.glassfish.pfl.basic.tools.file.Scanner, org.glassfish.pfl.basic.tools.file.Scanner$Action);
    descriptor: (Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;Lorg/glassfish/pfl/basic/tools/file/ActionFactory;Lorg/glassfish/pfl/basic/tools/file/Scanner;Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=7, args_size=5
        start local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
        start local 1 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments args
        start local 2 // org.glassfish.pfl.basic.tools.file.ActionFactory af
        start local 3 // org.glassfish.pfl.basic.tools.file.Scanner scanner
        start local 4 // org.glassfish.pfl.basic.tools.file.Scanner$Action classAct
         0: .line 203
            aload 2 /* af */
            invokevirtual org.glassfish.pfl.basic.tools.file.ActionFactory.getRecognizerAction:()Lorg/glassfish/pfl/basic/tools/file/Recognizer;
            astore 5 /* classRecognizer */
        start local 5 // org.glassfish.pfl.basic.tools.file.Recognizer classRecognizer
         1: .line 204
            aload 0 /* this */
         2: .line 205
            aload 1 /* args */
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.debug:()Z
            ifne 3
            aload 1 /* args */
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.verbose:()I
            iconst_2
            if_icmpgt 3
            iconst_0
            goto 4
      StackMap locals: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments org.glassfish.pfl.basic.tools.file.ActionFactory org.glassfish.pfl.basic.tools.file.Scanner org.glassfish.pfl.basic.tools.file.Scanner$Action org.glassfish.pfl.basic.tools.file.Recognizer
      StackMap stack: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool
         3: iconst_1
         4: .line 204
      StackMap locals: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments org.glassfish.pfl.basic.tools.file.ActionFactory org.glassfish.pfl.basic.tools.file.Scanner org.glassfish.pfl.basic.tools.file.Scanner$Action org.glassfish.pfl.basic.tools.file.Recognizer
      StackMap stack: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool int
            invokevirtual org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.makeIgnoreAction:(Z)Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;
            astore 6 /* ignoreAction */
        start local 6 // org.glassfish.pfl.basic.tools.file.Scanner$Action ignoreAction
         5: .line 206
            aload 5 /* classRecognizer */
            aload 6 /* ignoreAction */
            invokevirtual org.glassfish.pfl.basic.tools.file.Recognizer.setDefaultAction:(Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;)V
         6: .line 207
            aload 5 /* classRecognizer */
            ldc "class"
            aload 4 /* classAct */
            invokevirtual org.glassfish.pfl.basic.tools.file.Recognizer.addKnownSuffix:(Ljava/lang/String;Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;)V
         7: .line 208
            aload 3 /* scanner */
            aload 5 /* classRecognizer */
            invokevirtual org.glassfish.pfl.basic.tools.file.Scanner.scan:(Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;)Z
            pop
         8: .line 209
            return
        end local 6 // org.glassfish.pfl.basic.tools.file.Scanner$Action ignoreAction
        end local 5 // org.glassfish.pfl.basic.tools.file.Recognizer classRecognizer
        end local 4 // org.glassfish.pfl.basic.tools.file.Scanner$Action classAct
        end local 3 // org.glassfish.pfl.basic.tools.file.Scanner scanner
        end local 2 // org.glassfish.pfl.basic.tools.file.ActionFactory af
        end local 1 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments args
        end local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool;
            0    9     1             args  Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            0    9     2               af  Lorg/glassfish/pfl/basic/tools/file/ActionFactory;
            0    9     3          scanner  Lorg/glassfish/pfl/basic/tools/file/Scanner;
            0    9     4         classAct  Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;
            1    9     5  classRecognizer  Lorg/glassfish/pfl/basic/tools/file/Recognizer;
            5    9     6     ignoreAction  Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
          Name  Flags
      args      
      af        
      scanner   
      classAct  

  public void run(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=13, args_size=2
        start local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
        start local 1 // java.lang.String[] strs
         0: .line 213
            new org.glassfish.pfl.basic.tools.argparser.ArgParser
            dup
            ldc Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokespecial org.glassfish.pfl.basic.tools.argparser.ArgParser.<init>:(Ljava/lang/Class;)V
            astore 2 /* ap */
        start local 2 // org.glassfish.pfl.basic.tools.argparser.ArgParser ap
         1: .line 214
            aload 0 /* this */
            aload 2 /* ap */
            aload 1 /* strs */
            ldc Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokevirtual org.glassfish.pfl.basic.tools.argparser.ArgParser.parse:([Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments
            putfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
         2: .line 215
            aload 0 /* this */
            new org.glassfish.pfl.tf.spi.Util
            dup
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.debug:()Z
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.verbose:()I
            invokespecial org.glassfish.pfl.tf.spi.Util.<init>:(ZI)V
            putfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.util:Lorg/glassfish/pfl/tf/spi/Util;
         3: .line 217
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.timingPointClass:()Ljava/lang/String;
            astore 3 /* tpname */
        start local 3 // java.lang.String tpname
         4: .line 218
            ldc ""
            astore 4 /* pkg */
        start local 4 // java.lang.String pkg
         5: .line 219
            aload 3 /* tpname */
            astore 5 /* cname */
        start local 5 // java.lang.String cname
         6: .line 221
            aload 3 /* tpname */
            invokevirtual java.lang.String.length:()I
            ifle 12
         7: .line 222
            aload 3 /* tpname */
            bipush 46
            invokevirtual java.lang.String.lastIndexOf:(I)I
            istore 6 /* index */
        start local 6 // int index
         8: .line 223
            iload 6 /* index */
            ifle 14
         9: .line 224
            aload 3 /* tpname */
            iload 6 /* index */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 5 /* cname */
        10: .line 225
            aload 3 /* tpname */
            iconst_0
            iload 6 /* index */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 4 /* pkg */
        end local 6 // int index
        11: .line 227
            goto 14
        12: .line 228
      StackMap locals: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool java.lang.String[] org.glassfish.pfl.basic.tools.argparser.ArgParser java.lang.String java.lang.String java.lang.String
      StackMap stack:
            ldc "NotUsed"
            astore 5 /* cname */
        13: .line 229
            ldc "no.package"
            astore 4 /* pkg */
        14: .line 232
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor
            dup
            aload 5 /* cname */
            aload 4 /* pkg */
            invokespecial org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            putfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
        15: .line 234
            new org.glassfish.pfl.basic.tools.file.ActionFactory
            dup
            iconst_0
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.dryrun:()Z
            invokespecial org.glassfish.pfl.basic.tools.file.ActionFactory.<init>:(IZ)V
            astore 6 /* af */
        start local 6 // org.glassfish.pfl.basic.tools.file.ActionFactory af
        16: .line 235
            new org.glassfish.pfl.basic.tools.file.Scanner
            dup
            iconst_0
            iconst_1
            anewarray java.io.File
            dup
            iconst_0
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.dir:()Ljava/io/File;
            aastore
            invokespecial org.glassfish.pfl.basic.tools.file.Scanner.<init>:(I[Ljava/io/File;)V
            astore 7 /* scanner */
        start local 7 // org.glassfish.pfl.basic.tools.file.Scanner scanner
        17: .line 237
            new org.glassfish.pfl.tf.tools.enhancer.AnnotationScannerAction
            dup
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.util:Lorg/glassfish/pfl/tf/spi/Util;
        18: .line 238
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
        19: .line 237
            invokespecial org.glassfish.pfl.tf.tools.enhancer.AnnotationScannerAction.<init>:(Lorg/glassfish/pfl/tf/spi/Util;Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;)V
            astore 8 /* annoAct */
        start local 8 // org.glassfish.pfl.tf.tools.enhancer.AnnotationScannerAction annoAct
        20: .line 240
            aload 0 /* this */
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            aload 6 /* af */
            aload 7 /* scanner */
            aload 8 /* annoAct */
            invokevirtual org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.doScan:(Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;Lorg/glassfish/pfl/basic/tools/file/ActionFactory;Lorg/glassfish/pfl/basic/tools/file/Scanner;Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;)V
        21: .line 242
            aload 8 /* annoAct */
            invokevirtual org.glassfish.pfl.tf.tools.enhancer.AnnotationScannerAction.getAnnotationNames:()Ljava/util/Set;
            astore 9 /* anames */
        start local 9 // java.util.Set anames
        22: .line 244
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.debug:()Z
            ifeq 24
        23: .line 245
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.util:Lorg/glassfish/pfl/tf/spi/Util;
            iconst_1
            new java.lang.StringBuilder
            dup
            ldc "MM Annotations: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* anames */
            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
        24: .line 248
      StackMap locals: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool java.lang.String[] org.glassfish.pfl.basic.tools.argparser.ArgParser java.lang.String java.lang.String java.lang.String org.glassfish.pfl.basic.tools.file.ActionFactory org.glassfish.pfl.basic.tools.file.Scanner org.glassfish.pfl.tf.tools.enhancer.AnnotationScannerAction java.util.Set
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            aload 9 /* anames */
            invokevirtual org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.generatePropertiesFile:(Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;Ljava/util/Set;)V
        25: .line 250
            new org.glassfish.pfl.tf.tools.enhancer.Transformer
            dup
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.util:Lorg/glassfish/pfl/tf/spi/Util;
        26: .line 251
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.mode:()Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$ProcessingMode;
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
            aload 9 /* anames */
        27: .line 250
            invokespecial org.glassfish.pfl.tf.tools.enhancer.Transformer.<init>:(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
            astore 10 /* ea */
        start local 10 // org.glassfish.pfl.tf.tools.enhancer.Transformer ea
        28: .line 253
            new org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$EnhancerFileAction
            dup
            aload 0 /* this */
            aload 10 /* ea */
            invokespecial org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$EnhancerFileAction.<init>:(Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool;Lorg/glassfish/pfl/basic/func/UnaryFunction;)V
            astore 11 /* act */
        start local 11 // org.glassfish.pfl.basic.tools.file.Scanner$Action act
        29: .line 255
            aload 0 /* this */
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            aload 6 /* af */
            aload 7 /* scanner */
            aload 11 /* act */
            invokevirtual org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.doScan:(Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;Lorg/glassfish/pfl/basic/tools/file/ActionFactory;Lorg/glassfish/pfl/basic/tools/file/Scanner;Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;)V
        30: .line 257
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.tip:Lorg/glassfish/pfl/tf/timer/spi/TimingInfoProcessor;
            invokevirtual org.glassfish.pfl.tf.timer.spi.TimingInfoProcessor.getResult:()Lorg/glassfish/pfl/basic/contain/Pair;
            astore 12 /* res */
        start local 12 // org.glassfish.pfl.basic.contain.Pair res
        31: .line 259
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.timingPointDir:()Ljava/lang/String;
            ldc ""
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
        32: .line 261
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.timingPointDir:()Ljava/lang/String;
            aload 12 /* res */
        33: .line 260
            invokestatic org.glassfish.pfl.tf.timer.spi.TimerPointSourceGenerator.generateFile:(Ljava/lang/String;Lorg/glassfish/pfl/basic/contain/Pair;)V
        end local 12 // org.glassfish.pfl.basic.contain.Pair res
        end local 11 // org.glassfish.pfl.basic.tools.file.Scanner$Action act
        end local 10 // org.glassfish.pfl.tf.tools.enhancer.Transformer ea
        end local 9 // java.util.Set anames
        end local 8 // org.glassfish.pfl.tf.tools.enhancer.AnnotationScannerAction annoAct
        end local 7 // org.glassfish.pfl.basic.tools.file.Scanner scanner
        end local 6 // org.glassfish.pfl.basic.tools.file.ActionFactory af
        end local 5 // java.lang.String cname
        end local 4 // java.lang.String pkg
        end local 3 // java.lang.String tpname
        end local 2 // org.glassfish.pfl.basic.tools.argparser.ArgParser ap
        34: .line 263
            goto 41
      StackMap locals: org.glassfish.pfl.tf.tools.enhancer.EnhanceTool java.lang.String[]
      StackMap stack: java.lang.Exception
        35: astore 2 /* exc */
        start local 2 // java.lang.Exception exc
        36: .line 264
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.util:Lorg/glassfish/pfl/tf/spi/Util;
            ifnonnull 38
        37: .line 265
            aload 0 /* this */
            new org.glassfish.pfl.tf.spi.Util
            dup
            iconst_1
            iconst_1
            invokespecial org.glassfish.pfl.tf.spi.Util.<init>:(ZI)V
            putfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.util:Lorg/glassfish/pfl/tf/spi/Util;
        38: .line 268
      StackMap locals: java.lang.Exception
      StackMap stack:
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.util:Lorg/glassfish/pfl/tf/spi/Util;
            iconst_1
            new java.lang.StringBuilder
            dup
            ldc "Exception: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* exc */
            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
        39: .line 269
            aload 0 /* this */
            getfield org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.args:Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool$Arguments;
            invokeinterface org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments.debug:()Z
            ifeq 41
        40: .line 270
            aload 2 /* exc */
            invokevirtual java.lang.Exception.printStackTrace:()V
        end local 2 // java.lang.Exception exc
        41: .line 273
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String[] strs
        end local 0 // org.glassfish.pfl.tf.tools.enhancer.EnhanceTool this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   42     0     this  Lorg/glassfish/pfl/tf/tools/enhancer/EnhanceTool;
            0   42     1     strs  [Ljava/lang/String;
            1   34     2       ap  Lorg/glassfish/pfl/basic/tools/argparser/ArgParser;
            4   34     3   tpname  Ljava/lang/String;
            5   34     4      pkg  Ljava/lang/String;
            6   34     5    cname  Ljava/lang/String;
            8   11     6    index  I
           16   34     6       af  Lorg/glassfish/pfl/basic/tools/file/ActionFactory;
           17   34     7  scanner  Lorg/glassfish/pfl/basic/tools/file/Scanner;
           20   34     8  annoAct  Lorg/glassfish/pfl/tf/tools/enhancer/AnnotationScannerAction;
           22   34     9   anames  Ljava/util/Set<Ljava/lang/String;>;
           28   34    10       ea  Lorg/glassfish/pfl/tf/tools/enhancer/Transformer;
           29   34    11      act  Lorg/glassfish/pfl/basic/tools/file/Scanner$Action;
           31   34    12      res  Lorg/glassfish/pfl/basic/contain/Pair<Ljava/lang/String;Lorg/glassfish/pfl/tf/timer/spi/TimerFactory;>;
           36   41     2      exc  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0    34      35  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      strs  

  public static void main(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String[] strs
         0: .line 276
            new org.glassfish.pfl.tf.tools.enhancer.EnhanceTool
            dup
            invokespecial org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.<init>:()V
            aload 0 /* strs */
            invokevirtual org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.run:([Ljava/lang/String;)V
         1: .line 277
            getstatic org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.errorCount:I
            ifle 3
         2: .line 278
            getstatic org.glassfish.pfl.tf.tools.enhancer.EnhanceTool.errorCount:I
            invokestatic java.lang.System.exit:(I)V
         3: .line 280
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.lang.String[] strs
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  strs  [Ljava/lang/String;
    MethodParameters:
      Name  Flags
      strs  
}
SourceFile: "EnhanceTool.java"
NestMembers:
  org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$1  org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments  org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$EnhancerFileAction  org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode
InnerClasses:
  public final OpenMode = org.glassfish.pfl.basic.tools.file.FileWrapper$OpenMode of org.glassfish.pfl.basic.tools.file.FileWrapper
  public abstract Action = org.glassfish.pfl.basic.tools.file.Scanner$Action of org.glassfish.pfl.basic.tools.file.Scanner
  org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$1
  public abstract Arguments = org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$Arguments of org.glassfish.pfl.tf.tools.enhancer.EnhanceTool
  private EnhancerFileAction = org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$EnhancerFileAction of org.glassfish.pfl.tf.tools.enhancer.EnhanceTool
  public final ProcessingMode = org.glassfish.pfl.tf.tools.enhancer.EnhanceTool$ProcessingMode of org.glassfish.pfl.tf.tools.enhancer.EnhanceTool