final class sun.security.ssl.CertificateStatus$CertificateStatusMessage extends sun.security.ssl.SSLHandshake$HandshakeMessage
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.CertificateStatus$CertificateStatusMessage
  super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
  final sun.security.ssl.CertStatusExtension$CertStatusRequestType statusType;
    descriptor: Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
    flags: (0x0010) ACC_FINAL

  int encodedResponsesLen;
    descriptor: I
    flags: (0x0000) 

  int messageLength;
    descriptor: I
    flags: (0x0000) 

  final java.util.List<byte[]> encodedResponses;
    descriptor: Ljava/util/List;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/List<[B>;

  void <init>(sun.security.ssl.HandshakeContext);
    descriptor: (Lsun/security/ssl/HandshakeContext;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=10, args_size=2
        start local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
         0: .line 93
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 88
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
         2: .line 89
            aload 0 /* this */
            iconst_m1
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:I
         3: .line 90
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
         4: .line 96
            aload 1 /* handshakeContext */
            checkcast sun.security.ssl.ServerHandshakeContext
         5: .line 95
            astore 2 /* shc */
        start local 2 // sun.security.ssl.ServerHandshakeContext shc
         6: .line 101
            aload 2 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
         7: .line 100
            astore 3 /* stapleParams */
        start local 3 // sun.security.ssl.StatusResponseManager$StaplingParameters stapleParams
         8: .line 102
            aload 3 /* stapleParams */
            ifnonnull 12
         9: .line 103
            new java.lang.IllegalArgumentException
            dup
        10: .line 104
            ldc "Unexpected null stapling parameters"
        11: .line 103
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 108
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeContext sun.security.ssl.ServerHandshakeContext sun.security.ssl.StatusResponseManager$StaplingParameters
      StackMap stack:
            aload 2 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getLocalCertificates:()[Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate[]
        13: .line 107
            astore 4 /* certChain */
        start local 4 // java.security.cert.X509Certificate[] certChain
        14: .line 109
            aload 4 /* certChain */
            ifnonnull 18
        15: .line 110
            new java.lang.IllegalArgumentException
            dup
        16: .line 111
            ldc "Unexpected null certificate chain"
        17: .line 110
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 116
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            aload 0 /* this */
            aload 3 /* stapleParams */
            getfield sun.security.ssl.StatusResponseManager$StaplingParameters.statReqType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
        19: .line 117
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 26
        20: .line 119
            aload 3 /* stapleParams */
            getfield sun.security.ssl.StatusResponseManager$StaplingParameters.responseMap:Ljava/util/Map;
            aload 4 /* certChain */
            iconst_0
            aaload
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast byte[]
            astore 5 /* resp */
        start local 5 // byte[] resp
        21: .line 120
            aload 5 /* resp */
            ifnonnull 23
        22: .line 124
            iconst_0
            newarray 8
            astore 5 /* resp */
        23: .line 126
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
            aload 5 /* resp */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        24: .line 127
            aload 0 /* this */
            dup
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
            aload 5 /* resp */
            arraylength
            iconst_3
            iadd
            iadd
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
        end local 5 // byte[] resp
        25: .line 128
            goto 40
      StackMap locals:
      StackMap stack:
        26: aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 37
        27: .line 129
            aload 4 /* certChain */
            dup
            astore 8
            arraylength
            istore 7
            iconst_0
            istore 6
            goto 35
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeContext sun.security.ssl.ServerHandshakeContext sun.security.ssl.StatusResponseManager$StaplingParameters java.security.cert.X509Certificate[] top int int java.security.cert.X509Certificate[]
      StackMap stack:
        28: aload 8
            iload 6
            aaload
            astore 5 /* cert */
        start local 5 // java.security.cert.X509Certificate cert
        29: .line 130
            aload 3 /* stapleParams */
            getfield sun.security.ssl.StatusResponseManager$StaplingParameters.responseMap:Ljava/util/Map;
            aload 5 /* cert */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast byte[]
            astore 9 /* resp */
        start local 9 // byte[] resp
        30: .line 131
            aload 9 /* resp */
            ifnonnull 32
        31: .line 132
            iconst_0
            newarray 8
            astore 9 /* resp */
        32: .line 134
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeContext sun.security.ssl.ServerHandshakeContext sun.security.ssl.StatusResponseManager$StaplingParameters java.security.cert.X509Certificate[] java.security.cert.X509Certificate int int java.security.cert.X509Certificate[] byte[]
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
            aload 9 /* resp */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        33: .line 135
            aload 0 /* this */
            dup
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
            aload 9 /* resp */
            arraylength
            iconst_3
            iadd
            iadd
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
        end local 9 // byte[] resp
        end local 5 // java.security.cert.X509Certificate cert
        34: .line 129
            iinc 6 1
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeContext sun.security.ssl.ServerHandshakeContext sun.security.ssl.StatusResponseManager$StaplingParameters java.security.cert.X509Certificate[] top int int java.security.cert.X509Certificate[]
      StackMap stack:
        35: iload 6
            iload 7
            if_icmplt 28
        36: .line 137
            goto 40
        37: .line 138
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeContext sun.security.ssl.ServerHandshakeContext sun.security.ssl.StatusResponseManager$StaplingParameters java.security.cert.X509Certificate[]
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
        38: .line 139
            new java.lang.StringBuilder
            dup
            ldc "Unsupported StatusResponseType: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        39: .line 138
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        40: .line 142
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:()I
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:I
        41: .line 143
            return
        end local 4 // java.security.cert.X509Certificate[] certChain
        end local 3 // sun.security.ssl.StatusResponseManager$StaplingParameters stapleParams
        end local 2 // sun.security.ssl.ServerHandshakeContext shc
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   42     0              this  Lsun/security/ssl/CertificateStatus$CertificateStatusMessage;
            0   42     1  handshakeContext  Lsun/security/ssl/HandshakeContext;
            6   42     2               shc  Lsun/security/ssl/ServerHandshakeContext;
            8   42     3      stapleParams  Lsun/security/ssl/StatusResponseManager$StaplingParameters;
           14   42     4         certChain  [Ljava/security/cert/X509Certificate;
           21   25     5              resp  [B
           29   34     5              cert  Ljava/security/cert/X509Certificate;
           30   34     9              resp  [B
    MethodParameters:
                  Name  Flags
      handshakeContext  

  void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
    descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
        start local 2 // java.nio.ByteBuffer m
         0: .line 147
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 88
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
         2: .line 89
            aload 0 /* this */
            iconst_m1
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:I
         3: .line 90
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
         4: .line 149
            aload 0 /* this */
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getInt8:(Ljava/nio/ByteBuffer;)I
            i2b
            invokestatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.valueOf:(B)Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
         5: .line 150
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 15
         6: .line 151
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getBytes24:(Ljava/nio/ByteBuffer;)[B
            astore 3 /* respDER */
        start local 3 // byte[] respDER
         7: .line 153
            aload 3 /* respDER */
            arraylength
            ifle 11
         8: .line 154
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
            aload 3 /* respDER */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         9: .line 155
            aload 0 /* this */
            iconst_3
            aload 3 /* respDER */
            arraylength
            iadd
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
        10: .line 156
            goto 32
        11: .line 157
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer byte[]
      StackMap stack:
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
        12: .line 158
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        13: .line 159
            ldc "Zero-length OCSP Response"
        14: .line 157
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        end local 3 // byte[] respDER
        15: .line 161
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 28
        16: .line 162
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getInt24:(Ljava/nio/ByteBuffer;)I
            istore 3 /* respListLen */
        start local 3 // int respListLen
        17: .line 163
            aload 0 /* this */
            iload 3 /* respListLen */
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
        18: .line 169
            goto 22
        19: .line 170
      StackMap locals: int
      StackMap stack:
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getBytes24:(Ljava/nio/ByteBuffer;)[B
            astore 4 /* respDER */
        start local 4 // byte[] respDER
        20: .line 171
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
            aload 4 /* respDER */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        21: .line 172
            iload 3 /* respListLen */
            aload 4 /* respDER */
            arraylength
            iconst_3
            iadd
            isub
            istore 3 /* respListLen */
        end local 4 // byte[] respDER
        22: .line 169
      StackMap locals:
      StackMap stack:
            iload 3 /* respListLen */
            ifgt 19
        23: .line 175
            iload 3 /* respListLen */
            ifeq 32
        24: .line 176
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
        25: .line 177
            getstatic sun.security.ssl.Alert.INTERNAL_ERROR:Lsun/security/ssl/Alert;
        26: .line 178
            ldc "Bad OCSP response list length"
        27: .line 176
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        end local 3 // int respListLen
        28: .line 181
      StackMap locals:
      StackMap stack:
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
        29: .line 182
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        30: .line 183
            new java.lang.StringBuilder
            dup
            ldc "Unsupported StatusResponseType: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        31: .line 181
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        32: .line 185
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:()I
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:I
        33: .line 186
            return
        end local 2 // java.nio.ByteBuffer m
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   34     0              this  Lsun/security/ssl/CertificateStatus$CertificateStatusMessage;
            0   34     1  handshakeContext  Lsun/security/ssl/HandshakeContext;
            0   34     2                 m  Ljava/nio/ByteBuffer;
            7   15     3           respDER  [B
           17   28     3       respListLen  I
           20   22     4           respDER  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                  Name  Flags
      handshakeContext  
      m                 

  public sun.security.ssl.SSLHandshake handshakeType();
    descriptor: ()Lsun/security/ssl/SSLHandshake;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
         0: .line 190
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_STATUS:Lsun/security/ssl/SSLHandshake;
            areturn
        end local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/CertificateStatus$CertificateStatusMessage;

  public int messageLength();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
         0: .line 195
            iconst_1
            istore 1 /* len */
        start local 1 // int len
         1: .line 197
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:I
            iconst_m1
            if_icmpne 8
         2: .line 198
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 5
         3: .line 199
            iload 1 /* len */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
            iadd
            istore 1 /* len */
         4: .line 200
            goto 7
      StackMap locals: int
      StackMap stack:
         5: aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 7
         6: .line 201
            iload 1 /* len */
            iconst_3
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
            iadd
            iadd
            istore 1 /* len */
         7: .line 203
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* len */
            putfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:I
         8: .line 206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.messageLength:I
            ireturn
        end local 1 // int len
        end local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lsun/security/ssl/CertificateStatus$CertificateStatusMessage;
            1    9     1   len  I

  public void send(sun.security.ssl.HandshakeOutStream);
    descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
        start local 1 // sun.security.ssl.HandshakeOutStream s
         0: .line 211
            aload 1 /* s */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
            invokevirtual sun.security.ssl.HandshakeOutStream.putInt8:(I)V
         1: .line 212
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 4
         2: .line 213
            aload 1 /* s */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast byte[]
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes24:([B)V
         3: .line 214
            goto 17
      StackMap locals:
      StackMap stack:
         4: aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            if_acmpne 14
         5: .line 215
            aload 1 /* s */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponsesLen:I
            invokevirtual sun.security.ssl.HandshakeOutStream.putInt24:(I)V
         6: .line 216
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 12
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeOutStream top java.util.Iterator
      StackMap stack:
         7: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast byte[]
            astore 2 /* respBytes */
        start local 2 // byte[] respBytes
         8: .line 217
            aload 2 /* respBytes */
            ifnull 11
         9: .line 218
            aload 1 /* s */
            aload 2 /* respBytes */
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes24:([B)V
        10: .line 219
            goto 12
        11: .line 220
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeOutStream byte[] java.util.Iterator
      StackMap stack:
            aload 1 /* s */
            aconst_null
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes24:([B)V
        end local 2 // byte[] respBytes
        12: .line 216
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeOutStream top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        13: .line 223
            goto 17
        14: .line 226
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage sun.security.ssl.HandshakeOutStream
      StackMap stack:
            new javax.net.ssl.SSLHandshakeException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported status_type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        15: .line 227
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 226
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 229
      StackMap locals:
      StackMap stack:
            return
        end local 1 // sun.security.ssl.HandshakeOutStream s
        end local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   18     0       this  Lsun/security/ssl/CertificateStatus$CertificateStatusMessage;
            0   18     1          s  Lsun/security/ssl/HandshakeOutStream;
            8   12     2  respBytes  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      s     

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
         0: .line 233
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 236
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.encodedResponses:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 12
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage java.lang.StringBuilder top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast byte[]
            astore 2 /* respDER */
        start local 2 // byte[] respDER
         3: .line 237
            aload 2 /* respDER */
            arraylength
            ifle 11
         4: .line 239
            new sun.security.provider.certpath.OCSPResponse
            dup
            aload 2 /* respDER */
            invokespecial sun.security.provider.certpath.OCSPResponse.<init>:([B)V
            astore 4 /* oResp */
        start local 4 // sun.security.provider.certpath.OCSPResponse oResp
         5: .line 240
            aload 1 /* sb */
            aload 4 /* oResp */
            invokevirtual sun.security.provider.certpath.OCSPResponse.toString:()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;
            pop
        end local 4 // sun.security.provider.certpath.OCSPResponse oResp
         6: .line 241
            goto 12
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage java.lang.StringBuilder byte[] java.util.Iterator
      StackMap stack: java.io.IOException
         7: astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
         8: .line 242
            aload 1 /* sb */
            ldc "OCSP Response Exception: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         9: .line 243
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 4 // java.io.IOException ioe
        10: .line 245
            goto 12
        11: .line 246
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            ldc "<Zero-length entry>\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 2 // byte[] respDER
        12: .line 236
      StackMap locals: sun.security.ssl.CertificateStatus$CertificateStatusMessage java.lang.StringBuilder top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        13: .line 250
            new java.text.MessageFormat
            dup
        14: .line 251
            ldc "\"CertificateStatus\": '{'\n  \"type\"                : \"{0}\",\n  \"responses \"          : [\n{1}\n  ]\n'}'"
        15: .line 255
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
        16: .line 250
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 2 /* messageFormat */
        start local 2 // java.text.MessageFormat messageFormat
        17: .line 256
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
        18: .line 257
            aload 0 /* this */
            getfield sun.security.ssl.CertificateStatus$CertificateStatusMessage.statusType:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.name:Ljava/lang/String;
            aastore
            dup
            iconst_1
        19: .line 258
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            aastore
        20: .line 256
            astore 3 /* messageFields */
        start local 3 // java.lang.Object[] messageFields
        21: .line 261
            aload 2 /* messageFormat */
            aload 3 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 3 // java.lang.Object[] messageFields
        end local 2 // java.text.MessageFormat messageFormat
        end local 1 // java.lang.StringBuilder sb
        end local 0 // sun.security.ssl.CertificateStatus$CertificateStatusMessage this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   22     0           this  Lsun/security/ssl/CertificateStatus$CertificateStatusMessage;
            1   22     1             sb  Ljava/lang/StringBuilder;
            3   12     2        respDER  [B
            5    6     4          oResp  Lsun/security/provider/certpath/OCSPResponse;
            8   10     4            ioe  Ljava/io/IOException;
           17   22     2  messageFormat  Ljava/text/MessageFormat;
           21   22     3  messageFields  [Ljava/lang/Object;
      Exception table:
        from    to  target  type
           4     6       7  Class java.io.IOException
}
SourceFile: "CertificateStatus.java"
NestHost: sun.security.ssl.CertificateStatus
InnerClasses:
  final CertStatusRequestType = sun.security.ssl.CertStatusExtension$CertStatusRequestType of sun.security.ssl.CertStatusExtension
  final CertificateStatusMessage = sun.security.ssl.CertificateStatus$CertificateStatusMessage of sun.security.ssl.CertificateStatus
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake
  final StaplingParameters = sun.security.ssl.StatusResponseManager$StaplingParameters of sun.security.ssl.StatusResponseManager