public class sun.security.provider.certpath.X509CertificatePair
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.provider.certpath.X509CertificatePair
  super_class: java.lang.Object
{
  private static final byte TAG_FORWARD;
    descriptor: B
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  private static final byte TAG_REVERSE;
    descriptor: B
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  private java.security.cert.X509Certificate forward;
    descriptor: Ljava/security/cert/X509Certificate;
    flags: (0x0002) ACC_PRIVATE

  private java.security.cert.X509Certificate reverse;
    descriptor: Ljava/security/cert/X509Certificate;
    flags: (0x0002) ACC_PRIVATE

  private byte[] encoded;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private static final sun.security.util.Cache<java.lang.Object, sun.security.provider.certpath.X509CertificatePair> cache;
    descriptor: Lsun/security/util/Cache;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Lsun/security/util/Cache<Ljava/lang/Object;Lsun/security/provider/certpath/X509CertificatePair;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 83
            sipush 750
            invokestatic sun.security.util.Cache.newSoftMemoryCache:(I)Lsun/security/util/Cache;
         1: .line 82
            putstatic sun.security.provider.certpath.X509CertificatePair.cache:Lsun/security/util/Cache;
         2: .line 83
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
         0: .line 88
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/X509CertificatePair;

  public void <init>(java.security.cert.X509Certificate, java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
        start local 1 // java.security.cert.X509Certificate forward
        start local 2 // java.security.cert.X509Certificate reverse
         0: .line 100
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 102
            aload 1 /* forward */
            ifnonnull 3
            aload 2 /* reverse */
            ifnonnull 3
         2: .line 103
            new java.security.cert.CertificateException
            dup
            ldc "at least one of certificate pair must be non-null"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 107
      StackMap locals: sun.security.provider.certpath.X509CertificatePair java.security.cert.X509Certificate java.security.cert.X509Certificate
      StackMap stack:
            aload 0 /* this */
            aload 1 /* forward */
            putfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
         4: .line 108
            aload 0 /* this */
            aload 2 /* reverse */
            putfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
         5: .line 110
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.X509CertificatePair.checkPair:()V
         6: .line 111
            return
        end local 2 // java.security.cert.X509Certificate reverse
        end local 1 // java.security.cert.X509Certificate forward
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lsun/security/provider/certpath/X509CertificatePair;
            0    7     1  forward  Ljava/security/cert/X509Certificate;
            0    7     2  reverse  Ljava/security/cert/X509Certificate;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
         Name  Flags
      forward  
      reverse  

  private void <init>(byte[]);
    descriptor: ([B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
        start local 1 // byte[] encoded
         0: .line 118
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 120
            aload 0 /* this */
            new sun.security.util.DerValue
            dup
            aload 1 /* encoded */
            invokespecial sun.security.util.DerValue.<init>:([B)V
            invokevirtual sun.security.provider.certpath.X509CertificatePair.parse:(Lsun/security/util/DerValue;)V
         2: .line 121
            aload 0 /* this */
            aload 1 /* encoded */
            putfield sun.security.provider.certpath.X509CertificatePair.encoded:[B
         3: .line 122
            goto 6
      StackMap locals: sun.security.provider.certpath.X509CertificatePair byte[]
      StackMap stack: java.io.IOException
         4: astore 2 /* ex */
        start local 2 // java.io.IOException ex
         5: .line 123
            new java.security.cert.CertificateException
            dup
            aload 2 /* ex */
            invokevirtual java.io.IOException.toString:()Ljava/lang/String;
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.io.IOException ex
         6: .line 125
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.X509CertificatePair.checkPair:()V
         7: .line 126
            return
        end local 1 // byte[] encoded
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0     this  Lsun/security/provider/certpath/X509CertificatePair;
            0    8     1  encoded  [B
            5    6     2       ex  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     3       4  Class java.io.IOException
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
         Name  Flags
      encoded  

  public static synchronized void clearCache();
    descriptor: ()V
    flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=0, args_size=0
         0: .line 132
            getstatic sun.security.provider.certpath.X509CertificatePair.cache:Lsun/security/util/Cache;
            invokevirtual sun.security.util.Cache.clear:()V
         1: .line 133
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static synchronized sun.security.provider.certpath.X509CertificatePair generateCertificatePair(byte[]);
    descriptor: ([B)Lsun/security/provider/certpath/X509CertificatePair;
    flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // byte[] encoded
         0: .line 141
            new sun.security.util.Cache$EqualByteArray
            dup
            aload 0 /* encoded */
            invokespecial sun.security.util.Cache$EqualByteArray.<init>:([B)V
            astore 1 /* key */
        start local 1 // java.lang.Object key
         1: .line 142
            getstatic sun.security.provider.certpath.X509CertificatePair.cache:Lsun/security/util/Cache;
            aload 1 /* key */
            invokevirtual sun.security.util.Cache.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.provider.certpath.X509CertificatePair
            astore 2 /* pair */
        start local 2 // sun.security.provider.certpath.X509CertificatePair pair
         2: .line 143
            aload 2 /* pair */
            ifnull 4
         3: .line 144
            aload 2 /* pair */
            areturn
         4: .line 146
      StackMap locals: java.lang.Object sun.security.provider.certpath.X509CertificatePair
      StackMap stack:
            new sun.security.provider.certpath.X509CertificatePair
            dup
            aload 0 /* encoded */
            invokespecial sun.security.provider.certpath.X509CertificatePair.<init>:([B)V
            astore 2 /* pair */
         5: .line 147
            new sun.security.util.Cache$EqualByteArray
            dup
            aload 2 /* pair */
            getfield sun.security.provider.certpath.X509CertificatePair.encoded:[B
            invokespecial sun.security.util.Cache$EqualByteArray.<init>:([B)V
            astore 1 /* key */
         6: .line 148
            getstatic sun.security.provider.certpath.X509CertificatePair.cache:Lsun/security/util/Cache;
            aload 1 /* key */
            aload 2 /* pair */
            invokevirtual sun.security.util.Cache.put:(Ljava/lang/Object;Ljava/lang/Object;)V
         7: .line 149
            aload 2 /* pair */
            areturn
        end local 2 // sun.security.provider.certpath.X509CertificatePair pair
        end local 1 // java.lang.Object key
        end local 0 // byte[] encoded
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0  encoded  [B
            1    8     1      key  Ljava/lang/Object;
            2    8     2     pair  Lsun/security/provider/certpath/X509CertificatePair;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
         Name  Flags
      encoded  

  public void setForward(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
        start local 1 // java.security.cert.X509Certificate cert
         0: .line 156
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.X509CertificatePair.checkPair:()V
         1: .line 157
            aload 0 /* this */
            aload 1 /* cert */
            putfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
         2: .line 158
            return
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/provider/certpath/X509CertificatePair;
            0    3     1  cert  Ljava/security/cert/X509Certificate;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
      Name  Flags
      cert  

  public void setReverse(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
        start local 1 // java.security.cert.X509Certificate cert
         0: .line 164
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.X509CertificatePair.checkPair:()V
         1: .line 165
            aload 0 /* this */
            aload 1 /* cert */
            putfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
         2: .line 166
            return
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/provider/certpath/X509CertificatePair;
            0    3     1  cert  Ljava/security/cert/X509Certificate;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
      Name  Flags
      cert  

  public java.security.cert.X509Certificate getForward();
    descriptor: ()Ljava/security/cert/X509Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
         0: .line 174
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            areturn
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/X509CertificatePair;

  public java.security.cert.X509Certificate getReverse();
    descriptor: ()Ljava/security/cert/X509Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
         0: .line 183
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            areturn
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/X509CertificatePair;

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
         0: .line 194
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.encoded:[B
            ifnonnull 7
         1: .line 195
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 1 /* tmp */
        start local 1 // sun.security.util.DerOutputStream tmp
         2: .line 196
            aload 0 /* this */
            aload 1 /* tmp */
            invokevirtual sun.security.provider.certpath.X509CertificatePair.emit:(Lsun/security/util/DerOutputStream;)V
         3: .line 197
            aload 0 /* this */
            aload 1 /* tmp */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            putfield sun.security.provider.certpath.X509CertificatePair.encoded:[B
        end local 1 // sun.security.util.DerOutputStream tmp
         4: .line 199
            goto 7
      StackMap locals:
      StackMap stack: java.io.IOException
         5: astore 1 /* ex */
        start local 1 // java.io.IOException ex
         6: .line 200
            new java.security.cert.CertificateEncodingException
            dup
            aload 1 /* ex */
            invokevirtual java.io.IOException.toString:()Ljava/lang/String;
            invokespecial java.security.cert.CertificateEncodingException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.io.IOException ex
         7: .line 202
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.encoded:[B
            areturn
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lsun/security/provider/certpath/X509CertificatePair;
            2    4     1   tmp  Lsun/security/util/DerOutputStream;
            6    7     1    ex  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0     4       5  Class java.io.IOException
    Exceptions:
      throws java.security.cert.CertificateEncodingException

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
         0: .line 212
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 213
            aload 1 /* sb */
            ldc "X.509 Certificate Pair: [\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         2: .line 214
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            ifnull 4
         3: .line 215
            aload 1 /* sb */
            ldc "  Forward: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 216
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            ifnull 6
         5: .line 217
            aload 1 /* sb */
            ldc "  Reverse: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         6: .line 218
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 219
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder sb
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lsun/security/provider/certpath/X509CertificatePair;
            1    8     1    sb  Ljava/lang/StringBuilder;

  private void parse(sun.security.util.DerValue);
    descriptor: (Lsun/security/util/DerValue;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
        start local 1 // sun.security.util.DerValue val
         0: .line 226
            aload 1 /* val */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 24
         1: .line 227
            new java.io.IOException
            dup
         2: .line 228
            ldc "Sequence tag missing for X509CertificatePair"
         3: .line 227
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 232
      StackMap locals:
      StackMap stack:
            aload 1 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 2 /* opt */
        start local 2 // sun.security.util.DerValue opt
         5: .line 233
            aload 2 /* opt */
            getfield sun.security.util.DerValue.tag:B
            bipush 31
            iand
            i2b
            istore 3 /* tag */
        start local 3 // short tag
         6: .line 234
            iload 3 /* tag */
            tableswitch { // 0 - 1
                    0: 7
                    1: 15
              default: 23
          }
         7: .line 236
      StackMap locals: sun.security.util.DerValue int
      StackMap stack:
            aload 2 /* opt */
            invokevirtual sun.security.util.DerValue.isContextSpecific:()Z
            ifeq 24
            aload 2 /* opt */
            invokevirtual sun.security.util.DerValue.isConstructed:()Z
            ifeq 24
         8: .line 237
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            ifnull 10
         9: .line 238
            new java.io.IOException
            dup
            ldc "Duplicate forward certificate in X509CertificatePair"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 241
      StackMap locals:
      StackMap stack:
            aload 2 /* opt */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 2 /* opt */
        11: .line 242
            aload 0 /* this */
        12: .line 243
            new sun.security.x509.X509CertImpl
            dup
            aload 2 /* opt */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.x509.X509CertImpl.<init>:([B)V
        13: .line 242
            invokestatic sun.security.provider.X509Factory.intern:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            putfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
        14: .line 245
            goto 24
        15: .line 247
      StackMap locals:
      StackMap stack:
            aload 2 /* opt */
            invokevirtual sun.security.util.DerValue.isContextSpecific:()Z
            ifeq 24
            aload 2 /* opt */
            invokevirtual sun.security.util.DerValue.isConstructed:()Z
            ifeq 24
        16: .line 248
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            ifnull 18
        17: .line 249
            new java.io.IOException
            dup
            ldc "Duplicate reverse certificate in X509CertificatePair"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 252
      StackMap locals:
      StackMap stack:
            aload 2 /* opt */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 2 /* opt */
        19: .line 253
            aload 0 /* this */
        20: .line 254
            new sun.security.x509.X509CertImpl
            dup
            aload 2 /* opt */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.x509.X509CertImpl.<init>:([B)V
        21: .line 253
            invokestatic sun.security.provider.X509Factory.intern:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            putfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
        22: .line 256
            goto 24
        23: .line 258
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            ldc "Invalid encoding of X509CertificatePair"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // short tag
        end local 2 // sun.security.util.DerValue opt
        24: .line 231
      StackMap locals:
      StackMap stack:
            aload 1 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            ifnull 25
            aload 1 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifne 4
        25: .line 262
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            ifnonnull 27
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            ifnonnull 27
        26: .line 263
            new java.security.cert.CertificateException
            dup
            ldc "at least one of certificate pair must be non-null"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 266
      StackMap locals:
      StackMap stack:
            return
        end local 1 // sun.security.util.DerValue val
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   28     0  this  Lsun/security/provider/certpath/X509CertificatePair;
            0   28     1   val  Lsun/security/util/DerValue;
            5   24     2   opt  Lsun/security/util/DerValue;
            6   24     3   tag  S
    Exceptions:
      throws java.io.IOException, java.security.cert.CertificateException
    MethodParameters:
      Name  Flags
      val   

  private void emit(sun.security.util.DerOutputStream);
    descriptor: (Lsun/security/util/DerOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
        start local 1 // sun.security.util.DerOutputStream out
         0: .line 272
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* tagged */
        start local 2 // sun.security.util.DerOutputStream tagged
         1: .line 274
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            ifnull 9
         2: .line 275
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* tmp */
        start local 3 // sun.security.util.DerOutputStream tmp
         3: .line 276
            aload 3 /* tmp */
            new sun.security.util.DerValue
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            invokespecial sun.security.util.DerValue.<init>:([B)V
            invokevirtual sun.security.util.DerOutputStream.putDerValue:(Lsun/security/util/DerValue;)V
         4: .line 277
            aload 2 /* tagged */
            bipush -128
         5: .line 278
            iconst_1
            iconst_0
         6: .line 277
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
         7: .line 278
            aload 3 /* tmp */
         8: .line 277
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        end local 3 // sun.security.util.DerOutputStream tmp
         9: .line 281
      StackMap locals: sun.security.util.DerOutputStream
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            ifnull 17
        10: .line 282
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* tmp */
        start local 3 // sun.security.util.DerOutputStream tmp
        11: .line 283
            aload 3 /* tmp */
            new sun.security.util.DerValue
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            invokespecial sun.security.util.DerValue.<init>:([B)V
            invokevirtual sun.security.util.DerOutputStream.putDerValue:(Lsun/security/util/DerValue;)V
        12: .line 284
            aload 2 /* tagged */
            bipush -128
        13: .line 285
            iconst_1
            iconst_1
        14: .line 284
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        15: .line 285
            aload 3 /* tmp */
        16: .line 284
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        end local 3 // sun.security.util.DerOutputStream tmp
        17: .line 288
      StackMap locals:
      StackMap stack:
            aload 1 /* out */
            bipush 48
            aload 2 /* tagged */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        18: .line 289
            return
        end local 2 // sun.security.util.DerOutputStream tagged
        end local 1 // sun.security.util.DerOutputStream out
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   19     0    this  Lsun/security/provider/certpath/X509CertificatePair;
            0   19     1     out  Lsun/security/util/DerOutputStream;
            1   19     2  tagged  Lsun/security/util/DerOutputStream;
            3    9     3     tmp  Lsun/security/util/DerOutputStream;
           11   17     3     tmp  Lsun/security/util/DerOutputStream;
    Exceptions:
      throws java.io.IOException, java.security.cert.CertificateEncodingException
    MethodParameters:
      Name  Flags
      out   

  private void checkPair();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertificatePair this
         0: .line 297
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            ifnull 1
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            ifnonnull 2
         1: .line 298
      StackMap locals:
      StackMap stack:
            return
         2: .line 304
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 1 /* fwSubject */
        start local 1 // javax.security.auth.x500.X500Principal fwSubject
         3: .line 305
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 2 /* fwIssuer */
        start local 2 // javax.security.auth.x500.X500Principal fwIssuer
         4: .line 306
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 3 /* rvSubject */
        start local 3 // javax.security.auth.x500.X500Principal rvSubject
         5: .line 307
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 4 /* rvIssuer */
        start local 4 // javax.security.auth.x500.X500Principal rvIssuer
         6: .line 308
            aload 2 /* fwIssuer */
            aload 3 /* rvSubject */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifeq 7
            aload 4 /* rvIssuer */
            aload 1 /* fwSubject */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 8
         7: .line 309
      StackMap locals: sun.security.provider.certpath.X509CertificatePair javax.security.auth.x500.X500Principal javax.security.auth.x500.X500Principal javax.security.auth.x500.X500Principal javax.security.auth.x500.X500Principal
      StackMap stack:
            new java.security.cert.CertificateException
            dup
            ldc "subject and issuer names in forward and reverse certificates do not match"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 315
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 5 /* pk */
        start local 5 // java.security.PublicKey pk
         9: .line 316
            aload 5 /* pk */
            instanceof java.security.interfaces.DSAPublicKey
            ifeq 11
        10: .line 317
            aload 5 /* pk */
            checkcast java.security.interfaces.DSAPublicKey
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            ifnull 12
        11: .line 318
      StackMap locals: java.security.PublicKey
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            aload 5 /* pk */
            invokevirtual java.security.cert.X509Certificate.verify:(Ljava/security/PublicKey;)V
        12: .line 320
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.forward:Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 5 /* pk */
        13: .line 321
            aload 5 /* pk */
            instanceof java.security.interfaces.DSAPublicKey
            ifeq 15
        14: .line 322
            aload 5 /* pk */
            checkcast java.security.interfaces.DSAPublicKey
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            ifnull 21
        15: .line 323
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertificatePair.reverse:Ljava/security/cert/X509Certificate;
            aload 5 /* pk */
            invokevirtual java.security.cert.X509Certificate.verify:(Ljava/security/PublicKey;)V
        end local 5 // java.security.PublicKey pk
        16: .line 325
            goto 21
      StackMap locals: sun.security.provider.certpath.X509CertificatePair javax.security.auth.x500.X500Principal javax.security.auth.x500.X500Principal javax.security.auth.x500.X500Principal javax.security.auth.x500.X500Principal
      StackMap stack: java.security.GeneralSecurityException
        17: astore 5 /* e */
        start local 5 // java.security.GeneralSecurityException e
        18: .line 326
            new java.security.cert.CertificateException
            dup
            new java.lang.StringBuilder
            dup
            ldc "invalid signature: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        19: .line 327
            aload 5 /* e */
            invokevirtual java.security.GeneralSecurityException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 326
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.security.GeneralSecurityException e
        21: .line 329
      StackMap locals:
      StackMap stack:
            return
        end local 4 // javax.security.auth.x500.X500Principal rvIssuer
        end local 3 // javax.security.auth.x500.X500Principal rvSubject
        end local 2 // javax.security.auth.x500.X500Principal fwIssuer
        end local 1 // javax.security.auth.x500.X500Principal fwSubject
        end local 0 // sun.security.provider.certpath.X509CertificatePair this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   22     0       this  Lsun/security/provider/certpath/X509CertificatePair;
            3   22     1  fwSubject  Ljavax/security/auth/x500/X500Principal;
            4   22     2   fwIssuer  Ljavax/security/auth/x500/X500Principal;
            5   22     3  rvSubject  Ljavax/security/auth/x500/X500Principal;
            6   22     4   rvIssuer  Ljavax/security/auth/x500/X500Principal;
            9   16     5         pk  Ljava/security/PublicKey;
           18   21     5          e  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
           8    16      17  Class java.security.GeneralSecurityException
    Exceptions:
      throws java.security.cert.CertificateException
}
SourceFile: "X509CertificatePair.java"
InnerClasses:
  public EqualByteArray = sun.security.util.Cache$EqualByteArray of sun.security.util.Cache