final class sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec implements sun.security.ssl.SSLExtension$SSLExtensionSpec
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec
  super_class: java.lang.Object
{
  static final sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec DEFAULT;
    descriptor: Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  final sun.security.ssl.CertStatusExtension$CertStatusRequest[] certStatusRequests;
    descriptor: [Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
    flags: (0x0010) ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=0, args_size=0
         0: .line 769
            new sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec
            dup
            iconst_1
            anewarray sun.security.ssl.CertStatusExtension$CertStatusRequest
            dup
            iconst_0
         1: .line 770
            getstatic sun.security.ssl.CertStatusExtension$OCSPStatusRequest.EMPTY_OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$OCSPStatusRequest;
            aastore
         2: .line 769
            invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.<init>:([Lsun/security/ssl/CertStatusExtension$CertStatusRequest;)V
         3: .line 768
            putstatic sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.DEFAULT:Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
         4: .line 770
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(sun.security.ssl.CertStatusExtension$CertStatusRequest[]);
    descriptor: ([Lsun/security/ssl/CertStatusExtension$CertStatusRequest;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
        start local 1 // sun.security.ssl.CertStatusExtension$CertStatusRequest[] certStatusRequests
         0: .line 774
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 775
            aload 0 /* this */
            aload 1 /* certStatusRequests */
            putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
         2: .line 776
            return
        end local 1 // sun.security.ssl.CertStatusExtension$CertStatusRequest[] certStatusRequests
        end local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    3     0                this  Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
            0    3     1  certStatusRequests  [Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
    MethodParameters:
                    Name  Flags
      certStatusRequests  

  private void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
    descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=9, args_size=3
        start local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
        start local 1 // sun.security.ssl.HandshakeContext hc
        start local 2 // java.nio.ByteBuffer message
         0: .line 778
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 781
            aload 2 /* message */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            ifne 4
         2: .line 783
            aload 0 /* this */
            iconst_0
            anewarray sun.security.ssl.CertStatusExtension$CertStatusRequest
            putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
         3: .line 784
            return
         4: .line 787
      StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec sun.security.ssl.HandshakeContext java.nio.ByteBuffer
      StackMap stack:
            aload 2 /* message */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_5
            if_icmpge 10
         5: .line 790
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
         6: .line 791
            new javax.net.ssl.SSLProtocolException
            dup
         7: .line 792
            ldc "Invalid status_request_v2 extension: insufficient data"
         8: .line 791
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
         9: .line 790
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        10: .line 795
      StackMap locals:
      StackMap stack:
            aload 2 /* message */
            invokestatic sun.security.ssl.Record.getInt16:(Ljava/nio/ByteBuffer;)I
            istore 3 /* listLen */
        start local 3 // int listLen
        11: .line 796
            iload 3 /* listLen */
            ifgt 19
        12: .line 797
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
        13: .line 798
            new javax.net.ssl.SSLProtocolException
            dup
        14: .line 799
            new java.lang.StringBuilder
            dup
            ldc "certificate_status_req_list length must be positive (received length: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        15: .line 800
            iload 3 /* listLen */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        16: .line 799
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 798
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
        18: .line 797
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        19: .line 803
      StackMap locals: int
      StackMap stack:
            iload 3 /* listLen */
            istore 4 /* remaining */
        start local 4 // int remaining
        20: .line 804
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 5 /* statusRequests */
        start local 5 // java.util.List statusRequests
        21: .line 805
            goto 60
        22: .line 806
      StackMap locals: int java.util.List
      StackMap stack:
            aload 2 /* message */
            invokestatic sun.security.ssl.Record.getInt8:(Ljava/nio/ByteBuffer;)I
            i2b
            istore 6 /* statusType */
        start local 6 // byte statusType
        23: .line 807
            aload 2 /* message */
            invokestatic sun.security.ssl.Record.getInt16:(Ljava/nio/ByteBuffer;)I
            istore 7 /* requestLen */
        start local 7 // int requestLen
        24: .line 809
            aload 2 /* message */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iload 7 /* requestLen */
            if_icmpge 34
        25: .line 810
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
        26: .line 811
            getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
        27: .line 812
            new javax.net.ssl.SSLProtocolException
            dup
        28: .line 813
            new java.lang.StringBuilder
            dup
            ldc "Invalid status_request_v2 extension: insufficient data (request_length="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        29: .line 814
            iload 7 /* requestLen */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        30: .line 815
            ldc ", remining="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* message */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        31: .line 813
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        32: .line 812
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
        33: .line 810
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        34: .line 818
      StackMap locals: int int
      StackMap stack:
            iload 7 /* requestLen */
            newarray 8
            astore 8 /* encoded */
        start local 8 // byte[] encoded
        35: .line 819
            aload 8 /* encoded */
            arraylength
            ifeq 37
        36: .line 820
            aload 2 /* message */
            aload 8 /* encoded */
            invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
            pop
        37: .line 822
      StackMap locals: byte[]
      StackMap stack:
            iinc 4 /* remaining */ -3
        38: .line 823
            iload 4 /* remaining */
            iload 7 /* requestLen */
            isub
            istore 4 /* remaining */
        39: .line 825
            iload 6 /* statusType */
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
            if_icmpeq 41
        40: .line 826
            iload 6 /* statusType */
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
            if_icmpne 52
        41: .line 827
      StackMap locals:
      StackMap stack:
            aload 8 /* encoded */
            arraylength
            iconst_4
            if_icmpge 48
        42: .line 830
            aload 1 /* hc */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
        43: .line 831
            getstatic sun.security.ssl.Alert.DECODE_ERROR:Lsun/security/ssl/Alert;
        44: .line 832
            new javax.net.ssl.SSLProtocolException
            dup
        45: .line 833
            ldc "Invalid status_request_v2 extension: insufficient data"
        46: .line 832
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
        47: .line 830
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        48: .line 836
      StackMap locals:
      StackMap stack:
            aload 5 /* statusRequests */
        49: .line 837
            new sun.security.ssl.CertStatusExtension$OCSPStatusRequest
            dup
            iload 6 /* statusType */
            aload 8 /* encoded */
            invokespecial sun.security.ssl.CertStatusExtension$OCSPStatusRequest.<init>:(B[B)V
        50: .line 836
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        51: .line 838
            goto 60
        52: .line 839
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 57
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 57
        53: .line 841
            new java.lang.StringBuilder
            dup
            ldc "Unknown certificate status request (status type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        54: .line 842
            iload 6 /* statusType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        55: .line 841
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        56: .line 840
            invokestatic sun.security.ssl.SSLLogger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
        57: .line 844
      StackMap locals:
      StackMap stack:
            aload 5 /* statusRequests */
        58: .line 845
            new sun.security.ssl.CertStatusExtension$CertStatusRequest
            dup
            iload 6 /* statusType */
            aload 8 /* encoded */
            invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequest.<init>:(B[B)V
        59: .line 844
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // byte[] encoded
        end local 7 // int requestLen
        end local 6 // byte statusType
        60: .line 805
      StackMap locals:
      StackMap stack:
            iload 4 /* remaining */
            ifgt 22
        61: .line 849
            aload 0 /* this */
        62: .line 850
            aload 5 /* statusRequests */
            iconst_0
            anewarray sun.security.ssl.CertStatusExtension$CertStatusRequest
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.ssl.CertStatusExtension$CertStatusRequest[]
        63: .line 849
            putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
        64: .line 851
            return
        end local 5 // java.util.List statusRequests
        end local 4 // int remaining
        end local 3 // int listLen
        end local 2 // java.nio.ByteBuffer message
        end local 1 // sun.security.ssl.HandshakeContext hc
        end local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   65     0            this  Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
            0   65     1              hc  Lsun/security/ssl/HandshakeContext;
            0   65     2         message  Ljava/nio/ByteBuffer;
           11   65     3         listLen  I
           20   65     4       remaining  I
           21   65     5  statusRequests  Ljava/util/List<Lsun/security/ssl/CertStatusExtension$CertStatusRequest;>;
           23   60     6      statusType  B
           24   60     7      requestLen  I
           35   60     8         encoded  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      hc       
      message  

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=9, args_size=1
        start local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
         0: .line 855
            aload 0 /* this */
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
            ifnull 1
            aload 0 /* this */
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
            arraylength
            ifne 2
         1: .line 856
      StackMap locals:
      StackMap stack:
            ldc "<empty>"
            areturn
         2: .line 858
      StackMap locals:
      StackMap stack:
            new java.text.MessageFormat
            dup
         3: .line 859
            ldc "\"cert status request\": '{'\n{0}\n'}'"
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         4: .line 858
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         5: .line 861
            new java.lang.StringBuilder
            dup
            sipush 512
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 2 /* builder */
        start local 2 // java.lang.StringBuilder builder
         6: .line 862
            iconst_1
            istore 3 /* isFirst */
        start local 3 // boolean isFirst
         7: .line 863
            aload 0 /* this */
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 18
      StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec java.text.MessageFormat java.lang.StringBuilder int top int int sun.security.ssl.CertStatusExtension$CertStatusRequest[]
      StackMap stack:
         8: aload 7
            iload 5
            aaload
            astore 4 /* csr */
        start local 4 // sun.security.ssl.CertStatusExtension$CertStatusRequest csr
         9: .line 864
            iload 3 /* isFirst */
            ifeq 12
        10: .line 865
            iconst_0
            istore 3 /* isFirst */
        11: .line 866
            goto 13
        12: .line 867
      StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec java.text.MessageFormat java.lang.StringBuilder int sun.security.ssl.CertStatusExtension$CertStatusRequest int int sun.security.ssl.CertStatusExtension$CertStatusRequest[]
      StackMap stack:
            aload 2 /* builder */
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        13: .line 869
      StackMap locals:
      StackMap stack:
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        14: .line 870
            aload 4 /* csr */
            invokevirtual sun.security.ssl.CertStatusExtension$CertStatusRequest.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            aastore
        15: .line 869
            astore 8 /* messageFields */
        start local 8 // java.lang.Object[] messageFields
        16: .line 872
            aload 2 /* builder */
            aload 1 /* messageFormat */
            aload 8 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 8 // java.lang.Object[] messageFields
        end local 4 // sun.security.ssl.CertStatusExtension$CertStatusRequest csr
        17: .line 863
            iinc 5 1
      StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec java.text.MessageFormat java.lang.StringBuilder int top int int sun.security.ssl.CertStatusExtension$CertStatusRequest[]
      StackMap stack:
        18: iload 5
            iload 6
            if_icmplt 8
        19: .line 875
            aload 2 /* builder */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 3 // boolean isFirst
        end local 2 // java.lang.StringBuilder builder
        end local 1 // java.text.MessageFormat messageFormat
        end local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   20     0           this  Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
            5   20     1  messageFormat  Ljava/text/MessageFormat;
            6   20     2        builder  Ljava/lang/StringBuilder;
            7   20     3        isFirst  Z
            9   17     4            csr  Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
           16   17     8  messageFields  [Ljava/lang/Object;
}
SourceFile: "CertStatusExtension.java"
NestHost: sun.security.ssl.CertStatusExtension
InnerClasses:
  CertStatusRequest = sun.security.ssl.CertStatusExtension$CertStatusRequest of sun.security.ssl.CertStatusExtension
  final CertStatusRequestType = sun.security.ssl.CertStatusExtension$CertStatusRequestType of sun.security.ssl.CertStatusExtension
  final CertStatusRequestV2Spec = sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec of sun.security.ssl.CertStatusExtension
  final OCSPStatusRequest = sun.security.ssl.CertStatusExtension$OCSPStatusRequest of sun.security.ssl.CertStatusExtension
  abstract SSLExtensionSpec = sun.security.ssl.SSLExtension$SSLExtensionSpec of sun.security.ssl.SSLExtension