public abstract class java.security.cert.X509CRL extends java.security.cert.CRL implements java.security.cert.X509Extension
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: java.security.cert.X509CRL
  super_class: java.security.cert.CRL
{
  private transient javax.security.auth.x500.X500Principal issuerPrincipal;
    descriptor: Ljavax/security/auth/x500/X500Principal;
    flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT

  protected void <init>();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.security.cert.X509CRL this
         0: .line 117
            aload 0 /* this */
            ldc "X.509"
            invokespecial java.security.cert.CRL.<init>:(Ljava/lang/String;)V
         1: .line 118
            return
        end local 0 // java.security.cert.X509CRL this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/security/cert/X509CRL;

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // java.security.cert.X509CRL this
        start local 1 // java.lang.Object other
         0: .line 133
            aload 0 /* this */
            aload 1 /* other */
            if_acmpne 2
         1: .line 134
            iconst_1
            ireturn
         2: .line 136
      StackMap locals:
      StackMap stack:
            aload 1 /* other */
            instanceof java.security.cert.X509CRL
            ifne 4
         3: .line 137
            iconst_0
            ireturn
         4: .line 140
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokestatic sun.security.x509.X509CRLImpl.getEncodedInternal:(Ljava/security/cert/X509CRL;)[B
            astore 2 /* thisCRL */
        start local 2 // byte[] thisCRL
         5: .line 141
            aload 1 /* other */
            checkcast java.security.cert.X509CRL
            invokestatic sun.security.x509.X509CRLImpl.getEncodedInternal:(Ljava/security/cert/X509CRL;)[B
            astore 3 /* otherCRL */
        start local 3 // byte[] otherCRL
         6: .line 143
            aload 2 /* thisCRL */
            aload 3 /* otherCRL */
            invokestatic java.util.Arrays.equals:([B[B)Z
         7: ireturn
        end local 3 // byte[] otherCRL
        end local 2 // byte[] thisCRL
         8: .line 144
      StackMap locals:
      StackMap stack: java.security.cert.CRLException
            pop
         9: .line 145
            iconst_0
            ireturn
        end local 1 // java.lang.Object other
        end local 0 // java.security.cert.X509CRL this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   10     0      this  Ljava/security/cert/X509CRL;
            0   10     1     other  Ljava/lang/Object;
            5    8     2   thisCRL  [B
            6    8     3  otherCRL  [B
      Exception table:
        from    to  target  type
           4     7       8  Class java.security.cert.CRLException
    MethodParameters:
       Name  Flags
      other  

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // java.security.cert.X509CRL this
         0: .line 156
            iconst_0
            istore 1 /* retval */
        start local 1 // int retval
         1: .line 158
            aload 0 /* this */
            invokestatic sun.security.x509.X509CRLImpl.getEncodedInternal:(Ljava/security/cert/X509CRL;)[B
            astore 2 /* crlData */
        start local 2 // byte[] crlData
         2: .line 159
            iconst_1
            istore 3 /* i */
        start local 3 // int i
         3: goto 6
         4: .line 160
      StackMap locals: int byte[] int
      StackMap stack:
            iload 1 /* retval */
            aload 2 /* crlData */
            iload 3 /* i */
            baload
            iload 3 /* i */
            imul
            iadd
            istore 1 /* retval */
         5: .line 159
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 3 /* i */
            aload 2 /* crlData */
            arraylength
            if_icmplt 4
        end local 3 // int i
         7: .line 162
            iload 1 /* retval */
         8: ireturn
        end local 2 // byte[] crlData
         9: .line 163
      StackMap locals: java.security.cert.X509CRL int
      StackMap stack: java.security.cert.CRLException
            pop
        10: .line 164
            iload 1 /* retval */
            ireturn
        end local 1 // int retval
        end local 0 // java.security.cert.X509CRL this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   11     0     this  Ljava/security/cert/X509CRL;
            1   11     1   retval  I
            2    9     2  crlData  [B
            3    7     3        i  I
      Exception table:
        from    to  target  type
           1     8       9  Class java.security.cert.CRLException

  public abstract byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.cert.CRLException

  public abstract void verify(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.cert.CRLException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException, java.security.NoSuchProviderException, java.security.SignatureException
    MethodParameters:
      Name  Flags
      key   

  public abstract void verify(java.security.PublicKey, java.lang.String);
    descriptor: (Ljava/security/PublicKey;Ljava/lang/String;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.cert.CRLException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException, java.security.NoSuchProviderException, java.security.SignatureException
    MethodParameters:
             Name  Flags
      key          
      sigProvider  

  public void verify(java.security.PublicKey, java.security.Provider);
    descriptor: (Ljava/security/PublicKey;Ljava/security/Provider;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // java.security.cert.X509CRL this
        start local 1 // java.security.PublicKey key
        start local 2 // java.security.Provider sigProvider
         0: .line 241
            aload 0 /* this */
            invokevirtual java.security.cert.X509CRL.getSigAlgName:()Ljava/lang/String;
            astore 3 /* sigAlgName */
        start local 3 // java.lang.String sigAlgName
         1: .line 242
            aload 2 /* sigProvider */
            ifnonnull 3
         2: .line 243
            aload 3 /* sigAlgName */
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;)Ljava/security/Signature;
            goto 4
         3: .line 244
      StackMap locals: java.lang.String
      StackMap stack:
            aload 3 /* sigAlgName */
            aload 2 /* sigProvider */
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/Signature;
         4: .line 242
      StackMap locals:
      StackMap stack: java.security.Signature
            astore 4 /* sig */
        start local 4 // java.security.Signature sig
         5: .line 247
            aload 0 /* this */
            invokevirtual java.security.cert.X509CRL.getSigAlgParams:()[B
            astore 5 /* paramBytes */
        start local 5 // byte[] paramBytes
         6: .line 248
            aload 4 /* sig */
            aload 1 /* key */
         7: .line 249
            aload 3 /* sigAlgName */
            aload 5 /* paramBytes */
            invokestatic sun.security.util.SignatureUtil.getParamSpec:(Ljava/lang/String;[B)Ljava/security/spec/AlgorithmParameterSpec;
         8: .line 248
            invokestatic sun.security.util.SignatureUtil.initVerifyWithParam:(Ljava/security/Signature;Ljava/security/PublicKey;Ljava/security/spec/AlgorithmParameterSpec;)V
        end local 5 // byte[] paramBytes
         9: .line 250
            goto 14
      StackMap locals: java.security.cert.X509CRL java.security.PublicKey java.security.Provider java.lang.String java.security.Signature
      StackMap stack: java.security.ProviderException
        10: astore 5 /* e */
        start local 5 // java.security.ProviderException e
        11: .line 251
            new java.security.cert.CRLException
            dup
            aload 5 /* e */
            invokevirtual java.security.ProviderException.getMessage:()Ljava/lang/String;
            aload 5 /* e */
            invokevirtual java.security.ProviderException.getCause:()Ljava/lang/Throwable;
            invokespecial java.security.cert.CRLException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.security.ProviderException e
        12: .line 252
      StackMap locals:
      StackMap stack: java.security.InvalidAlgorithmParameterException
            astore 5 /* e */
        start local 5 // java.security.InvalidAlgorithmParameterException e
        13: .line 253
            new java.security.cert.CRLException
            dup
            aload 5 /* e */
            invokespecial java.security.cert.CRLException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.security.InvalidAlgorithmParameterException e
        14: .line 256
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.security.cert.X509CRL.getTBSCertList:()[B
            astore 5 /* tbsCRL */
        start local 5 // byte[] tbsCRL
        15: .line 257
            aload 4 /* sig */
            aload 5 /* tbsCRL */
            iconst_0
            aload 5 /* tbsCRL */
            arraylength
            invokevirtual java.security.Signature.update:([BII)V
        16: .line 259
            aload 4 /* sig */
            aload 0 /* this */
            invokevirtual java.security.cert.X509CRL.getSignature:()[B
            invokevirtual java.security.Signature.verify:([B)Z
            ifne 18
        17: .line 260
            new java.security.SignatureException
            dup
            ldc "Signature does not match."
            invokespecial java.security.SignatureException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 262
      StackMap locals: byte[]
      StackMap stack:
            return
        end local 5 // byte[] tbsCRL
        end local 4 // java.security.Signature sig
        end local 3 // java.lang.String sigAlgName
        end local 2 // java.security.Provider sigProvider
        end local 1 // java.security.PublicKey key
        end local 0 // java.security.cert.X509CRL this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   19     0         this  Ljava/security/cert/X509CRL;
            0   19     1          key  Ljava/security/PublicKey;
            0   19     2  sigProvider  Ljava/security/Provider;
            1   19     3   sigAlgName  Ljava/lang/String;
            5   19     4          sig  Ljava/security/Signature;
            6    9     5   paramBytes  [B
           11   12     5            e  Ljava/security/ProviderException;
           13   14     5            e  Ljava/security/InvalidAlgorithmParameterException;
           15   19     5       tbsCRL  [B
      Exception table:
        from    to  target  type
           5     9      10  Class java.security.ProviderException
           5     9      12  Class java.security.InvalidAlgorithmParameterException
    Exceptions:
      throws java.security.cert.CRLException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException, java.security.SignatureException
    MethodParameters:
             Name  Flags
      key          
      sigProvider  

  public abstract int getVersion();
    descriptor: ()I
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract java.security.Principal getIssuerDN();
    descriptor: ()Ljava/security/Principal;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public javax.security.auth.x500.X500Principal getIssuerX500Principal();
    descriptor: ()Ljavax/security/auth/x500/X500Principal;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.security.cert.X509CRL this
         0: .line 332
            aload 0 /* this */
            getfield java.security.cert.X509CRL.issuerPrincipal:Ljavax/security/auth/x500/X500Principal;
            ifnonnull 2
         1: .line 333
            aload 0 /* this */
            aload 0 /* this */
            invokestatic sun.security.x509.X509CRLImpl.getIssuerX500Principal:(Ljava/security/cert/X509CRL;)Ljavax/security/auth/x500/X500Principal;
            putfield java.security.cert.X509CRL.issuerPrincipal:Ljavax/security/auth/x500/X500Principal;
         2: .line 335
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.cert.X509CRL.issuerPrincipal:Ljavax/security/auth/x500/X500Principal;
            areturn
        end local 0 // java.security.cert.X509CRL this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljava/security/cert/X509CRL;

  public abstract java.util.Date getThisUpdate();
    descriptor: ()Ljava/util/Date;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract java.util.Date getNextUpdate();
    descriptor: ()Ljava/util/Date;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract java.security.cert.X509CRLEntry getRevokedCertificate(java.math.BigInteger);
    descriptor: (Ljava/math/BigInteger;)Ljava/security/cert/X509CRLEntry;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
              Name  Flags
      serialNumber  

  public java.security.cert.X509CRLEntry getRevokedCertificate(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)Ljava/security/cert/X509CRLEntry;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // java.security.cert.X509CRL this
        start local 1 // java.security.cert.X509Certificate certificate
         0: .line 390
            aload 1 /* certificate */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 2 /* certIssuer */
        start local 2 // javax.security.auth.x500.X500Principal certIssuer
         1: .line 391
            aload 0 /* this */
            invokevirtual java.security.cert.X509CRL.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 3 /* crlIssuer */
        start local 3 // javax.security.auth.x500.X500Principal crlIssuer
         2: .line 392
            aload 2 /* certIssuer */
            aload 3 /* crlIssuer */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 4
         3: .line 393
            aconst_null
            areturn
         4: .line 395
      StackMap locals: javax.security.auth.x500.X500Principal javax.security.auth.x500.X500Principal
      StackMap stack:
            aload 0 /* this */
            aload 1 /* certificate */
            invokevirtual java.security.cert.X509Certificate.getSerialNumber:()Ljava/math/BigInteger;
            invokevirtual java.security.cert.X509CRL.getRevokedCertificate:(Ljava/math/BigInteger;)Ljava/security/cert/X509CRLEntry;
            areturn
        end local 3 // javax.security.auth.x500.X500Principal crlIssuer
        end local 2 // javax.security.auth.x500.X500Principal certIssuer
        end local 1 // java.security.cert.X509Certificate certificate
        end local 0 // java.security.cert.X509CRL this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Ljava/security/cert/X509CRL;
            0    5     1  certificate  Ljava/security/cert/X509Certificate;
            1    5     2   certIssuer  Ljavax/security/auth/x500/X500Principal;
            2    5     3    crlIssuer  Ljavax/security/auth/x500/X500Principal;
    MethodParameters:
             Name  Flags
      certificate  

  public abstract java.util.Set<? extends java.security.cert.X509CRLEntry> getRevokedCertificates();
    descriptor: ()Ljava/util/Set;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Signature: ()Ljava/util/Set<+Ljava/security/cert/X509CRLEntry;>;

  public abstract byte[] getTBSCertList();
    descriptor: ()[B
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.cert.CRLException

  public abstract byte[] getSignature();
    descriptor: ()[B
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract java.lang.String getSigAlgName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract java.lang.String getSigAlgOID();
    descriptor: ()Ljava/lang/String;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract byte[] getSigAlgParams();
    descriptor: ()[B
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
}
SourceFile: "X509CRL.java"