final class sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage extends sun.security.ssl.SSLHandshake$HandshakeMessage
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage
  super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
  private final byte[] signature;
    descriptor: [B
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(sun.security.ssl.HandshakeContext, sun.security.ssl.X509Authentication$X509Possession);
    descriptor: (Lsun/security/ssl/HandshakeContext;Lsun/security/ssl/X509Authentication$X509Possession;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=8, args_size=3
        start local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
        start local 1 // sun.security.ssl.HandshakeContext context
        start local 2 // sun.security.ssl.X509Authentication$X509Possession x509Possession
         0: .line 72
            aload 0 /* this */
            aload 1 /* context */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 75
            aload 1 /* context */
            checkcast sun.security.ssl.ClientHandshakeContext
            astore 3 /* chc */
        start local 3 // sun.security.ssl.ClientHandshakeContext chc
         2: .line 76
            aconst_null
            astore 4 /* temproary */
        start local 4 // byte[] temproary
         3: .line 77
            aload 2 /* x509Possession */
            getfield sun.security.ssl.X509Authentication$X509Possession.popPrivateKey:Ljava/security/PrivateKey;
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
            astore 5 /* algorithm */
        start local 5 // java.lang.String algorithm
         4: .line 80
            aload 5 /* algorithm */
            aload 2 /* x509Possession */
            getfield sun.security.ssl.X509Authentication$X509Possession.popPrivateKey:Ljava/security/PrivateKey;
            invokestatic sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.getSignature:(Ljava/lang/String;Ljava/security/Key;)Ljava/security/Signature;
         5: .line 79
            astore 6 /* signer */
        start local 6 // java.security.Signature signer
         6: .line 81
            aload 3 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
            aload 5 /* algorithm */
         7: .line 82
            aload 3 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getMasterSecret:()Ljavax/crypto/SecretKey;
         8: .line 81
            invokevirtual sun.security.ssl.HandshakeHash.digest:(Ljava/lang/String;Ljavax/crypto/SecretKey;)[B
            astore 7 /* hashes */
        start local 7 // byte[] hashes
         9: .line 83
            aload 6 /* signer */
            aload 7 /* hashes */
            invokevirtual java.security.Signature.update:([B)V
        10: .line 84
            aload 6 /* signer */
            invokevirtual java.security.Signature.sign:()[B
            astore 4 /* temproary */
        end local 7 // byte[] hashes
        end local 6 // java.security.Signature signer
        11: .line 85
            goto 23
      StackMap locals: sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage sun.security.ssl.HandshakeContext sun.security.ssl.X509Authentication$X509Possession sun.security.ssl.ClientHandshakeContext byte[] java.lang.String
      StackMap stack: java.security.NoSuchAlgorithmException
        12: astore 6 /* nsae */
        start local 6 // java.security.NoSuchAlgorithmException nsae
        13: .line 86
            aload 3 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.INTERNAL_ERROR:Lsun/security/ssl/Alert;
        14: .line 87
            new java.lang.StringBuilder
            dup
            ldc "Unsupported signature algorithm ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        15: .line 88
            ldc ") used in CertificateVerify handshake message"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        16: .line 87
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 88
            aload 6 /* nsae */
        18: .line 86
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        end local 6 // java.security.NoSuchAlgorithmException nsae
        19: .line 89
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 6 /* gse */
        start local 6 // java.security.GeneralSecurityException gse
        20: .line 90
            aload 3 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        21: .line 91
            ldc "Cannot produce CertificateVerify signature"
            aload 6 /* gse */
        22: .line 90
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        end local 6 // java.security.GeneralSecurityException gse
        23: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* temproary */
            putfield sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.signature:[B
        24: .line 95
            return
        end local 5 // java.lang.String algorithm
        end local 4 // byte[] temproary
        end local 3 // sun.security.ssl.ClientHandshakeContext chc
        end local 2 // sun.security.ssl.X509Authentication$X509Possession x509Possession
        end local 1 // sun.security.ssl.HandshakeContext context
        end local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   25     0            this  Lsun/security/ssl/CertificateVerify$S30CertificateVerifyMessage;
            0   25     1         context  Lsun/security/ssl/HandshakeContext;
            0   25     2  x509Possession  Lsun/security/ssl/X509Authentication$X509Possession;
            2   25     3             chc  Lsun/security/ssl/ClientHandshakeContext;
            3   25     4       temproary  [B
            4   25     5       algorithm  Ljava/lang/String;
            6   11     6          signer  Ljava/security/Signature;
            9   11     7          hashes  [B
           13   19     6            nsae  Ljava/security/NoSuchAlgorithmException;
           20   23     6             gse  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
           4    11      12  Class java.security.NoSuchAlgorithmException
           4    11      19  Class java.security.GeneralSecurityException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                Name  Flags
      context         
      x509Possession  

  void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
    descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=8, args_size=3
        start local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
        start local 1 // sun.security.ssl.HandshakeContext context
        start local 2 // java.nio.ByteBuffer m
         0: .line 99
            aload 0 /* this */
            aload 1 /* context */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 102
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            astore 3 /* shc */
        start local 3 // sun.security.ssl.ServerHandshakeContext shc
         2: .line 114
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_2
            if_icmpge 6
         3: .line 115
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
         4: .line 116
            ldc "Invalid CertificateVerify message: no sufficient data"
         5: .line 115
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
         6: .line 120
      StackMap locals: sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer sun.security.ssl.ServerHandshakeContext
      StackMap stack:
            aload 0 /* this */
            aload 2 /* m */
            invokestatic sun.security.ssl.Record.getBytes16:(Ljava/nio/ByteBuffer;)[B
            putfield sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.signature:[B
         7: .line 121
            aconst_null
            astore 4 /* x509Credentials */
        start local 4 // sun.security.ssl.X509Authentication$X509Credentials x509Credentials
         8: .line 122
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeCredentials:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 13
      StackMap locals: sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer sun.security.ssl.ServerHandshakeContext sun.security.ssl.X509Authentication$X509Credentials top java.util.Iterator
      StackMap stack:
         9: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.SSLCredentials
            astore 5 /* cd */
        start local 5 // sun.security.ssl.SSLCredentials cd
        10: .line 123
            aload 5 /* cd */
            instanceof sun.security.ssl.X509Authentication$X509Credentials
            ifeq 13
        11: .line 124
            aload 5 /* cd */
            checkcast sun.security.ssl.X509Authentication$X509Credentials
            astore 4 /* x509Credentials */
        12: .line 125
            goto 14
        end local 5 // sun.security.ssl.SSLCredentials cd
        13: .line 122
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        14: .line 129
      StackMap locals: sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer sun.security.ssl.ServerHandshakeContext sun.security.ssl.X509Authentication$X509Credentials
      StackMap stack:
            aload 4 /* x509Credentials */
            ifnull 16
        15: .line 130
            aload 4 /* x509Credentials */
            getfield sun.security.ssl.X509Authentication$X509Credentials.popPublicKey:Ljava/security/PublicKey;
            ifnonnull 19
        16: .line 131
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        17: .line 132
            ldc "No X509 credentials negotiated for CertificateVerify"
        18: .line 131
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        19: .line 135
      StackMap locals:
      StackMap stack:
            aload 4 /* x509Credentials */
            getfield sun.security.ssl.X509Authentication$X509Credentials.popPublicKey:Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
            astore 5 /* algorithm */
        start local 5 // java.lang.String algorithm
        20: .line 138
            aload 5 /* algorithm */
            aload 4 /* x509Credentials */
            getfield sun.security.ssl.X509Authentication$X509Credentials.popPublicKey:Ljava/security/PublicKey;
            invokestatic sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.getSignature:(Ljava/lang/String;Ljava/security/Key;)Ljava/security/Signature;
        21: .line 137
            astore 6 /* signer */
        start local 6 // java.security.Signature signer
        22: .line 139
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
            aload 5 /* algorithm */
        23: .line 140
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getMasterSecret:()Ljavax/crypto/SecretKey;
        24: .line 139
            invokevirtual sun.security.ssl.HandshakeHash.digest:(Ljava/lang/String;Ljavax/crypto/SecretKey;)[B
            astore 7 /* hashes */
        start local 7 // byte[] hashes
        25: .line 141
            aload 6 /* signer */
            aload 7 /* hashes */
            invokevirtual java.security.Signature.update:([B)V
        26: .line 142
            aload 6 /* signer */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.signature:[B
            invokevirtual java.security.Signature.verify:([B)Z
            ifne 41
        27: .line 143
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        28: .line 144
            ldc "Invalid CertificateVerify message: invalid signature"
        29: .line 143
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        end local 7 // byte[] hashes
        end local 6 // java.security.Signature signer
        30: .line 146
      StackMap locals: sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer sun.security.ssl.ServerHandshakeContext sun.security.ssl.X509Authentication$X509Credentials java.lang.String
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 6 /* nsae */
        start local 6 // java.security.NoSuchAlgorithmException nsae
        31: .line 147
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.INTERNAL_ERROR:Lsun/security/ssl/Alert;
        32: .line 148
            new java.lang.StringBuilder
            dup
            ldc "Unsupported signature algorithm ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        33: .line 149
            ldc ") used in CertificateVerify handshake message"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        34: .line 148
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        35: .line 149
            aload 6 /* nsae */
        36: .line 147
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        end local 6 // java.security.NoSuchAlgorithmException nsae
        37: .line 150
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 6 /* gse */
        start local 6 // java.security.GeneralSecurityException gse
        38: .line 151
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        39: .line 152
            ldc "Cannot verify CertificateVerify signature"
            aload 6 /* gse */
        40: .line 151
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;Ljava/lang/Throwable;)Ljavax/net/ssl/SSLException;
            athrow
        end local 6 // java.security.GeneralSecurityException gse
        41: .line 154
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.lang.String algorithm
        end local 4 // sun.security.ssl.X509Authentication$X509Credentials x509Credentials
        end local 3 // sun.security.ssl.ServerHandshakeContext shc
        end local 2 // java.nio.ByteBuffer m
        end local 1 // sun.security.ssl.HandshakeContext context
        end local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   42     0             this  Lsun/security/ssl/CertificateVerify$S30CertificateVerifyMessage;
            0   42     1          context  Lsun/security/ssl/HandshakeContext;
            0   42     2                m  Ljava/nio/ByteBuffer;
            2   42     3              shc  Lsun/security/ssl/ServerHandshakeContext;
            8   42     4  x509Credentials  Lsun/security/ssl/X509Authentication$X509Credentials;
           10   13     5               cd  Lsun/security/ssl/SSLCredentials;
           20   42     5        algorithm  Ljava/lang/String;
           22   30     6           signer  Ljava/security/Signature;
           25   30     7           hashes  [B
           31   37     6             nsae  Ljava/security/NoSuchAlgorithmException;
           38   41     6              gse  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
          20    30      30  Class java.security.NoSuchAlgorithmException
          20    30      37  Class java.security.GeneralSecurityException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
      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.CertificateVerify$S30CertificateVerifyMessage this
         0: .line 158
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_VERIFY:Lsun/security/ssl/SSLHandshake;
            areturn
        end local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/CertificateVerify$S30CertificateVerifyMessage;

  public int messageLength();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
         0: .line 163
            iconst_2
            aload 0 /* this */
            getfield sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.signature:[B
            arraylength
            iadd
            ireturn
        end local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/CertificateVerify$S30CertificateVerifyMessage;

  public void send(sun.security.ssl.HandshakeOutStream);
    descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
        start local 1 // sun.security.ssl.HandshakeOutStream hos
         0: .line 168
            aload 1 /* hos */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.signature:[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         1: .line 169
            return
        end local 1 // sun.security.ssl.HandshakeOutStream hos
        end local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/CertificateVerify$S30CertificateVerifyMessage;
            0    2     1   hos  Lsun/security/ssl/HandshakeOutStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      hos   

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
         0: .line 173
            new java.text.MessageFormat
            dup
         1: .line 174
            ldc "\"CertificateVerify\": '{'\n  \"signature\": '{'\n{0}\n  '}'\n'}'"
         2: .line 179
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         3: .line 173
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         4: .line 181
            new sun.security.util.HexDumpEncoder
            dup
            invokespecial sun.security.util.HexDumpEncoder.<init>:()V
            astore 2 /* hexEncoder */
        start local 2 // sun.security.util.HexDumpEncoder hexEncoder
         5: .line 182
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
         6: .line 184
            aload 2 /* hexEncoder */
            aload 0 /* this */
            getfield sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage.signature:[B
            invokevirtual sun.security.util.HexDumpEncoder.encodeBuffer:([B)Ljava/lang/String;
            ldc "    "
         7: .line 183
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            aastore
         8: .line 182
            astore 3 /* messageFields */
        start local 3 // java.lang.Object[] messageFields
         9: .line 187
            aload 1 /* 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 // sun.security.util.HexDumpEncoder hexEncoder
        end local 1 // java.text.MessageFormat messageFormat
        end local 0 // sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   10     0           this  Lsun/security/ssl/CertificateVerify$S30CertificateVerifyMessage;
            4   10     1  messageFormat  Ljava/text/MessageFormat;
            5   10     2     hexEncoder  Lsun/security/util/HexDumpEncoder;
            9   10     3  messageFields  [Ljava/lang/Object;

  private static java.security.Signature getSignature(java.lang.String, java.security.Key);
    descriptor: (Ljava/lang/String;Ljava/security/Key;)Ljava/security/Signature;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // java.lang.String algorithm
        start local 1 // java.security.Key key
         0: .line 196
            aconst_null
            astore 2 /* signer */
        start local 2 // java.security.Signature signer
         1: .line 197
            aload 0 /* algorithm */
            dup
            astore 3
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 3
                 2206: 2
                67986: 3
                81440: 4
              default: 11
          }
      StackMap locals: java.security.Signature java.lang.String
      StackMap stack:
         2: aload 3
            ldc "EC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 9
            goto 11
      StackMap locals:
      StackMap stack:
         3: aload 3
            ldc "DSA"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 7
            goto 11
      StackMap locals:
      StackMap stack:
         4: aload 3
            ldc "RSA"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 5
            goto 11
         5: .line 199
      StackMap locals:
      StackMap stack:
            ldc "NONEwithRSA"
            invokestatic sun.security.ssl.JsseJce.getSignature:(Ljava/lang/String;)Ljava/security/Signature;
            astore 2 /* signer */
         6: .line 200
            goto 14
         7: .line 202
      StackMap locals:
      StackMap stack:
            ldc "RawDSA"
            invokestatic sun.security.ssl.JsseJce.getSignature:(Ljava/lang/String;)Ljava/security/Signature;
            astore 2 /* signer */
         8: .line 203
            goto 14
         9: .line 205
      StackMap locals:
      StackMap stack:
            ldc "NONEwithECDSA"
            invokestatic sun.security.ssl.JsseJce.getSignature:(Ljava/lang/String;)Ljava/security/Signature;
            astore 2 /* signer */
        10: .line 206
            goto 14
        11: .line 208
      StackMap locals:
      StackMap stack:
            new java.security.SignatureException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unrecognized algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        12: .line 209
            aload 0 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 208
            invokespecial java.security.SignatureException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 212
      StackMap locals:
      StackMap stack:
            aload 2 /* signer */
            ifnull 19
        15: .line 213
            aload 1 /* key */
            instanceof java.security.PublicKey
            ifeq 18
        16: .line 214
            aload 2 /* signer */
            aload 1 /* key */
            checkcast java.security.PublicKey
            invokevirtual java.security.Signature.initVerify:(Ljava/security/PublicKey;)V
        17: .line 215
            goto 19
        18: .line 216
      StackMap locals:
      StackMap stack:
            aload 2 /* signer */
            aload 1 /* key */
            checkcast java.security.PrivateKey
            invokevirtual java.security.Signature.initSign:(Ljava/security/PrivateKey;)V
        19: .line 220
      StackMap locals:
      StackMap stack:
            aload 2 /* signer */
            areturn
        end local 2 // java.security.Signature signer
        end local 1 // java.security.Key key
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   20     0  algorithm  Ljava/lang/String;
            0   20     1        key  Ljava/security/Key;
            1   20     2     signer  Ljava/security/Signature;
    Exceptions:
      throws java.security.GeneralSecurityException
    MethodParameters:
           Name  Flags
      algorithm  
      key        
}
SourceFile: "CertificateVerify.java"
NestHost: sun.security.ssl.CertificateVerify
InnerClasses:
  final S30CertificateVerifyMessage = sun.security.ssl.CertificateVerify$S30CertificateVerifyMessage of sun.security.ssl.CertificateVerify
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake
  final X509Credentials = sun.security.ssl.X509Authentication$X509Credentials of sun.security.ssl.X509Authentication
  final X509Possession = sun.security.ssl.X509Authentication$X509Possession of sun.security.ssl.X509Authentication