public class sun.security.provider.certpath.X509CertPath extends java.security.cert.CertPath
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.provider.certpath.X509CertPath
  super_class: java.security.cert.CertPath
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 4989800333263052980

  private java.util.List<java.security.cert.X509Certificate> certs;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/List<Ljava/security/cert/X509Certificate;>;

  private static final java.lang.String COUNT_ENCODING;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "count"

  private static final java.lang.String PKCS7_ENCODING;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "PKCS7"

  private static final java.lang.String PKIPATH_ENCODING;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "PkiPath"

  private static final java.util.Collection<java.lang.String> encodingList;
    descriptor: Ljava/util/Collection;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Collection<Ljava/lang/String;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 86
            new java.util.ArrayList
            dup
            iconst_2
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 0 /* list */
        start local 0 // java.util.List list
         1: .line 87
            aload 0 /* list */
            ldc "PkiPath"
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         2: .line 88
            aload 0 /* list */
            ldc "PKCS7"
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         3: .line 89
            aload 0 /* list */
            invokestatic java.util.Collections.unmodifiableCollection:(Ljava/util/Collection;)Ljava/util/Collection;
            putstatic sun.security.provider.certpath.X509CertPath.encodingList:Ljava/util/Collection;
        end local 0 // java.util.List list
         4: .line 90
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            1    4     0  list  Ljava/util/List<Ljava/lang/String;>;

  public void <init>(java.util.List<? extends java.security.cert.Certificate>);
    descriptor: (Ljava/util/List;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertPath this
        start local 1 // java.util.List certs
         0: .line 105
            aload 0 /* this */
            ldc "X.509"
            invokespecial java.security.cert.CertPath.<init>:(Ljava/lang/String;)V
         1: .line 114
            aload 1 /* certs */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 9
      StackMap locals: sun.security.provider.certpath.X509CertPath java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 2 /* obj */
        start local 2 // java.lang.Object obj
         3: .line 115
            aload 2 /* obj */
            instanceof java.security.cert.X509Certificate
            ifne 9
         4: .line 116
            new java.security.cert.CertificateException
            dup
         5: .line 117
            new java.lang.StringBuilder
            dup
            ldc "List is not all X509Certificates: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 118
            aload 2 /* obj */
            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;
         7: .line 117
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 116
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.Object obj
         9: .line 114
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        10: .line 126
            aload 0 /* this */
        11: .line 127
            new java.util.ArrayList
            dup
            aload 1 /* certs */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
        12: .line 126
            invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
            putfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
        13: .line 128
            return
        end local 1 // java.util.List certs
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   14     0   this  Lsun/security/provider/certpath/X509CertPath;
            0   14     1  certs  Ljava/util/List<+Ljava/security/cert/Certificate;>;
            3    9     2    obj  Ljava/lang/Object;
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Ljava/util/List<+Ljava/security/cert/Certificate;>;)V
    MethodParameters:
       Name  Flags
      certs  

  public void <init>(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertPath this
        start local 1 // java.io.InputStream is
         0: .line 139
            aload 0 /* this */
            aload 1 /* is */
            ldc "PkiPath"
            invokespecial sun.security.provider.certpath.X509CertPath.<init>:(Ljava/io/InputStream;Ljava/lang/String;)V
         1: .line 140
            return
        end local 1 // java.io.InputStream is
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/provider/certpath/X509CertPath;
            0    2     1    is  Ljava/io/InputStream;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
      Name  Flags
      is    

  public void <init>(java.io.InputStream, java.lang.String);
    descriptor: (Ljava/io/InputStream;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // sun.security.provider.certpath.X509CertPath this
        start local 1 // java.io.InputStream is
        start local 2 // java.lang.String encoding
         0: .line 154
            aload 0 /* this */
            ldc "X.509"
            invokespecial java.security.cert.CertPath.<init>:(Ljava/lang/String;)V
         1: .line 156
            aload 2 /* encoding */
            dup
            astore 3
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 2
             76183020: 2
           1148619507: 3
              default: 8
          }
      StackMap locals: sun.security.provider.certpath.X509CertPath java.io.InputStream java.lang.String java.lang.String
      StackMap stack:
         2: aload 3
            ldc "PKCS7"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
            goto 8
      StackMap locals:
      StackMap stack:
         3: aload 3
            ldc "PkiPath"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 4
            goto 8
         4: .line 158
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* is */
            invokestatic sun.security.provider.certpath.X509CertPath.parsePKIPATH:(Ljava/io/InputStream;)Ljava/util/List;
            putfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
         5: .line 159
            goto 9
         6: .line 161
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* is */
            invokestatic sun.security.provider.certpath.X509CertPath.parsePKCS7:(Ljava/io/InputStream;)Ljava/util/List;
            putfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
         7: .line 162
            goto 9
         8: .line 164
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateException
            dup
            ldc "unsupported encoding"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 166
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String encoding
        end local 1 // java.io.InputStream is
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   10     0      this  Lsun/security/provider/certpath/X509CertPath;
            0   10     1        is  Ljava/io/InputStream;
            0   10     2  encoding  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      is        
      encoding  

  private static java.util.List<java.security.cert.X509Certificate> parsePKIPATH(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=6, args_size=1
        start local 0 // java.io.InputStream is
         0: .line 178
            aconst_null
            astore 1 /* certList */
        start local 1 // java.util.List certList
         1: .line 179
            aconst_null
            astore 2 /* certFac */
        start local 2 // java.security.cert.CertificateFactory certFac
         2: .line 181
            aload 0 /* is */
            ifnonnull 4
         3: .line 182
            new java.security.cert.CertificateException
            dup
            ldc "input stream is null"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 186
      StackMap locals: java.util.List java.security.cert.CertificateFactory
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 0 /* is */
            invokestatic sun.security.provider.certpath.X509CertPath.readAllBytes:(Ljava/io/InputStream;)[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 3 /* dis */
        start local 3 // sun.security.util.DerInputStream dis
         5: .line 187
            aload 3 /* dis */
            iconst_3
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 4 /* seq */
        start local 4 // sun.security.util.DerValue[] seq
         6: .line 188
            aload 4 /* seq */
            arraylength
            ifne 9
         7: .line 189
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
         8: areturn
         9: .line 192
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            ldc "X.509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 2 /* certFac */
        10: .line 193
            new java.util.ArrayList
            dup
            aload 4 /* seq */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 1 /* certList */
        11: .line 196
            aload 4 /* seq */
            arraylength
            iconst_1
            isub
            istore 5 /* i */
        start local 5 // int i
        12: goto 17
        13: .line 197
      StackMap locals: int
      StackMap stack:
            aload 1 /* certList */
            aload 2 /* certFac */
        14: .line 198
            new java.io.ByteArrayInputStream
            dup
            aload 4 /* seq */
            iload 5 /* i */
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
        15: .line 197
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        16: .line 196
            iinc 5 /* i */ -1
      StackMap locals:
      StackMap stack:
        17: iload 5 /* i */
            ifge 13
        end local 5 // int i
        18: .line 201
            aload 1 /* certList */
            invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
        19: areturn
        end local 4 // sun.security.util.DerValue[] seq
        end local 3 // sun.security.util.DerInputStream dis
        20: .line 203
      StackMap locals: java.io.InputStream java.util.List java.security.cert.CertificateFactory
      StackMap stack: java.io.IOException
            astore 3 /* ioe */
        start local 3 // java.io.IOException ioe
        21: .line 204
            new java.security.cert.CertificateException
            dup
            new java.lang.StringBuilder
            dup
            ldc "IOException parsing PkiPath data: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        22: .line 205
            aload 3 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 3 /* ioe */
        23: .line 204
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.io.IOException ioe
        end local 2 // java.security.cert.CertificateFactory certFac
        end local 1 // java.util.List certList
        end local 0 // java.io.InputStream is
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   24     0        is  Ljava/io/InputStream;
            1   24     1  certList  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
            2   24     2   certFac  Ljava/security/cert/CertificateFactory;
            5   20     3       dis  Lsun/security/util/DerInputStream;
            6   20     4       seq  [Lsun/security/util/DerValue;
           12   18     5         i  I
           21   24     3       ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           4     8      20  Class java.io.IOException
           9    19      20  Class java.io.IOException
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Ljava/io/InputStream;)Ljava/util/List<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
      Name  Flags
      is    

  private static java.util.List<java.security.cert.X509Certificate> parsePKCS7(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // java.io.InputStream is
         0: .line 221
            aload 0 /* is */
            ifnonnull 2
         1: .line 222
            new java.security.cert.CertificateException
            dup
            ldc "input stream is null"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 226
      StackMap locals:
      StackMap stack:
            aload 0 /* is */
            invokevirtual java.io.InputStream.markSupported:()Z
            ifne 4
         3: .line 229
            new java.io.ByteArrayInputStream
            dup
            aload 0 /* is */
            invokestatic sun.security.provider.certpath.X509CertPath.readAllBytes:(Ljava/io/InputStream;)[B
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 0 /* is */
         4: .line 231
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs.PKCS7
            dup
            aload 0 /* is */
            invokespecial sun.security.pkcs.PKCS7.<init>:(Ljava/io/InputStream;)V
            astore 2 /* pkcs7 */
        start local 2 // sun.security.pkcs.PKCS7 pkcs7
         5: .line 233
            aload 2 /* pkcs7 */
            invokevirtual sun.security.pkcs.PKCS7.getCertificates:()[Ljava/security/cert/X509Certificate;
            astore 3 /* certArray */
        start local 3 // java.security.cert.X509Certificate[] certArray
         6: .line 235
            aload 3 /* certArray */
            ifnull 9
         7: .line 236
            aload 3 /* certArray */
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            astore 1 /* certList */
        start local 1 // java.util.List certList
         8: .line 237
            goto 15
        end local 1 // java.util.List certList
         9: .line 239
      StackMap locals: java.io.InputStream top sun.security.pkcs.PKCS7 java.security.cert.X509Certificate[]
      StackMap stack:
            new java.util.ArrayList
            dup
            iconst_0
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 1 /* certList */
        end local 3 // java.security.cert.X509Certificate[] certArray
        end local 2 // sun.security.pkcs.PKCS7 pkcs7
        start local 1 // java.util.List certList
        10: .line 241
            goto 15
        end local 1 // java.util.List certList
      StackMap locals: java.io.InputStream
      StackMap stack: java.io.IOException
        11: astore 2 /* ioe */
        start local 2 // java.io.IOException ioe
        12: .line 242
            new java.security.cert.CertificateException
            dup
            new java.lang.StringBuilder
            dup
            ldc "IOException parsing PKCS7 data: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        13: .line 243
            aload 2 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 242
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.io.IOException ioe
        start local 1 // java.util.List certList
        15: .line 249
      StackMap locals: java.util.List
      StackMap stack:
            aload 1 /* certList */
            invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
            areturn
        end local 1 // java.util.List certList
        end local 0 // java.io.InputStream is
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   16     0         is  Ljava/io/InputStream;
            8    9     1   certList  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
           10   11     1   certList  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
           15   16     1   certList  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
            5   10     2      pkcs7  Lsun/security/pkcs/PKCS7;
            6   10     3  certArray  [Ljava/security/cert/X509Certificate;
           12   15     2        ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           2    10      11  Class java.io.IOException
    Exceptions:
      throws java.security.cert.CertificateException
    Signature: (Ljava/io/InputStream;)Ljava/util/List<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
      Name  Flags
      is    

  private static byte[] readAllBytes(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // java.io.InputStream is
         0: .line 259
            sipush 8192
            newarray 8
            astore 1 /* buffer */
        start local 1 // byte[] buffer
         1: .line 260
            new java.io.ByteArrayOutputStream
            dup
            sipush 2048
            invokespecial java.io.ByteArrayOutputStream.<init>:(I)V
            astore 2 /* baos */
        start local 2 // java.io.ByteArrayOutputStream baos
         2: .line 262
            goto 4
        start local 3 // int n
         3: .line 263
      StackMap locals: byte[] java.io.ByteArrayOutputStream int
      StackMap stack:
            aload 2 /* baos */
            aload 1 /* buffer */
            iconst_0
            iload 3 /* n */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
        end local 3 // int n
         4: .line 262
      StackMap locals:
      StackMap stack:
            aload 0 /* is */
            aload 1 /* buffer */
            invokevirtual java.io.InputStream.read:([B)I
            dup
            istore 3 /* n */
        start local 3 // int n
         5: iconst_m1
            if_icmpne 3
         6: .line 265
            aload 2 /* baos */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            areturn
        end local 3 // int n
        end local 2 // java.io.ByteArrayOutputStream baos
        end local 1 // byte[] buffer
        end local 0 // java.io.InputStream is
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0      is  Ljava/io/InputStream;
            1    7     1  buffer  [B
            2    7     2    baos  Ljava/io/ByteArrayOutputStream;
            3    4     3       n  I
            5    7     3       n  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      is    

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertPath this
         0: .line 278
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.X509CertPath.encodePKIPATH:()[B
            areturn
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/X509CertPath;
    Exceptions:
      throws java.security.cert.CertificateEncodingException

  private byte[] encodePKIPATH();
    descriptor: ()[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertPath this
         0: .line 289
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            invokeinterface java.util.List.listIterator:(I)Ljava/util/ListIterator;
            astore 1 /* li */
        start local 1 // java.util.ListIterator li
         1: .line 291
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* bytes */
        start local 2 // sun.security.util.DerOutputStream bytes
         2: .line 294
            goto 10
         3: .line 295
      StackMap locals: java.util.ListIterator sun.security.util.DerOutputStream
      StackMap stack:
            aload 1 /* li */
            invokeinterface java.util.ListIterator.previous:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 3 /* cert */
        start local 3 // java.security.cert.X509Certificate cert
         4: .line 297
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
            aload 3 /* cert */
            invokeinterface java.util.List.lastIndexOf:(Ljava/lang/Object;)I
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
            aload 3 /* cert */
            invokeinterface java.util.List.indexOf:(Ljava/lang/Object;)I
            if_icmpeq 8
         5: .line 298
            new java.security.cert.CertificateEncodingException
            dup
         6: .line 299
            ldc "Duplicate Certificate"
         7: .line 298
            invokespecial java.security.cert.CertificateEncodingException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 302
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 3 /* cert */
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            astore 4 /* encoded */
        start local 4 // byte[] encoded
         9: .line 303
            aload 2 /* bytes */
            aload 4 /* encoded */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        end local 4 // byte[] encoded
        end local 3 // java.security.cert.X509Certificate cert
        10: .line 294
      StackMap locals:
      StackMap stack:
            aload 1 /* li */
            invokeinterface java.util.ListIterator.hasPrevious:()Z
            ifne 3
        11: .line 307
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* derout */
        start local 3 // sun.security.util.DerOutputStream derout
        12: .line 308
            aload 3 /* derout */
            bipush 48
            aload 2 /* bytes */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        13: .line 309
            aload 3 /* derout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
        14: areturn
        end local 3 // sun.security.util.DerOutputStream derout
        end local 2 // sun.security.util.DerOutputStream bytes
        15: .line 311
      StackMap locals: sun.security.provider.certpath.X509CertPath java.util.ListIterator
      StackMap stack: java.io.IOException
            astore 2 /* ioe */
        start local 2 // java.io.IOException ioe
        16: .line 312
            new java.security.cert.CertificateEncodingException
            dup
            new java.lang.StringBuilder
            dup
            ldc "IOException encoding PkiPath data: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        17: .line 313
            aload 2 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* ioe */
        18: .line 312
            invokespecial java.security.cert.CertificateEncodingException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException ioe
        end local 1 // java.util.ListIterator li
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   19     0     this  Lsun/security/provider/certpath/X509CertPath;
            1   19     1       li  Ljava/util/ListIterator<Ljava/security/cert/X509Certificate;>;
            2   15     2    bytes  Lsun/security/util/DerOutputStream;
            4   10     3     cert  Ljava/security/cert/X509Certificate;
            9   10     4  encoded  [B
           12   15     3   derout  Lsun/security/util/DerOutputStream;
           16   19     2      ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1    14      15  Class java.io.IOException
    Exceptions:
      throws java.security.cert.CertificateEncodingException

  private byte[] encodePKCS7();
    descriptor: ()[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=4, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertPath this
         0: .line 324
            new sun.security.pkcs.PKCS7
            dup
            iconst_0
            anewarray sun.security.x509.AlgorithmId
         1: .line 325
            new sun.security.pkcs.ContentInfo
            dup
            getstatic sun.security.pkcs.ContentInfo.DATA_OID:Lsun/security/util/ObjectIdentifier;
            aconst_null
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/ObjectIdentifier;Lsun/security/util/DerValue;)V
         2: .line 326
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            anewarray java.security.cert.X509Certificate
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate[]
         3: .line 327
            iconst_0
            anewarray sun.security.pkcs.SignerInfo
         4: .line 324
            invokespecial sun.security.pkcs.PKCS7.<init>:([Lsun/security/x509/AlgorithmId;Lsun/security/pkcs/ContentInfo;[Ljava/security/cert/X509Certificate;[Lsun/security/pkcs/SignerInfo;)V
            astore 1 /* p7 */
        start local 1 // sun.security.pkcs.PKCS7 p7
         5: .line 328
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* derout */
        start local 2 // sun.security.util.DerOutputStream derout
         6: .line 330
            aload 1 /* p7 */
            aload 2 /* derout */
            invokevirtual sun.security.pkcs.PKCS7.encodeSignedData:(Lsun/security/util/DerOutputStream;)V
         7: .line 331
            goto 10
      StackMap locals: sun.security.provider.certpath.X509CertPath sun.security.pkcs.PKCS7 sun.security.util.DerOutputStream
      StackMap stack: java.io.IOException
         8: astore 3 /* ioe */
        start local 3 // java.io.IOException ioe
         9: .line 332
            new java.security.cert.CertificateEncodingException
            dup
            aload 3 /* ioe */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokespecial java.security.cert.CertificateEncodingException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // java.io.IOException ioe
        10: .line 334
      StackMap locals:
      StackMap stack:
            aload 2 /* derout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 2 // sun.security.util.DerOutputStream derout
        end local 1 // sun.security.pkcs.PKCS7 p7
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    this  Lsun/security/provider/certpath/X509CertPath;
            5   11     1      p7  Lsun/security/pkcs/PKCS7;
            6   11     2  derout  Lsun/security/util/DerOutputStream;
            9   10     3     ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           6     7       8  Class java.io.IOException
    Exceptions:
      throws java.security.cert.CertificateEncodingException

  public byte[] getEncoded(java.lang.String);
    descriptor: (Ljava/lang/String;)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.provider.certpath.X509CertPath this
        start local 1 // java.lang.String encoding
         0: .line 349
            aload 1 /* encoding */
            dup
            astore 2
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 2
             76183020: 1
           1148619507: 2
              default: 5
          }
      StackMap locals: java.lang.String
      StackMap stack:
         1: aload 2
            ldc "PKCS7"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 4
            goto 5
      StackMap locals:
      StackMap stack:
         2: aload 2
            ldc "PkiPath"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 3
            goto 5
         3: .line 351
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.X509CertPath.encodePKIPATH:()[B
            areturn
         4: .line 353
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.X509CertPath.encodePKCS7:()[B
            areturn
         5: .line 355
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertificateEncodingException
            dup
            ldc "unsupported encoding"
            invokespecial java.security.cert.CertificateEncodingException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.String encoding
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lsun/security/provider/certpath/X509CertPath;
            0    6     1  encoding  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertificateEncodingException
    MethodParameters:
          Name  Flags
      encoding  

  public static java.util.Iterator<java.lang.String> getEncodingsStatic();
    descriptor: ()Ljava/util/Iterator;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 367
            getstatic sun.security.provider.certpath.X509CertPath.encodingList:Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Signature: ()Ljava/util/Iterator<Ljava/lang/String;>;

  public java.util.Iterator<java.lang.String> getEncodings();
    descriptor: ()Ljava/util/Iterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertPath this
         0: .line 383
            invokestatic sun.security.provider.certpath.X509CertPath.getEncodingsStatic:()Ljava/util/Iterator;
            areturn
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/X509CertPath;
    Signature: ()Ljava/util/Iterator<Ljava/lang/String;>;

  public java.util.List<java.security.cert.X509Certificate> getCertificates();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.X509CertPath this
         0: .line 395
            aload 0 /* this */
            getfield sun.security.provider.certpath.X509CertPath.certs:Ljava/util/List;
            areturn
        end local 0 // sun.security.provider.certpath.X509CertPath this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/X509CertPath;
    Signature: ()Ljava/util/List<Ljava/security/cert/X509Certificate;>;
}
SourceFile: "X509CertPath.java"