public class org.bouncycastle.jce.provider.DSAUtil
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.jce.provider.DSAUtil
  super_class: java.lang.Object
{
  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.DSAUtil this
         0: .line 18
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.bouncycastle.jce.provider.DSAUtil this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/DSAUtil;

  public static org.bouncycastle.crypto.params.AsymmetricKeyParameter generatePublicKeyParameter(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)Lorg/bouncycastle/crypto/params/AsymmetricKeyParameter;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=8, locals=2, args_size=1
        start local 0 // java.security.PublicKey key
         0: .line 24
            aload 0 /* key */
            instanceof java.security.interfaces.DSAPublicKey
            ifeq 5
         1: .line 26
            aload 0 /* key */
            checkcast java.security.interfaces.DSAPublicKey
            astore 1 /* k */
        start local 1 // java.security.interfaces.DSAPublicKey k
         2: .line 28
            new org.bouncycastle.crypto.params.DSAPublicKeyParameters
            dup
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPublicKey.getY:()Ljava/math/BigInteger;
         3: .line 29
            new org.bouncycastle.crypto.params.DSAParameters
            dup
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            invokeinterface java.security.interfaces.DSAParams.getP:()Ljava/math/BigInteger;
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            invokeinterface java.security.interfaces.DSAParams.getQ:()Ljava/math/BigInteger;
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            invokeinterface java.security.interfaces.DSAParams.getG:()Ljava/math/BigInteger;
            invokespecial org.bouncycastle.crypto.params.DSAParameters.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
         4: .line 28
            invokespecial org.bouncycastle.crypto.params.DSAPublicKeyParameters.<init>:(Ljava/math/BigInteger;Lorg/bouncycastle/crypto/params/DSAParameters;)V
            areturn
        end local 1 // java.security.interfaces.DSAPublicKey k
         5: .line 32
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "can't identify DSA public key: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* key */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // java.security.PublicKey key
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0   key  Ljava/security/PublicKey;
            2    5     1     k  Ljava/security/interfaces/DSAPublicKey;
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  public static org.bouncycastle.crypto.params.AsymmetricKeyParameter generatePrivateKeyParameter(java.security.PrivateKey);
    descriptor: (Ljava/security/PrivateKey;)Lorg/bouncycastle/crypto/params/AsymmetricKeyParameter;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=8, locals=2, args_size=1
        start local 0 // java.security.PrivateKey key
         0: .line 39
            aload 0 /* key */
            instanceof java.security.interfaces.DSAPrivateKey
            ifeq 5
         1: .line 41
            aload 0 /* key */
            checkcast java.security.interfaces.DSAPrivateKey
            astore 1 /* k */
        start local 1 // java.security.interfaces.DSAPrivateKey k
         2: .line 43
            new org.bouncycastle.crypto.params.DSAPrivateKeyParameters
            dup
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPrivateKey.getX:()Ljava/math/BigInteger;
         3: .line 44
            new org.bouncycastle.crypto.params.DSAParameters
            dup
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPrivateKey.getParams:()Ljava/security/interfaces/DSAParams;
            invokeinterface java.security.interfaces.DSAParams.getP:()Ljava/math/BigInteger;
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPrivateKey.getParams:()Ljava/security/interfaces/DSAParams;
            invokeinterface java.security.interfaces.DSAParams.getQ:()Ljava/math/BigInteger;
            aload 1 /* k */
            invokeinterface java.security.interfaces.DSAPrivateKey.getParams:()Ljava/security/interfaces/DSAParams;
            invokeinterface java.security.interfaces.DSAParams.getG:()Ljava/math/BigInteger;
            invokespecial org.bouncycastle.crypto.params.DSAParameters.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
         4: .line 43
            invokespecial org.bouncycastle.crypto.params.DSAPrivateKeyParameters.<init>:(Ljava/math/BigInteger;Lorg/bouncycastle/crypto/params/DSAParameters;)V
            areturn
        end local 1 // java.security.interfaces.DSAPrivateKey k
         5: .line 47
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "can't identify DSA private key."
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // java.security.PrivateKey key
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0   key  Ljava/security/PrivateKey;
            2    5     1     k  Ljava/security/interfaces/DSAPrivateKey;
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   
}
SourceFile: "DSAUtil.java"