class sun.security.ssl.SSLLogger$SSLSimpleFormatter
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.ssl.SSLLogger$SSLSimpleFormatter
  super_class: java.lang.Object
{
  private static final java.lang.ThreadLocal<java.text.SimpleDateFormat> dateFormat;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/text/SimpleDateFormat;>;

  private static final java.text.MessageFormat basicCertFormat;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.text.MessageFormat extendedCertFormart;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.text.MessageFormat messageFormatNoParas;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.text.MessageFormat messageCompactFormatNoParas;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.text.MessageFormat messageFormatWithParas;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.text.MessageFormat messageCompactFormatWithParas;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.text.MessageFormat keyObjectFormat;
    descriptor: Ljava/text/MessageFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 251
            new sun.security.ssl.SSLLogger$SSLSimpleFormatter$1
            dup
            invokespecial sun.security.ssl.SSLLogger$SSLSimpleFormatter$1.<init>:()V
         1: .line 250
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.dateFormat:Ljava/lang/ThreadLocal;
         2: .line 258
            new java.text.MessageFormat
            dup
         3: .line 259
            ldc "\"version\"            : \"v{0}\",\n\"serial number\"      : \"{1}\",\n\"signature algorithm\": \"{2}\",\n\"issuer\"             : \"{3}\",\n\"not before\"         : \"{4}\",\n\"not  after\"         : \"{5}\",\n\"subject\"            : \"{6}\",\n\"subject public key\" : \"{7}\"\n"
         4: .line 267
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         5: .line 258
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.basicCertFormat:Ljava/text/MessageFormat;
         6: .line 270
            new java.text.MessageFormat
            dup
         7: .line 271
            ldc "\"version\"            : \"v{0}\",\n\"serial number\"      : \"{1}\",\n\"signature algorithm\": \"{2}\",\n\"issuer\"             : \"{3}\",\n\"not before\"         : \"{4}\",\n\"not  after\"         : \"{5}\",\n\"subject\"            : \"{6}\",\n\"subject public key\" : \"{7}\",\n\"extensions\"         : [\n{8}\n]\n"
         8: .line 282
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         9: .line 270
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
        10: .line 269
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.extendedCertFormart:Ljava/text/MessageFormat;
        11: .line 294
            new java.text.MessageFormat
            dup
        12: .line 295
            ldc "'{'\n  \"logger\"      : \"{0}\",\n  \"level\"       : \"{1}\",\n  \"thread id\"   : \"{2}\",\n  \"thread name\" : \"{3}\",\n  \"time\"        : \"{4}\",\n  \"caller\"      : \"{5}\",\n  \"message\"     : \"{6}\"\n'}'\n"
        13: .line 304
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
        14: .line 294
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
        15: .line 293
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageFormatNoParas:Ljava/text/MessageFormat;
        16: .line 307
            new java.text.MessageFormat
            dup
        17: .line 308
            ldc "{0}|{1}|{2}|{3}|{4}|{5}|{6}\n"
        18: .line 309
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
        19: .line 307
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
        20: .line 306
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageCompactFormatNoParas:Ljava/text/MessageFormat;
        21: .line 312
            new java.text.MessageFormat
            dup
        22: .line 313
            ldc "'{'\n  \"logger\"      : \"{0}\",\n  \"level\"       : \"{1}\",\n  \"thread id\"   : \"{2}\",\n  \"thread name\" : \"{3}\",\n  \"time\"        : \"{4}\",\n  \"caller\"      : \"{5}\",\n  \"message\"     : \"{6}\",\n  \"specifics\"   : [\n{7}\n  ]\n'}'\n"
        23: .line 325
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
        24: .line 312
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
        25: .line 311
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageFormatWithParas:Ljava/text/MessageFormat;
        26: .line 328
            new java.text.MessageFormat
            dup
        27: .line 329
            ldc "{0}|{1}|{2}|{3}|{4}|{5}|{6} (\n{7}\n)\n"
        28: .line 332
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
        29: .line 328
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
        30: .line 327
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageCompactFormatWithParas:Ljava/text/MessageFormat;
        31: .line 334
            new java.text.MessageFormat
            dup
        32: .line 335
            ldc "\"{0}\" : '{'\n{1}'}'\n"
        33: .line 338
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
        34: .line 334
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            putstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.keyObjectFormat:Ljava/text/MessageFormat;
        35: .line 338
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLLogger$SSLSimpleFormatter this
         0: .line 249
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.ssl.SSLLogger$SSLSimpleFormatter this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/SSLLogger$SSLSimpleFormatter;

  private static java.lang.String format(sun.security.ssl.SSLLogger$SSLConsoleLogger, java.util.logging.Level, java.lang.String, java.lang.Object[]);
    descriptor: (Lsun/security/ssl/SSLLogger$SSLConsoleLogger;Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x008a) ACC_PRIVATE, ACC_STATIC, ACC_VARARGS
    Code:
      stack=8, locals=5, args_size=4
        start local 0 // sun.security.ssl.SSLLogger$SSLConsoleLogger logger
        start local 1 // java.util.logging.Level level
        start local 2 // java.lang.String message
        start local 3 // java.lang.Object[] parameters
         0: .line 347
            aload 3 /* parameters */
            ifnull 1
            aload 3 /* parameters */
            arraylength
            ifne 13
         1: .line 348
      StackMap locals:
      StackMap stack:
            bipush 7
            anewarray java.lang.Object
            dup
            iconst_0
         2: .line 349
            aload 0 /* logger */
            getfield sun.security.ssl.SSLLogger$SSLConsoleLogger.loggerName:Ljava/lang/String;
            aastore
            dup
            iconst_1
         3: .line 350
            aload 1 /* level */
            invokevirtual java.util.logging.Level.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_2
         4: .line 351
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getId:()J
            invokestatic sun.security.ssl.Utilities.toHexString:(J)Ljava/lang/String;
            aastore
            dup
            iconst_3
         5: .line 352
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_4
         6: .line 353
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.dateFormat:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.text.SimpleDateFormat
            new java.util.Date
            dup
            invokestatic java.lang.System.currentTimeMillis:()J
            invokespecial java.util.Date.<init>:(J)V
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            iconst_5
         7: .line 354
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatCaller:()Ljava/lang/String;
            aastore
            dup
            bipush 6
         8: .line 355
            aload 2 /* message */
            aastore
         9: .line 348
            astore 4 /* messageFields */
        start local 4 // java.lang.Object[] messageFields
        10: .line 358
            aload 0 /* logger */
            getfield sun.security.ssl.SSLLogger$SSLConsoleLogger.useCompactFormat:Z
            ifeq 12
        11: .line 359
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageCompactFormatNoParas:Ljava/text/MessageFormat;
            aload 4 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        12: .line 361
      StackMap locals: java.lang.Object[]
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageFormatNoParas:Ljava/text/MessageFormat;
            aload 4 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 4 // java.lang.Object[] messageFields
        13: .line 365
      StackMap locals:
      StackMap stack:
            bipush 8
            anewarray java.lang.Object
            dup
            iconst_0
        14: .line 366
            aload 0 /* logger */
            getfield sun.security.ssl.SSLLogger$SSLConsoleLogger.loggerName:Ljava/lang/String;
            aastore
            dup
            iconst_1
        15: .line 367
            aload 1 /* level */
            invokevirtual java.util.logging.Level.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_2
        16: .line 368
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getId:()J
            invokestatic sun.security.ssl.Utilities.toHexString:(J)Ljava/lang/String;
            aastore
            dup
            iconst_3
        17: .line 369
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_4
        18: .line 370
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.dateFormat:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.text.SimpleDateFormat
            new java.util.Date
            dup
            invokestatic java.lang.System.currentTimeMillis:()J
            invokespecial java.util.Date.<init>:(J)V
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            iconst_5
        19: .line 371
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatCaller:()Ljava/lang/String;
            aastore
            dup
            bipush 6
        20: .line 372
            aload 2 /* message */
            aastore
            dup
            bipush 7
        21: .line 373
            aload 0 /* logger */
            getfield sun.security.ssl.SSLLogger$SSLConsoleLogger.useCompactFormat:Z
            ifeq 23
        22: .line 374
            aload 3 /* parameters */
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatParameters:([Ljava/lang/Object;)Ljava/lang/String;
            goto 24
        23: .line 375
      StackMap locals: sun.security.ssl.SSLLogger$SSLConsoleLogger java.util.logging.Level java.lang.String java.lang.Object[]
      StackMap stack: java.lang.Object[] java.lang.Object[] int
            aload 3 /* parameters */
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatParameters:([Ljava/lang/Object;)Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
      StackMap locals: sun.security.ssl.SSLLogger$SSLConsoleLogger java.util.logging.Level java.lang.String java.lang.Object[]
      StackMap stack: java.lang.Object[] java.lang.Object[] int java.lang.String
        24: aastore
        25: .line 365
            astore 4 /* messageFields */
        start local 4 // java.lang.Object[] messageFields
        26: .line 378
            aload 0 /* logger */
            getfield sun.security.ssl.SSLLogger$SSLConsoleLogger.useCompactFormat:Z
            ifeq 28
        27: .line 379
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageCompactFormatWithParas:Ljava/text/MessageFormat;
            aload 4 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        28: .line 381
      StackMap locals: java.lang.Object[]
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.messageFormatWithParas:Ljava/text/MessageFormat;
            aload 4 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 4 // java.lang.Object[] messageFields
        end local 3 // java.lang.Object[] parameters
        end local 2 // java.lang.String message
        end local 1 // java.util.logging.Level level
        end local 0 // sun.security.ssl.SSLLogger$SSLConsoleLogger logger
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   29     0         logger  Lsun/security/ssl/SSLLogger$SSLConsoleLogger;
            0   29     1          level  Ljava/util/logging/Level;
            0   29     2        message  Ljava/lang/String;
            0   29     3     parameters  [Ljava/lang/Object;
           10   13     4  messageFields  [Ljava/lang/Object;
           26   29     4  messageFields  [Ljava/lang/Object;
    MethodParameters:
            Name  Flags
      logger      
      level       
      message     
      parameters  

  private static java.lang.String formatCaller();
    descriptor: ()Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=0
         0: .line 386
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getStackTrace:()[Ljava/lang/StackTraceElement;
            astore 0 /* stElements */
        start local 0 // java.lang.StackTraceElement[] stElements
         1: .line 387
            iconst_1
            istore 1 /* i */
        start local 1 // int i
         2: goto 8
         3: .line 388
      StackMap locals: java.lang.StackTraceElement[] int
      StackMap stack:
            aload 0 /* stElements */
            iload 1 /* i */
            aaload
            astore 2 /* ste */
        start local 2 // java.lang.StackTraceElement ste
         4: .line 389
            aload 2 /* ste */
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            ldc Lsun/security/ssl/SSLLogger;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 7
         5: .line 390
            aload 2 /* ste */
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            ldc "java.lang.System"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 7
         6: .line 391
            new java.lang.StringBuilder
            dup
            aload 2 /* ste */
            invokevirtual java.lang.StackTraceElement.getFileName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ":"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* ste */
            invokevirtual java.lang.StackTraceElement.getLineNumber:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 2 // java.lang.StackTraceElement ste
         7: .line 387
      StackMap locals:
      StackMap stack:
            iinc 1 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 1 /* i */
            aload 0 /* stElements */
            arraylength
            if_icmplt 3
        end local 1 // int i
         9: .line 394
            ldc "unknown caller"
            areturn
        end local 0 // java.lang.StackTraceElement[] stElements
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            1   10     0  stElements  [Ljava/lang/StackTraceElement;
            2    9     1           i  I
            4    7     2         ste  Ljava/lang/StackTraceElement;

  private static java.lang.String formatParameters(java.lang.Object[]);
    descriptor: ([Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x008a) ACC_PRIVATE, ACC_STATIC, ACC_VARARGS
    Code:
      stack=4, locals=8, args_size=1
        start local 0 // java.lang.Object[] parameters
         0: .line 398
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 1 /* builder */
        start local 1 // java.lang.StringBuilder builder
         1: .line 399
            iconst_1
            istore 2 /* isFirst */
        start local 2 // boolean isFirst
         2: .line 400
            aload 0 /* parameters */
            dup
            astore 6
            arraylength
            istore 5
            iconst_0
            istore 4
            goto 34
      StackMap locals: java.lang.Object[] java.lang.StringBuilder int top int int java.lang.Object[]
      StackMap stack:
         3: aload 6
            iload 4
            aaload
            astore 3 /* parameter */
        start local 3 // java.lang.Object parameter
         4: .line 401
            iload 2 /* isFirst */
            ifeq 7
         5: .line 402
            iconst_0
            istore 2 /* isFirst */
         6: .line 403
            goto 8
         7: .line 404
      StackMap locals: java.lang.Object[] java.lang.StringBuilder int java.lang.Object int int java.lang.Object[]
      StackMap stack:
            aload 1 /* builder */
            ldc ",\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         8: .line 407
      StackMap locals:
      StackMap stack:
            aload 3 /* parameter */
            instanceof java.lang.Throwable
            ifeq 11
         9: .line 408
            aload 1 /* builder */
            aload 3 /* parameter */
            checkcast java.lang.Throwable
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatThrowable:(Ljava/lang/Throwable;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        10: .line 409
            goto 33
      StackMap locals:
      StackMap stack:
        11: aload 3 /* parameter */
            instanceof java.security.cert.Certificate
            ifeq 14
        12: .line 410
            aload 1 /* builder */
            aload 3 /* parameter */
            checkcast java.security.cert.Certificate
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatCertificate:(Ljava/security/cert/Certificate;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        13: .line 411
            goto 33
      StackMap locals:
      StackMap stack:
        14: aload 3 /* parameter */
            instanceof java.io.ByteArrayInputStream
            ifeq 19
        15: .line 412
            aload 1 /* builder */
        16: .line 413
            aload 3 /* parameter */
            checkcast java.io.ByteArrayInputStream
        17: .line 412
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatByteArrayInputStream:(Ljava/io/ByteArrayInputStream;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        18: .line 414
            goto 33
      StackMap locals:
      StackMap stack:
        19: aload 3 /* parameter */
            instanceof java.nio.ByteBuffer
            ifeq 22
        20: .line 415
            aload 1 /* builder */
            aload 3 /* parameter */
            checkcast java.nio.ByteBuffer
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatByteBuffer:(Ljava/nio/ByteBuffer;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        21: .line 416
            goto 33
      StackMap locals:
      StackMap stack:
        22: aload 3 /* parameter */
            instanceof byte[]
            ifeq 27
        23: .line 417
            aload 1 /* builder */
        24: .line 418
            new java.io.ByteArrayInputStream
            dup
            aload 3 /* parameter */
            checkcast byte[]
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
        25: .line 417
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatByteArrayInputStream:(Ljava/io/ByteArrayInputStream;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        26: .line 419
            goto 33
      StackMap locals:
      StackMap stack:
        27: aload 3 /* parameter */
            instanceof java.util.Map$Entry
            ifeq 32
        28: .line 422
            aload 3 /* parameter */
            checkcast java.util.Map$Entry
        29: .line 421
            astore 7 /* mapParameter */
        start local 7 // java.util.Map$Entry mapParameter
        30: .line 423
            aload 1 /* builder */
            aload 7 /* mapParameter */
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatMapEntry:(Ljava/util/Map$Entry;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 7 // java.util.Map$Entry mapParameter
        31: .line 424
            goto 33
        32: .line 425
      StackMap locals:
      StackMap stack:
            aload 1 /* builder */
            aload 3 /* parameter */
            invokestatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.formatObject:(Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 3 // java.lang.Object parameter
        33: .line 400
      StackMap locals: java.lang.Object[] java.lang.StringBuilder int top int int java.lang.Object[]
      StackMap stack:
            iinc 4 1
      StackMap locals:
      StackMap stack:
        34: iload 4
            iload 5
            if_icmplt 3
        35: .line 429
            aload 1 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 2 // boolean isFirst
        end local 1 // java.lang.StringBuilder builder
        end local 0 // java.lang.Object[] parameters
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   36     0    parameters  [Ljava/lang/Object;
            1   36     1       builder  Ljava/lang/StringBuilder;
            2   36     2       isFirst  Z
            4   33     3     parameter  Ljava/lang/Object;
           30   31     7  mapParameter  Ljava/util/Map$Entry<Ljava/lang/String;*>;
    MethodParameters:
            Name  Flags
      parameters  

  private static java.lang.String formatThrowable(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // java.lang.Throwable throwable
         0: .line 436
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 1 /* builder */
        start local 1 // java.lang.StringBuilder builder
         1: .line 437
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* bytesOut */
        start local 2 // java.io.ByteArrayOutputStream bytesOut
         2: .line 438
            aconst_null
            astore 3
            aconst_null
            astore 4
         3: new java.io.PrintStream
            dup
            aload 2 /* bytesOut */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 5 /* out */
        start local 5 // java.io.PrintStream out
         4: .line 439
            aload 0 /* throwable */
            aload 5 /* out */
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintStream;)V
         5: .line 440
            aload 1 /* builder */
            aload 2 /* bytesOut */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         6: .line 441
            aload 5 /* out */
            ifnull 12
            aload 5 /* out */
            invokevirtual java.io.PrintStream.close:()V
            goto 12
      StackMap locals: java.lang.Throwable java.lang.StringBuilder java.io.ByteArrayOutputStream java.lang.Throwable java.lang.Throwable java.io.PrintStream
      StackMap stack: java.lang.Throwable
         7: astore 3
            aload 5 /* out */
            ifnull 8
            aload 5 /* out */
            invokevirtual java.io.PrintStream.close:()V
        end local 5 // java.io.PrintStream out
      StackMap locals:
      StackMap stack:
         8: aload 3
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
         9: astore 4
            aload 3
            ifnonnull 10
            aload 4
            astore 3
            goto 11
      StackMap locals:
      StackMap stack:
        10: aload 3
            aload 4
            if_acmpeq 11
            aload 3
            aload 4
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        11: aload 3
            athrow
        12: .line 442
      StackMap locals:
      StackMap stack:
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
        13: .line 443
            ldc "throwable"
            aastore
            dup
            iconst_1
        14: .line 444
            aload 1 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aastore
        15: .line 442
            astore 3 /* fields */
        start local 3 // java.lang.Object[] fields
        16: .line 447
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.keyObjectFormat:Ljava/text/MessageFormat;
            aload 3 /* fields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 3 // java.lang.Object[] fields
        end local 2 // java.io.ByteArrayOutputStream bytesOut
        end local 1 // java.lang.StringBuilder builder
        end local 0 // java.lang.Throwable throwable
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   17     0  throwable  Ljava/lang/Throwable;
            1   17     1    builder  Ljava/lang/StringBuilder;
            2   17     2   bytesOut  Ljava/io/ByteArrayOutputStream;
            4    8     5        out  Ljava/io/PrintStream;
           16   17     3     fields  [Ljava/lang/Object;
      Exception table:
        from    to  target  type
           4     6       7  any
           3     9       9  any
    MethodParameters:
           Name  Flags
      throwable  

  private static java.lang.String formatCertificate(java.security.cert.Certificate);
    descriptor: (Ljava/security/cert/Certificate;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=9, args_size=1
        start local 0 // java.security.cert.Certificate certificate
         0: .line 455
            aload 0 /* certificate */
            instanceof java.security.cert.X509Certificate
            ifne 2
         1: .line 456
            aload 0 /* certificate */
            invokevirtual java.security.cert.Certificate.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            areturn
         2: .line 459
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 1 /* builder */
        start local 1 // java.lang.StringBuilder builder
         3: .line 462
            aload 0 /* certificate */
            checkcast java.security.cert.X509Certificate
            invokestatic sun.security.x509.X509CertImpl.toImpl:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
         4: .line 461
            astore 2 /* x509 */
        start local 2 // sun.security.x509.X509CertImpl x509
         5: .line 464
            aload 2 /* x509 */
            ldc "x509.info"
            invokevirtual sun.security.x509.X509CertImpl.get:(Ljava/lang/String;)Ljava/lang/Object;
            checkcast sun.security.x509.X509CertInfo
         6: .line 463
            astore 3 /* certInfo */
        start local 3 // sun.security.x509.X509CertInfo certInfo
         7: .line 467
            aload 3 /* certInfo */
            ldc "extensions"
            invokevirtual sun.security.x509.X509CertInfo.get:(Ljava/lang/String;)Ljava/lang/Object;
         8: .line 466
            checkcast sun.security.x509.CertificateExtensions
            astore 4 /* certExts */
        start local 4 // sun.security.x509.CertificateExtensions certExts
         9: .line 468
            aload 4 /* certExts */
            ifnonnull 25
        10: .line 469
            bipush 8
            anewarray java.lang.Object
            dup
            iconst_0
        11: .line 470
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getVersion:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
        12: .line 472
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getSerialNumber:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.toByteArray:()[B
        13: .line 471
            invokestatic sun.security.ssl.Utilities.toHexString:([B)Ljava/lang/String;
            aastore
            dup
            iconst_2
        14: .line 473
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getSigAlgName:()Ljava/lang/String;
            aastore
            dup
            iconst_3
        15: .line 474
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
            aastore
            dup
            iconst_4
        16: .line 475
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.dateFormat:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.text.SimpleDateFormat
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getNotBefore:()Ljava/util/Date;
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            iconst_5
        17: .line 476
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.dateFormat:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.text.SimpleDateFormat
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getNotAfter:()Ljava/util/Date;
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            bipush 6
        18: .line 477
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
            aastore
            dup
            bipush 7
        19: .line 478
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getPublicKey:()Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
            aastore
        20: .line 469
            astore 5 /* certFields */
        start local 5 // java.lang.Object[] certFields
        21: .line 480
            aload 1 /* builder */
        22: .line 481
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.basicCertFormat:Ljava/text/MessageFormat;
            aload 5 /* certFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
        23: .line 480
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 5 // java.lang.Object[] certFields
        24: .line 482
            goto 54
        25: .line 483
      StackMap locals: java.security.cert.Certificate java.lang.StringBuilder sun.security.x509.X509CertImpl sun.security.x509.X509CertInfo sun.security.x509.CertificateExtensions
      StackMap stack:
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 5 /* extBuilder */
        start local 5 // java.lang.StringBuilder extBuilder
        26: .line 484
            iconst_1
            istore 6 /* isFirst */
        start local 6 // boolean isFirst
        27: .line 485
            aload 4 /* certExts */
            invokevirtual sun.security.x509.CertificateExtensions.getAllExtensions:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 8
            goto 36
      StackMap locals: java.security.cert.Certificate java.lang.StringBuilder sun.security.x509.X509CertImpl sun.security.x509.X509CertInfo sun.security.x509.CertificateExtensions java.lang.StringBuilder int top java.util.Iterator
      StackMap stack:
        28: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.Extension
            astore 7 /* certExt */
        start local 7 // java.security.cert.Extension certExt
        29: .line 486
            iload 6 /* isFirst */
            ifeq 32
        30: .line 487
            iconst_0
            istore 6 /* isFirst */
        31: .line 488
            goto 33
        32: .line 489
      StackMap locals: java.security.cert.Certificate java.lang.StringBuilder sun.security.x509.X509CertImpl sun.security.x509.X509CertInfo sun.security.x509.CertificateExtensions java.lang.StringBuilder int java.security.cert.Extension java.util.Iterator
      StackMap stack:
            aload 5 /* extBuilder */
            ldc ",\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        33: .line 491
      StackMap locals:
      StackMap stack:
            aload 5 /* extBuilder */
            new java.lang.StringBuilder
            dup
            ldc "{\n"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        34: .line 492
            aload 7 /* certExt */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n}"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        35: .line 491
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 7 // java.security.cert.Extension certExt
        36: .line 485
      StackMap locals: java.security.cert.Certificate java.lang.StringBuilder sun.security.x509.X509CertImpl sun.security.x509.X509CertInfo sun.security.x509.CertificateExtensions java.lang.StringBuilder int top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 28
        37: .line 494
            bipush 9
            anewarray java.lang.Object
            dup
            iconst_0
        38: .line 495
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getVersion:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
        39: .line 497
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getSerialNumber:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.toByteArray:()[B
        40: .line 496
            invokestatic sun.security.ssl.Utilities.toHexString:([B)Ljava/lang/String;
            aastore
            dup
            iconst_2
        41: .line 498
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getSigAlgName:()Ljava/lang/String;
            aastore
            dup
            iconst_3
        42: .line 499
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
            aastore
            dup
            iconst_4
        43: .line 500
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.dateFormat:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.text.SimpleDateFormat
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getNotBefore:()Ljava/util/Date;
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            iconst_5
        44: .line 501
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.dateFormat:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast java.text.SimpleDateFormat
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getNotAfter:()Ljava/util/Date;
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            aastore
            dup
            bipush 6
        45: .line 502
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
            aastore
            dup
            bipush 7
        46: .line 503
            aload 2 /* x509 */
            invokevirtual sun.security.x509.X509CertImpl.getPublicKey:()Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
            aastore
            dup
            bipush 8
        47: .line 504
            aload 5 /* extBuilder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            aastore
        48: .line 494
            astore 7 /* certFields */
        start local 7 // java.lang.Object[] certFields
        49: .line 506
            aload 1 /* builder */
        50: .line 507
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.extendedCertFormart:Ljava/text/MessageFormat;
            aload 7 /* certFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
        51: .line 506
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 7 // java.lang.Object[] certFields
        end local 6 // boolean isFirst
        end local 5 // java.lang.StringBuilder extBuilder
        end local 4 // sun.security.x509.CertificateExtensions certExts
        end local 3 // sun.security.x509.X509CertInfo certInfo
        end local 2 // sun.security.x509.X509CertImpl x509
        52: .line 509
            goto 54
      StackMap locals: java.security.cert.Certificate java.lang.StringBuilder
      StackMap stack: java.lang.Exception
        53: pop
        54: .line 513
      StackMap locals:
      StackMap stack:
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
        55: .line 514
            ldc "certificate"
            aastore
            dup
            iconst_1
        56: .line 515
            aload 1 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aastore
        57: .line 513
            astore 2 /* fields */
        start local 2 // java.lang.Object[] fields
        58: .line 518
            getstatic sun.security.ssl.SSLLogger$SSLSimpleFormatter.keyObjectFormat:Ljava/text/MessageFormat;
            aload 2 /* fields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            areturn
        end local 2 // java.lang.Object[] fields
        end local 1 // java.lang.StringBuilder builder
        end local 0 // java.security.cert.Certificate certificate
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   59     0  certificate  Ljava/security/cert/Certificate;
            3   59     1      builder  Ljava/lang/StringBuilder;
            5   52     2         x509  Lsun/security/x509/X509CertImpl;
            7   52     3     certInfo  Lsun/security/x509/X509CertInfo;
            9   52     4     certExts  Lsun/security/x509/CertificateExtensions;
           21   24     5   certFields  [Ljava/lang/Object;
           26   52     5   extBuilder  Ljava/lang/StringBuilder;
           27   52     6      isFirst  Z
           29   36     7      certExt  Ljava/security/cert/Extension;
           49   52     7   certFields  [Ljava/lang/Object;
           58   59     2       fields  [Ljava/lang/Object;
      Exception table:
        from    to  target  type
           3    52      53  Class java.lang.Exception
    MethodParameters:
             Name  Flags
      certificate  

  private static java.lang.String formatByteArrayInputStream(java.io.ByteArrayInputStream);
    descriptor: (Ljava/io/ByteArrayInputStream;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // java.io.ByteArrayInputStream bytes
         0: .line 523
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 1 /* builder */
        start local 1 // java.lang.StringBuilder builder
         1: .line 525
            aconst_null
            astore 2
            aconst_null
            astore 3
         2: new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 4 /* bytesOut */
        start local 4 // java.io.ByteArrayOutputStream bytesOut
         3: .line 526
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 5 /* hexEncoder */
        start local 5 // sun.misc.HexDumpEncoder hexEncoder
         4: .line 527
            aload 5 /* hexEncoder */
            aload 0 /* bytes */
            aload 4 /* bytesOut */
            invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:(Ljava/io/InputStream;Ljava/io/OutputStream;)V
         5: .line 529
            aload 1 /* builder */
            aload 4 /* bytesOut */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 5 // sun.misc.HexDumpEncoder hexEncoder
         6: .line 530
            aload 4 /* bytesOut */
            ifnull 13
            aload 4 /* bytesOut */
            invokevirtual java.io.ByteArrayOutputStream.close:()V
            goto 13
      StackMap locals: java.io.ByteArrayInputStream java.lang.StringBuilder java.lang.Throwable java.lang.Throwable java.io.ByteArrayOutputStream
      StackMap stack: java.lang.Throwable
         7: astore 2
            aload 4 /* bytesOut */
            ifnull 8
            aload 4 /* bytesOut */
            invokevirtual java.io.ByteArrayOutputStream.close:()V
        end local 4 // java.io.ByteArrayOutputStream bytesOut
      StackMap locals:
      StackMap stack:
         8: aload 2
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
         9: astore 3
            aload 2
            ifnonnull 10
            aload 3
            astore 2
            goto 11
      StackMap locals:
      StackMap stack:
        10: aload 2
            aload 3
            if_acmpeq 11
            aload 2
            aload 3
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        11: aload 2
            athrow
      StackMap locals: java.io.ByteArrayInputStream java.lang.StringBuilder
      StackMap stack: java.io.IOException
        12: pop
        13: .line 534
      StackMap locals:
      StackMap stack:
            aload 1 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder builder
        end local 0 // java.io.ByteArrayInputStream bytes
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0       bytes  Ljava/io/ByteArrayInputStream;
            1   14     1     builder  Ljava/lang/StringBuilder;
            3    8     4    bytesOut  Ljava/io/ByteArrayOutputStream;
            4    6     5  hexEncoder  Lsun/misc/HexDumpEncoder;
      Exception table:
        from    to  target  type
           3     6       7  any
           2     9       9  any
           1    12      12  Class java.io.IOException
    MethodParameters:
       Name  Flags
      bytes  

  private static java.lang.String formatByteBuffer(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // java.nio.ByteBuffer byteBuffer
         0: .line 538
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 1 /* builder */
        start local 1 // java.lang.StringBuilder builder
         1: .line 539
            aconst_null
            astore 2
            aconst_null
            astore 3
         2: new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 4 /* bytesOut */
        start local 4 // java.io.ByteArrayOutputStream bytesOut
         3: .line 540
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 5 /* hexEncoder */
        start local 5 // sun.misc.HexDumpEncoder hexEncoder
         4: .line 541
            aload 5 /* hexEncoder */
            aload 0 /* byteBuffer */
            invokevirtual java.nio.ByteBuffer.duplicate:()Ljava/nio/ByteBuffer;
            aload 4 /* bytesOut */
            invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:(Ljava/nio/ByteBuffer;Ljava/io/OutputStream;)V
         5: .line 542
            aload 1 /* builder */
            aload 4 /* bytesOut */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 5 // sun.misc.HexDumpEncoder hexEncoder
         6: .line 543
            aload 4 /* bytesOut */
            ifnull 13
            aload 4 /* bytesOut */
            invokevirtual java.io.ByteArrayOutputStream.close:()V
            goto 13
      StackMap locals: java.nio.ByteBuffer java.lang.StringBuilder java.lang.Throwable java.lang.Throwable java.io.ByteArrayOutputStream
      StackMap stack: java.lang.Throwable
         7: astore 2
            aload 4 /* bytesOut */
            ifnull 8
            aload 4 /* bytesOut */
            invokevirtual java.io.ByteArrayOutputStream.close:()V
        end local 4 // java.io.ByteArrayOutputStream bytesOut
      StackMap locals:
      StackMap stack:
         8: aload 2
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
         9: astore 3
            aload 2
            ifnonnull 10
            aload 3
            astore 2
            goto 11
      StackMap locals:
      StackMap stack:
        10: aload 2
            aload 3
            if_acmpeq 11
            aload 2
            aload 3
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        11: aload 2
            athrow
      StackMap locals: java.nio.ByteBuffer java.lang.StringBuilder
      StackMap stack: java.io.IOException
        12: pop
        13: .line 547
      StackMap locals:
      StackMap stack:
            aload 1 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder builder
        end local 0 // java.nio.ByteBuffer byteBuffer
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0  byteBuffer  Ljava/nio/ByteBuffer;
            1   14     1     builder  Ljava/lang/StringBuilder;
            3    8     4    bytesOut  Ljava/io/ByteArrayOutputStream;
            4    6     5  hexEncoder  Lsun/misc/HexDumpEncoder;
      Exception table:
        from    to  target  type
           3     6       7  any
           2     9       9  any
           1    12      12  Class java.io.IOException
    MethodParameters:
            Name  Flags
      byteBuffer  

  private static java.lang.String formatMapEntry(java.util.Map$Entry<java.lang.String, ?>);
    descriptor: (Ljava/util/Map$Entry;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=10, args_size=1
        start local 0 // java.util.Map$Entry entry
         0: .line 551
            aload 0 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 1 /* key */
        start local 1 // java.lang.String key
         1: .line 552
            aload 0 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            astore 2 /* value */
        start local 2 // java.lang.Object value
         2: .line 555
            aload 2 /* value */
            instanceof java.lang.String
            ifeq 5
         3: .line 557
            new java.lang.StringBuilder
            dup
            ldc "\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\": \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* value */
            checkcast java.lang.String
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* formatted */
        start local 3 // java.lang.String formatted
         4: .line 558
            goto 33
        end local 3 // java.lang.String formatted
      StackMap locals: java.lang.String java.lang.Object
      StackMap stack:
         5: aload 2 /* value */
            instanceof java.lang.String[]
            ifeq 20
         6: .line 563
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 4 /* builder */
        start local 4 // java.lang.StringBuilder builder
         7: .line 564
            aload 2 /* value */
            checkcast java.lang.String[]
            astore 5 /* strings */
        start local 5 // java.lang.String[] strings
         8: .line 565
            aload 4 /* builder */
            new java.lang.StringBuilder
            dup
            ldc "\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)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 java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         9: .line 566
            aload 5 /* strings */
            dup
            astore 9
            arraylength
            istore 8
            iconst_0
            istore 7
            goto 16
      StackMap locals: java.util.Map$Entry java.lang.String java.lang.Object top java.lang.StringBuilder java.lang.String[] top int int java.lang.String[]
      StackMap stack:
        10: aload 9
            iload 7
            aaload
            astore 6 /* string */
        start local 6 // java.lang.String string
        11: .line 567
            aload 4 /* builder */
            new java.lang.StringBuilder
            dup
            ldc "      \""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* string */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        12: .line 568
            aload 6 /* string */
            aload 5 /* strings */
            aload 5 /* strings */
            arraylength
            iconst_1
            isub
            aaload
            if_acmpeq 14
        13: .line 569
            aload 4 /* builder */
            ldc ","
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        14: .line 571
      StackMap locals: java.util.Map$Entry java.lang.String java.lang.Object top java.lang.StringBuilder java.lang.String[] java.lang.String int int java.lang.String[]
      StackMap stack:
            aload 4 /* builder */
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 6 // java.lang.String string
        15: .line 566
            iinc 7 1
      StackMap locals: java.util.Map$Entry java.lang.String java.lang.Object top java.lang.StringBuilder java.lang.String[] top int int java.lang.String[]
      StackMap stack:
        16: iload 7
            iload 8
            if_icmplt 10
        17: .line 573
            aload 4 /* builder */
            ldc "      ]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        18: .line 575
            aload 4 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* formatted */
        end local 5 // java.lang.String[] strings
        end local 4 // java.lang.StringBuilder builder
        start local 3 // java.lang.String formatted
        19: .line 576
            goto 33
        end local 3 // java.lang.String formatted
      StackMap locals: java.util.Map$Entry java.lang.String java.lang.Object
      StackMap stack:
        20: aload 2 /* value */
            instanceof byte[]
            ifeq 25
        21: .line 577
            new java.lang.StringBuilder
            dup
            ldc "\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\": \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        22: .line 578
            aload 2 /* value */
            checkcast byte[]
            invokestatic sun.security.ssl.Utilities.toHexString:([B)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        23: .line 577
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* formatted */
        start local 3 // java.lang.String formatted
        24: .line 579
            goto 33
        end local 3 // java.lang.String formatted
      StackMap locals:
      StackMap stack:
        25: aload 2 /* value */
            instanceof java.lang.Byte
            ifeq 30
        26: .line 580
            new java.lang.StringBuilder
            dup
            ldc "\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\": \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        27: .line 581
            aload 2 /* value */
            checkcast java.lang.Byte
            invokevirtual java.lang.Byte.byteValue:()B
            invokestatic sun.security.ssl.Utilities.toHexString:(B)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        28: .line 580
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* formatted */
        start local 3 // java.lang.String formatted
        29: .line 582
            goto 33
        end local 3 // java.lang.String formatted
        30: .line 583
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        31: .line 584
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* value */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        32: .line 583
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* formatted */
        start local 3 // java.lang.String formatted
        33: .line 587
      StackMap locals: java.lang.String
      StackMap stack:
            aload 3 /* formatted */
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            areturn
        end local 3 // java.lang.String formatted
        end local 2 // java.lang.Object value
        end local 1 // java.lang.String key
        end local 0 // java.util.Map$Entry entry
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   34     0      entry  Ljava/util/Map$Entry<Ljava/lang/String;*>;
            1   34     1        key  Ljava/lang/String;
            2   34     2      value  Ljava/lang/Object;
            4    5     3  formatted  Ljava/lang/String;
           19   20     3  formatted  Ljava/lang/String;
           24   25     3  formatted  Ljava/lang/String;
           29   30     3  formatted  Ljava/lang/String;
           33   34     3  formatted  Ljava/lang/String;
            7   19     4    builder  Ljava/lang/StringBuilder;
            8   19     5    strings  [Ljava/lang/String;
           11   15     6     string  Ljava/lang/String;
    Signature: (Ljava/util/Map$Entry<Ljava/lang/String;*>;)Ljava/lang/String;
    MethodParameters:
       Name  Flags
      entry  

  private static java.lang.String formatObject(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.lang.Object obj
         0: .line 591
            aload 0 /* obj */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            areturn
        end local 0 // java.lang.Object obj
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0   obj  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      obj   
}
SourceFile: "SSLLogger.java"
NestHost: sun.security.ssl.SSLLogger
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map
  private SSLConsoleLogger = sun.security.ssl.SSLLogger$SSLConsoleLogger of sun.security.ssl.SSLLogger
  private SSLSimpleFormatter = sun.security.ssl.SSLLogger$SSLSimpleFormatter of sun.security.ssl.SSLLogger
  sun.security.ssl.SSLLogger$SSLSimpleFormatter$1