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 774
            new sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec
            dup
            iconst_1
            anewarray sun.security.ssl.CertStatusExtension$CertStatusRequest
            dup
            iconst_0
         1: .line 775
            getstatic sun.security.ssl.CertStatusExtension$OCSPStatusRequest.EMPTY_OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$OCSPStatusRequest;
            aastore
         2: .line 774
            invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.<init>:([Lsun/security/ssl/CertStatusExtension$CertStatusRequest;)V
         3: .line 773
            putstatic sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.DEFAULT:Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
         4: .line 775
            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 779
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 780
            aload 0 /* this */
            aload 1 /* certStatusRequests */
            putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
         2: .line 781
            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>(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=2
        start local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
        start local 1 // java.nio.ByteBuffer message
         0: .line 783
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 785
            aload 1 /* message */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            ifne 4
         2: .line 787
            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 788
            return
         4: .line 791
      StackMap locals: sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec java.nio.ByteBuffer
      StackMap stack:
            aload 1 /* message */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_5
            if_icmpge 8
         5: .line 794
            new javax.net.ssl.SSLProtocolException
            dup
         6: .line 795
            ldc "Invalid status_request_v2 extension: insufficient data"
         7: .line 794
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 798
      StackMap locals:
      StackMap stack:
            aload 1 /* message */
            invokestatic sun.security.ssl.Record.getInt16:(Ljava/nio/ByteBuffer;)I
            istore 2 /* listLen */
        start local 2 // int listLen
         9: .line 799
            iload 2 /* listLen */
            ifgt 15
        10: .line 800
            new javax.net.ssl.SSLProtocolException
            dup
        11: .line 801
            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
        12: .line 802
            iload 2 /* listLen */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        13: .line 801
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 800
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 805
      StackMap locals: int
      StackMap stack:
            iload 2 /* listLen */
            istore 3 /* remaining */
        start local 3 // int remaining
        16: .line 806
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 4 /* statusRequests */
        start local 4 // java.util.List statusRequests
        17: .line 807
            goto 50
        18: .line 808
      StackMap locals: int java.util.List
      StackMap stack:
            aload 1 /* message */
            invokestatic sun.security.ssl.Record.getInt8:(Ljava/nio/ByteBuffer;)I
            i2b
            istore 5 /* statusType */
        start local 5 // byte statusType
        19: .line 809
            aload 1 /* message */
            invokestatic sun.security.ssl.Record.getInt16:(Ljava/nio/ByteBuffer;)I
            istore 6 /* requestLen */
        start local 6 // int requestLen
        20: .line 811
            aload 1 /* message */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iload 6 /* requestLen */
            if_icmpge 27
        21: .line 812
            new javax.net.ssl.SSLProtocolException
            dup
        22: .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
        23: .line 814
            iload 6 /* requestLen */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        24: .line 815
            ldc ", remining="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* 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;
        25: .line 813
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        26: .line 812
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 818
      StackMap locals: int int
      StackMap stack:
            iload 6 /* requestLen */
            newarray 8
            astore 7 /* encoded */
        start local 7 // byte[] encoded
        28: .line 819
            aload 7 /* encoded */
            arraylength
            ifeq 30
        29: .line 820
            aload 1 /* message */
            aload 7 /* encoded */
            invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
            pop
        30: .line 822
      StackMap locals: byte[]
      StackMap stack:
            iinc 3 /* remaining */ -3
        31: .line 823
            iload 3 /* remaining */
            iload 6 /* requestLen */
            isub
            istore 3 /* remaining */
        32: .line 825
            iload 5 /* statusType */
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
            if_icmpeq 34
        33: .line 826
            iload 5 /* statusType */
            getstatic sun.security.ssl.CertStatusExtension$CertStatusRequestType.OCSP_MULTI:Lsun/security/ssl/CertStatusExtension$CertStatusRequestType;
            getfield sun.security.ssl.CertStatusExtension$CertStatusRequestType.id:B
            if_icmpne 42
        34: .line 827
      StackMap locals:
      StackMap stack:
            aload 7 /* encoded */
            arraylength
            iconst_4
            if_icmpge 38
        35: .line 830
            new javax.net.ssl.SSLProtocolException
            dup
        36: .line 831
            ldc "Invalid status_request_v2 extension: insufficient data"
        37: .line 830
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
            athrow
        38: .line 834
      StackMap locals:
      StackMap stack:
            aload 4 /* statusRequests */
        39: .line 835
            new sun.security.ssl.CertStatusExtension$OCSPStatusRequest
            dup
            iload 5 /* statusType */
            aload 7 /* encoded */
            invokespecial sun.security.ssl.CertStatusExtension$OCSPStatusRequest.<init>:(B[B)V
        40: .line 834
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        41: .line 836
            goto 50
        42: .line 837
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 47
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 47
        43: .line 839
            new java.lang.StringBuilder
            dup
            ldc "Unknown certificate status request (status type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        44: .line 840
            iload 5 /* statusType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        45: .line 839
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        46: .line 838
            invokestatic sun.security.ssl.SSLLogger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
        47: .line 842
      StackMap locals:
      StackMap stack:
            aload 4 /* statusRequests */
        48: .line 843
            new sun.security.ssl.CertStatusExtension$CertStatusRequest
            dup
            iload 5 /* statusType */
            aload 7 /* encoded */
            invokespecial sun.security.ssl.CertStatusExtension$CertStatusRequest.<init>:(B[B)V
        49: .line 842
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // byte[] encoded
        end local 6 // int requestLen
        end local 5 // byte statusType
        50: .line 807
      StackMap locals:
      StackMap stack:
            iload 3 /* remaining */
            ifgt 18
        51: .line 847
            aload 0 /* this */
        52: .line 848
            aload 4 /* 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[]
        53: .line 847
            putfield sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec.certStatusRequests:[Lsun/security/ssl/CertStatusExtension$CertStatusRequest;
        54: .line 849
            return
        end local 4 // java.util.List statusRequests
        end local 3 // int remaining
        end local 2 // int listLen
        end local 1 // java.nio.ByteBuffer message
        end local 0 // sun.security.ssl.CertStatusExtension$CertStatusRequestV2Spec this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   55     0            this  Lsun/security/ssl/CertStatusExtension$CertStatusRequestV2Spec;
            0   55     1         message  Ljava/nio/ByteBuffer;
            9   55     2         listLen  I
           16   55     3       remaining  I
           17   55     4  statusRequests  Ljava/util/List<Lsun/security/ssl/CertStatusExtension$CertStatusRequest;>;
           19   50     5      statusType  B
           20   50     6      requestLen  I
           28   50     7         encoded  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      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 853
            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 854
      StackMap locals:
      StackMap stack:
            ldc "<empty>"
            areturn
         2: .line 856
      StackMap locals:
      StackMap stack:
            new java.text.MessageFormat
            dup
         3: .line 857
            ldc "\"cert status request\": '{'\n{0}\n'}'"
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         4: .line 856
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         5: .line 859
            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 860
            iconst_1
            istore 3 /* isFirst */
        start local 3 // boolean isFirst
         7: .line 861
            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 862
            iload 3 /* isFirst */
            ifeq 12
        10: .line 863
            iconst_0
            istore 3 /* isFirst */
        11: .line 864
            goto 13
        12: .line 865
      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 867
      StackMap locals:
      StackMap stack:
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        14: .line 868
            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 867
            astore 8 /* messageFields */
        start local 8 // java.lang.Object[] messageFields
        16: .line 870
            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 861
            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 873
            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