public class jdk.jpackage.internal.Log$Logger
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: jdk.jpackage.internal.Log$Logger
  super_class: java.lang.Object
{
  private boolean verbose;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private java.io.PrintWriter out;
    descriptor: Ljava/io/PrintWriter;
    flags: (0x0002) ACC_PRIVATE

  private java.io.PrintWriter err;
    descriptor: Ljava/io/PrintWriter;
    flags: (0x0002) ACC_PRIVATE

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // jdk.jpackage.internal.Log$Logger this
         0: .line 48
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 40
            aload 0 /* this */
            iconst_0
            putfield jdk.jpackage.internal.Log$Logger.verbose:Z
         2: .line 41
            aload 0 /* this */
            aconst_null
            putfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
         3: .line 42
            aload 0 /* this */
            aconst_null
            putfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
         4: .line 49
            aload 0 /* this */
            ldc "true"
            ldc "JPACKAGE_DEBUG"
            invokestatic java.lang.System.getenv:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            putfield jdk.jpackage.internal.Log$Logger.verbose:Z
         5: .line 50
            return
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljdk/jpackage/internal/Log$Logger;

  public void setVerbose();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // jdk.jpackage.internal.Log$Logger this
         0: .line 53
            aload 0 /* this */
            iconst_1
            putfield jdk.jpackage.internal.Log$Logger.verbose:Z
         1: .line 54
            return
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljdk/jpackage/internal/Log$Logger;

  public boolean isVerbose();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jpackage.internal.Log$Logger this
         0: .line 57
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.verbose:Z
            ireturn
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/jpackage/internal/Log$Logger;

  public void setPrintWriter(java.io.PrintWriter, java.io.PrintWriter);
    descriptor: (Ljava/io/PrintWriter;Ljava/io/PrintWriter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.io.PrintWriter out
        start local 2 // java.io.PrintWriter err
         0: .line 61
            aload 0 /* this */
            aload 1 /* out */
            putfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
         1: .line 62
            aload 0 /* this */
            aload 2 /* err */
            putfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
         2: .line 63
            return
        end local 2 // java.io.PrintWriter err
        end local 1 // java.io.PrintWriter out
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljdk/jpackage/internal/Log$Logger;
            0    3     1   out  Ljava/io/PrintWriter;
            0    3     2   err  Ljava/io/PrintWriter;
    MethodParameters:
      Name  Flags
      out   
      err   

  public void flush();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jpackage.internal.Log$Logger this
         0: .line 66
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            ifnull 2
         1: .line 67
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            invokevirtual java.io.PrintWriter.flush:()V
         2: .line 70
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
            ifnull 4
         3: .line 71
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
            invokevirtual java.io.PrintWriter.flush:()V
         4: .line 73
      StackMap locals:
      StackMap stack:
            return
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Ljdk/jpackage/internal/Log$Logger;

  public void info(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.lang.String msg
         0: .line 76
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            ifnull 2
         1: .line 77
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            aload 1 /* msg */
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
         2: .line 79
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String msg
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljdk/jpackage/internal/Log$Logger;
            0    3     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   

  public void fatalError(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.lang.String msg
         0: .line 82
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
            ifnull 2
         1: .line 83
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
            aload 1 /* msg */
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
         2: .line 85
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String msg
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljdk/jpackage/internal/Log$Logger;
            0    3     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   

  public void error(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.lang.String msg
         0: .line 88
            aload 0 /* this */
            aload 1 /* msg */
            invokevirtual jdk.jpackage.internal.Log$Logger.addTimestamp:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* msg */
         1: .line 89
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
            ifnull 3
         2: .line 90
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.err:Ljava/io/PrintWriter;
            aload 1 /* msg */
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
         3: .line 92
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String msg
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljdk/jpackage/internal/Log$Logger;
            0    4     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   

  public void verbose(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.lang.Throwable t
         0: .line 95
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            ifnull 3
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.verbose:Z
            ifeq 3
         1: .line 96
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            aload 0 /* this */
            ldc ""
            invokevirtual jdk.jpackage.internal.Log$Logger.addTimestamp:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
         2: .line 97
            aload 1 /* t */
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintWriter;)V
         3: .line 99
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable t
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljdk/jpackage/internal/Log$Logger;
            0    4     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void verbose(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.lang.String msg
         0: .line 102
            aload 0 /* this */
            aload 1 /* msg */
            invokevirtual jdk.jpackage.internal.Log$Logger.addTimestamp:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* msg */
         1: .line 103
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            ifnull 3
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.verbose:Z
            ifeq 3
         2: .line 104
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.out:Ljava/io/PrintWriter;
            aload 1 /* msg */
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
         3: .line 106
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String msg
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljdk/jpackage/internal/Log$Logger;
            0    4     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   

  public void verbose(java.util.List<java.lang.String>, java.util.List<java.lang.String>, );
    descriptor: (Ljava/util/List;Ljava/util/List;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=4
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.util.List strings
        start local 2 // java.util.List output
        start local 3 // int returnCode
         0: .line 110
            aload 0 /* this */
            getfield jdk.jpackage.internal.Log$Logger.verbose:Z
            ifeq 15
         1: .line 111
            new java.lang.StringBuffer
            dup
            ldc "Command:\n   "
            invokespecial java.lang.StringBuffer.<init>:(Ljava/lang/String;)V
            astore 4 /* sb */
        start local 4 // java.lang.StringBuffer sb
         2: .line 112
            aload 1 /* strings */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 5
      StackMap locals: jdk.jpackage.internal.Log$Logger java.util.List java.util.List int java.lang.StringBuffer top java.util.Iterator
      StackMap stack:
         3: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* s */
        start local 5 // java.lang.String s
         4: .line 113
            aload 4 /* sb */
            new java.lang.StringBuilder
            dup
            ldc " "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* s */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        end local 5 // java.lang.String s
         5: .line 112
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 115
            aload 0 /* this */
            new java.lang.String
            dup
            aload 4 /* sb */
            invokespecial java.lang.String.<init>:(Ljava/lang/StringBuffer;)V
            invokevirtual jdk.jpackage.internal.Log$Logger.verbose:(Ljava/lang/String;)V
         7: .line 116
            aload 2 /* output */
            ifnull 14
            aload 2 /* output */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 14
         8: .line 117
            new java.lang.StringBuffer
            dup
            ldc "Output:"
            invokespecial java.lang.StringBuffer.<init>:(Ljava/lang/String;)V
            astore 4 /* sb */
         9: .line 118
            aload 2 /* output */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 12
      StackMap locals:
      StackMap stack:
        10: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* s */
        start local 5 // java.lang.String s
        11: .line 119
            aload 4 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n    "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* s */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        end local 5 // java.lang.String s
        12: .line 118
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        13: .line 121
            aload 0 /* this */
            new java.lang.String
            dup
            aload 4 /* sb */
            invokespecial java.lang.String.<init>:(Ljava/lang/StringBuffer;)V
            invokevirtual jdk.jpackage.internal.Log$Logger.verbose:(Ljava/lang/String;)V
        14: .line 123
      StackMap locals: jdk.jpackage.internal.Log$Logger java.util.List java.util.List int java.lang.StringBuffer
      StackMap stack:
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Returned: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 3 /* returnCode */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual jdk.jpackage.internal.Log$Logger.verbose:(Ljava/lang/String;)V
        end local 4 // java.lang.StringBuffer sb
        15: .line 125
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int returnCode
        end local 2 // java.util.List output
        end local 1 // java.util.List strings
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   16     0        this  Ljdk/jpackage/internal/Log$Logger;
            0   16     1     strings  Ljava/util/List<Ljava/lang/String;>;
            0   16     2      output  Ljava/util/List<Ljava/lang/String;>;
            0   16     3  returnCode  I
            2   15     4          sb  Ljava/lang/StringBuffer;
            4    5     5           s  Ljava/lang/String;
           11   12     5           s  Ljava/lang/String;
    Signature: (Ljava/util/List<Ljava/lang/String;>;Ljava/util/List<Ljava/lang/String;>;I)V
    MethodParameters:
            Name  Flags
      strings     
      output      
      returnCode  

  private java.lang.String addTimestamp(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=4, args_size=2
        start local 0 // jdk.jpackage.internal.Log$Logger this
        start local 1 // java.lang.String msg
         0: .line 128
            new java.text.SimpleDateFormat
            dup
            ldc "HH:mm:ss.SSS"
            invokespecial java.text.SimpleDateFormat.<init>:(Ljava/lang/String;)V
            astore 2 /* sdf */
        start local 2 // java.text.SimpleDateFormat sdf
         1: .line 129
            new java.util.Date
            dup
            invokestatic java.lang.System.currentTimeMillis:()J
            invokespecial java.util.Date.<init>:(J)V
            astore 3 /* time */
        start local 3 // java.util.Date time
         2: .line 130
            ldc "[%s] %s"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* sdf */
            aload 3 /* time */
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            iconst_1
            aload 1 /* msg */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 3 // java.util.Date time
        end local 2 // java.text.SimpleDateFormat sdf
        end local 1 // java.lang.String msg
        end local 0 // jdk.jpackage.internal.Log$Logger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljdk/jpackage/internal/Log$Logger;
            0    3     1   msg  Ljava/lang/String;
            1    3     2   sdf  Ljava/text/SimpleDateFormat;
            2    3     3  time  Ljava/util/Date;
    MethodParameters:
      Name  Flags
      msg   
}
SourceFile: "Log.java"
NestHost: jdk.jpackage.internal.Log
InnerClasses:
  public Logger = jdk.jpackage.internal.Log$Logger of jdk.jpackage.internal.Log