public final class sun.security.provider.certpath.SunCertPathBuilder extends java.security.cert.CertPathBuilderSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.provider.certpath.SunCertPathBuilder
  super_class: java.security.cert.CertPathBuilderSpi
{
  private static final sun.security.util.Debug debug;
    descriptor: Lsun/security/util/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private sun.security.provider.certpath.PKIX$BuilderParams buildParams;
    descriptor: Lsun/security/provider/certpath/PKIX$BuilderParams;
    flags: (0x0002) ACC_PRIVATE

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

  private boolean pathCompleted;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

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

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

  private java.security.PublicKey finalPublicKey;
    descriptor: Ljava/security/PublicKey;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 72
            ldc "certpath"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
         0: .line 89
            aload 0 /* this */
            invokespecial java.security.cert.CertPathBuilderSpi.<init>:()V
         1: .line 79
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
         2: .line 91
            aload 0 /* this */
            ldc "X.509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            putfield sun.security.provider.certpath.SunCertPathBuilder.cf:Ljava/security/cert/CertificateFactory;
         3: .line 92
            goto 6
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder
      StackMap stack: java.security.cert.CertificateException
         4: astore 1 /* e */
        start local 1 // java.security.cert.CertificateException e
         5: .line 93
            new java.security.cert.CertPathBuilderException
            dup
            aload 1 /* e */
            invokespecial java.security.cert.CertPathBuilderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.cert.CertificateException e
         6: .line 95
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/provider/certpath/SunCertPathBuilder;
            5    6     1     e  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
           2     3       4  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.cert.CertPathBuilderException

  public sun.security.provider.certpath.CertPathChecker engineGetRevocationChecker();
    descriptor: ()Lsun/security/provider/certpath/CertPathChecker;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
         0: .line 98
            new sun.security.provider.certpath.RevocationChecker
            dup
            invokespecial sun.security.provider.certpath.RevocationChecker.<init>:()V
            areturn
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/SunCertPathBuilder;

  public java.security.cert.CertPathBuilderResult engineBuild(java.security.cert.CertPathParameters);
    descriptor: (Ljava/security/cert/CertPathParameters;)Ljava/security/cert/CertPathBuilderResult;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // java.security.cert.CertPathParameters params
         0: .line 125
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 126
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.engineBuild("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* params */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 129
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* params */
            invokestatic sun.security.provider.certpath.PKIX.checkBuilderParams:(Ljava/security/cert/CertPathParameters;)Lsun/security/provider/certpath/PKIX$BuilderParams;
            putfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
         3: .line 130
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.build:()Ljava/security/cert/PKIXCertPathBuilderResult;
            areturn
        end local 1 // java.security.cert.CertPathParameters params
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0    4     1  params  Ljava/security/cert/CertPathParameters;
    Exceptions:
      throws java.security.cert.CertPathBuilderException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      params  

  private java.security.cert.PKIXCertPathBuilderResult build();
    descriptor: ()Ljava/security/cert/PKIXCertPathBuilderResult;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
         0: .line 134
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* adjList */
        start local 1 // java.util.List adjList
         1: .line 135
            aload 0 /* this */
            iconst_0
            aload 1 /* adjList */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildCertPath:(ZLjava/util/List;)Ljava/security/cert/PKIXCertPathBuilderResult;
            astore 2 /* result */
        start local 2 // java.security.cert.PKIXCertPathBuilderResult result
         2: .line 136
            aload 2 /* result */
            ifnonnull 11
         3: .line 137
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 5
         4: .line 138
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.engineBuild: 2nd pass"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         5: .line 141
      StackMap locals: java.util.List java.security.cert.PKIXCertPathBuilderResult
      StackMap stack:
            aload 1 /* adjList */
            invokeinterface java.util.List.clear:()V
         6: .line 142
            aload 0 /* this */
            iconst_1
            aload 1 /* adjList */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildCertPath:(ZLjava/util/List;)Ljava/security/cert/PKIXCertPathBuilderResult;
            astore 2 /* result */
         7: .line 143
            aload 2 /* result */
            ifnonnull 11
         8: .line 144
            new sun.security.provider.certpath.SunCertPathBuilderException
            dup
            ldc "unable to find valid certification path to requested target"
         9: .line 146
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 1 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        10: .line 144
            invokespecial sun.security.provider.certpath.SunCertPathBuilderException.<init>:(Ljava/lang/String;Lsun/security/provider/certpath/AdjacencyList;)V
            athrow
        11: .line 149
      StackMap locals:
      StackMap stack:
            aload 2 /* result */
            areturn
        end local 2 // java.security.cert.PKIXCertPathBuilderResult result
        end local 1 // java.util.List adjList
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   12     0     this  Lsun/security/provider/certpath/SunCertPathBuilder;
            1   12     1  adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            2   12     2   result  Ljava/security/cert/PKIXCertPathBuilderResult;
    Exceptions:
      throws java.security.cert.CertPathBuilderException

  private java.security.cert.PKIXCertPathBuilderResult buildCertPath(boolean, java.util.List<java.util.List<sun.security.provider.certpath.Vertex>>);
    descriptor: (ZLjava/util/List;)Ljava/security/cert/PKIXCertPathBuilderResult;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=5, args_size=3
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // boolean searchAllCertStores
        start local 2 // java.util.List adjList
         0: .line 157
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
         1: .line 158
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
         2: .line 159
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
         3: .line 160
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
         4: .line 161
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 3 /* certPathList */
        start local 3 // java.util.LinkedList certPathList
         5: .line 163
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.buildForward:()Z
            ifeq 8
         6: .line 164
            aload 0 /* this */
            aload 2 /* adjList */
            aload 3 /* certPathList */
            iload 1 /* searchAllCertStores */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildForward:(Ljava/util/List;Ljava/util/LinkedList;Z)V
         7: .line 165
            goto 18
         8: .line 166
      StackMap locals: java.util.LinkedList
      StackMap stack:
            aload 0 /* this */
            aload 2 /* adjList */
            aload 3 /* certPathList */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildReverse:(Ljava/util/List;Ljava/util/LinkedList;)V
         9: .line 168
            goto 18
      StackMap locals:
      StackMap stack: java.lang.Exception
        10: astore 4 /* e */
        start local 4 // java.lang.Exception e
        11: .line 169
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 14
        12: .line 170
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.engineBuild() exception in build"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 172
            aload 4 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        14: .line 174
      StackMap locals: java.lang.Exception
      StackMap stack:
            new sun.security.provider.certpath.SunCertPathBuilderException
            dup
            ldc "unable to find valid certification path to requested target"
        15: .line 175
            aload 4 /* e */
        16: .line 176
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 2 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        17: .line 174
            invokespecial sun.security.provider.certpath.SunCertPathBuilderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;Lsun/security/provider/certpath/AdjacencyList;)V
            athrow
        end local 4 // java.lang.Exception e
        18: .line 181
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 36
        19: .line 182
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 21
        20: .line 183
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.engineBuild() pathCompleted"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        21: .line 189
      StackMap locals:
      StackMap stack:
            aload 3 /* certPathList */
            invokestatic java.util.Collections.reverse:(Ljava/util/List;)V
        22: .line 191
            new sun.security.provider.certpath.SunCertPathBuilderResult
            dup
        23: .line 192
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.cf:Ljava/security/cert/CertificateFactory;
            aload 3 /* certPathList */
            invokevirtual java.security.cert.CertificateFactory.generateCertPath:(Ljava/util/List;)Ljava/security/cert/CertPath;
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        24: .line 193
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        25: .line 194
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 2 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        26: .line 191
            invokespecial sun.security.provider.certpath.SunCertPathBuilderResult.<init>:(Ljava/security/cert/CertPath;Ljava/security/cert/TrustAnchor;Ljava/security/cert/PolicyNode;Ljava/security/PublicKey;Lsun/security/provider/certpath/AdjacencyList;)V
        27: areturn
        28: .line 196
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
            astore 4 /* e */
        start local 4 // java.security.cert.CertificateException e
        29: .line 197
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 32
        30: .line 198
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.engineBuild() exception in wrap-up"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        31: .line 200
            aload 4 /* e */
            invokevirtual java.security.cert.CertificateException.printStackTrace:()V
        32: .line 202
      StackMap locals: java.security.cert.CertificateException
      StackMap stack:
            new sun.security.provider.certpath.SunCertPathBuilderException
            dup
            ldc "unable to find valid certification path to requested target"
        33: .line 203
            aload 4 /* e */
        34: .line 204
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 2 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        35: .line 202
            invokespecial sun.security.provider.certpath.SunCertPathBuilderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;Lsun/security/provider/certpath/AdjacencyList;)V
            athrow
        end local 4 // java.security.cert.CertificateException e
        36: .line 207
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 3 // java.util.LinkedList certPathList
        end local 2 // java.util.List adjList
        end local 1 // boolean searchAllCertStores
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   37     0                 this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   37     1  searchAllCertStores  Z
            0   37     2              adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            5   37     3         certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
           11   18     4                    e  Ljava/lang/Exception;
           29   36     4                    e  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
           5     9      10  Class java.security.GeneralSecurityException
           5     9      10  Class java.io.IOException
          18    27      28  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.cert.CertPathBuilderException
    Signature: (ZLjava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;)Ljava/security/cert/PKIXCertPathBuilderResult;
    MethodParameters:
                     Name  Flags
      searchAllCertStores  
      adjList              

  private void buildReverse(java.util.List<java.util.List<sun.security.provider.certpath.Vertex>>, java.util.LinkedList<java.security.cert.X509Certificate>);
    descriptor: (Ljava/util/List;Ljava/util/LinkedList;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=9, args_size=3
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // java.util.List adjacencyList
        start local 2 // java.util.LinkedList certPathList
         0: .line 217
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 5
         1: .line 218
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.buildReverse()..."
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 219
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.buildReverse() InitialPolicies: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         3: .line 220
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.initialPolicies:()Ljava/util/Set;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         4: .line 219
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         5: .line 223
      StackMap locals:
      StackMap stack:
            new sun.security.provider.certpath.ReverseState
            dup
            invokespecial sun.security.provider.certpath.ReverseState.<init>:()V
            astore 3 /* currentState */
        start local 3 // sun.security.provider.certpath.ReverseState currentState
         6: .line 225
            aload 1 /* adjacencyList */
            invokeinterface java.util.List.clear:()V
         7: .line 226
            aload 1 /* adjacencyList */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         8: .line 232
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.trustAnchors:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4 /* iter */
        start local 4 // java.util.Iterator iter
         9: .line 233
            goto 40
        10: .line 234
      StackMap locals: sun.security.provider.certpath.ReverseState java.util.Iterator
      StackMap stack:
            aload 4 /* iter */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.TrustAnchor
            astore 5 /* anchor */
        start local 5 // java.security.cert.TrustAnchor anchor
        11: .line 237
            aload 5 /* anchor */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.targetCertConstraints:()Ljava/security/cert/CertSelector;
            invokestatic sun.security.provider.certpath.SunCertPathBuilder.anchorIsTarget:(Ljava/security/cert/TrustAnchor;Ljava/security/cert/CertSelector;)Z
            ifeq 16
        12: .line 238
            aload 0 /* this */
            aload 5 /* anchor */
            putfield sun.security.provider.certpath.SunCertPathBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        13: .line 239
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
        14: .line 240
            aload 0 /* this */
            aload 5 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        15: .line 241
            goto 41
        16: .line 245
      StackMap locals: java.security.cert.TrustAnchor
      StackMap stack:
            aload 5 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            astore 6 /* trustedCert */
        start local 6 // java.security.cert.X509Certificate trustedCert
        17: .line 246
            aload 6 /* trustedCert */
            ifnull 18
            aload 6 /* trustedCert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            goto 19
        18: .line 247
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 5 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
        19: .line 246
      StackMap locals:
      StackMap stack: java.security.PublicKey
            astore 7 /* pubKey */
        start local 7 // java.security.PublicKey pubKey
        20: .line 249
            aload 7 /* pubKey */
            invokestatic sun.security.provider.certpath.PKIX.isDSAPublicKeyWithoutParams:(Ljava/security/PublicKey;)Z
            ifeq 22
        21: .line 250
            goto 40
        22: .line 254
      StackMap locals: java.security.PublicKey
      StackMap stack:
            aload 3 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.ReverseState.initState:(Lsun/security/provider/certpath/PKIX$BuilderParams;)V
        23: .line 255
            aload 3 /* currentState */
            aload 5 /* anchor */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.ReverseState.updateState:(Ljava/security/cert/TrustAnchor;Lsun/security/provider/certpath/PKIX$BuilderParams;)V
        24: .line 257
            aload 3 /* currentState */
            new sun.security.provider.certpath.AlgorithmChecker
            dup
            aload 5 /* anchor */
        25: .line 258
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.date:()Ljava/util/Date;
        26: .line 259
            aconst_null
            invokespecial sun.security.provider.certpath.AlgorithmChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/util/Date;Ljava/lang/String;)V
        27: .line 257
            putfield sun.security.provider.certpath.ReverseState.algorithmChecker:Lsun/security/provider/certpath/AlgorithmChecker;
        28: .line 260
            aload 3 /* currentState */
            new sun.security.provider.certpath.UntrustedChecker
            dup
            invokespecial sun.security.provider.certpath.UntrustedChecker.<init>:()V
            putfield sun.security.provider.certpath.ReverseState.untrustedChecker:Lsun/security/provider/certpath/UntrustedChecker;
        29: .line 262
            aload 0 /* this */
            aconst_null
            aload 3 /* currentState */
        30: .line 263
            new sun.security.provider.certpath.ReverseBuilder
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokespecial sun.security.provider.certpath.ReverseBuilder.<init>:(Lsun/security/provider/certpath/PKIX$BuilderParams;)V
        31: .line 264
            aload 1 /* adjacencyList */
            aload 2 /* certPathList */
        32: .line 262
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.depthFirstSearchReverse:(Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ReverseState;Lsun/security/provider/certpath/ReverseBuilder;Ljava/util/List;Ljava/util/LinkedList;)V
        33: .line 265
            goto 38
      StackMap locals:
      StackMap stack: java.lang.Exception
        34: astore 8 /* e */
        start local 8 // java.lang.Exception e
        35: .line 267
            aload 4 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifeq 37
        36: .line 268
            goto 40
        37: .line 270
      StackMap locals: java.lang.Exception
      StackMap stack:
            aload 8 /* e */
            athrow
        end local 8 // java.lang.Exception e
        38: .line 274
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 40
        39: .line 275
            goto 41
        end local 7 // java.security.PublicKey pubKey
        end local 6 // java.security.cert.X509Certificate trustedCert
        end local 5 // java.security.cert.TrustAnchor anchor
        40: .line 233
      StackMap locals:
      StackMap stack:
            aload 4 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        41: .line 279
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 46
        42: .line 280
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.buildReverse() returned from depthFirstSearchReverse()"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        43: .line 282
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.buildReverse() certPathList.size: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        44: .line 283
            aload 2 /* certPathList */
            invokevirtual java.util.LinkedList.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        45: .line 282
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        46: .line 285
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.util.Iterator iter
        end local 3 // sun.security.provider.certpath.ReverseState currentState
        end local 2 // java.util.LinkedList certPathList
        end local 1 // java.util.List adjacencyList
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   47     0           this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   47     1  adjacencyList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0   47     2   certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            6   47     3   currentState  Lsun/security/provider/certpath/ReverseState;
            9   47     4           iter  Ljava/util/Iterator<Ljava/security/cert/TrustAnchor;>;
           11   40     5         anchor  Ljava/security/cert/TrustAnchor;
           17   40     6    trustedCert  Ljava/security/cert/X509Certificate;
           20   40     7         pubKey  Ljava/security/PublicKey;
           35   38     8              e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          29    33      34  Class java.security.GeneralSecurityException
          29    33      34  Class java.io.IOException
    Exceptions:
      throws java.security.GeneralSecurityException, java.io.IOException
    Signature: (Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
               Name  Flags
      adjacencyList  
      certPathList   

  private void buildForward(java.util.List<java.util.List<sun.security.provider.certpath.Vertex>>, java.util.LinkedList<java.security.cert.X509Certificate>, );
    descriptor: (Ljava/util/List;Ljava/util/LinkedList;Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=5, args_size=4
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // java.util.List adjacencyList
        start local 2 // java.util.LinkedList certPathList
        start local 3 // boolean searchAllCertStores
         0: .line 295
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 296
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.buildForward()..."
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 300
      StackMap locals:
      StackMap stack:
            new sun.security.provider.certpath.ForwardState
            dup
            invokespecial sun.security.provider.certpath.ForwardState.<init>:()V
            astore 4 /* currentState */
        start local 4 // sun.security.provider.certpath.ForwardState currentState
         3: .line 301
            aload 4 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.certPathCheckers:()Ljava/util/List;
            invokevirtual sun.security.provider.certpath.ForwardState.initState:(Ljava/util/List;)V
         4: .line 304
            aload 1 /* adjacencyList */
            invokeinterface java.util.List.clear:()V
         5: .line 305
            aload 1 /* adjacencyList */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         6: .line 307
            aload 4 /* currentState */
            new sun.security.provider.certpath.UntrustedChecker
            dup
            invokespecial sun.security.provider.certpath.UntrustedChecker.<init>:()V
            putfield sun.security.provider.certpath.ForwardState.untrustedChecker:Lsun/security/provider/certpath/UntrustedChecker;
         7: .line 308
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.targetSubject:()Ljavax/security/auth/x500/X500Principal;
            aload 4 /* currentState */
         8: .line 309
            new sun.security.provider.certpath.ForwardBuilder
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
         9: .line 310
            iload 3 /* searchAllCertStores */
        10: .line 309
            invokespecial sun.security.provider.certpath.ForwardBuilder.<init>:(Lsun/security/provider/certpath/PKIX$BuilderParams;Z)V
        11: .line 311
            aload 1 /* adjacencyList */
            aload 2 /* certPathList */
        12: .line 308
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.depthFirstSearchForward:(Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ForwardState;Lsun/security/provider/certpath/ForwardBuilder;Ljava/util/List;Ljava/util/LinkedList;)V
        13: .line 313
            return
        end local 4 // sun.security.provider.certpath.ForwardState currentState
        end local 3 // boolean searchAllCertStores
        end local 2 // java.util.LinkedList certPathList
        end local 1 // java.util.List adjacencyList
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   14     0                 this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   14     1        adjacencyList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0   14     2         certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            0   14     3  searchAllCertStores  Z
            3   14     4         currentState  Lsun/security/provider/certpath/ForwardState;
    Exceptions:
      throws java.security.GeneralSecurityException, java.io.IOException
    Signature: (Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;Z)V
    MethodParameters:
                     Name  Flags
      adjacencyList        
      certPathList         
      searchAllCertStores  

  private void depthFirstSearchForward(javax.security.auth.x500.X500Principal, sun.security.provider.certpath.ForwardState, sun.security.provider.certpath.ForwardBuilder, java.util.List<java.util.List<sun.security.provider.certpath.Vertex>>, java.util.LinkedList<java.security.cert.X509Certificate>);
    descriptor: (Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ForwardState;Lsun/security/provider/certpath/ForwardBuilder;Ljava/util/List;Ljava/util/LinkedList;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=26, args_size=6
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // javax.security.auth.x500.X500Principal dN
        start local 2 // sun.security.provider.certpath.ForwardState currentState
        start local 3 // sun.security.provider.certpath.ForwardBuilder builder
        start local 4 // java.util.List adjList
        start local 5 // java.util.LinkedList cpList
         0: .line 337
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 338
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchForward("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* dN */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         2: .line 339
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ForwardState.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 338
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 347
      StackMap locals:
      StackMap stack:
            aload 3 /* builder */
            aload 2 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.certStores:()Ljava/util/List;
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getMatchingCerts:(Lsun/security/provider/certpath/State;Ljava/util/List;)Ljava/util/Collection;
         5: .line 346
            astore 6 /* certs */
        start local 6 // java.util.Collection certs
         6: .line 348
            aload 6 /* certs */
            aload 4 /* adjList */
            invokestatic sun.security.provider.certpath.SunCertPathBuilder.addVertices:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            astore 7 /* vertices */
        start local 7 // java.util.List vertices
         7: .line 349
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 11
         8: .line 350
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchForward(): certs.size="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         9: .line 351
            aload 7 /* vertices */
            invokeinterface java.util.List.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 350
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 362
      StackMap locals: java.util.Collection java.util.List
      StackMap stack:
            aload 7 /* vertices */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 175
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List top java.util.Iterator
      StackMap stack:
        12: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.Vertex
            astore 8 /* vertex */
        start local 8 // sun.security.provider.certpath.Vertex vertex
        13: .line 370
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ForwardState.clone:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.ForwardState
            astore 10 /* nextState */
        start local 10 // sun.security.provider.certpath.ForwardState nextState
        14: .line 371
            aload 8 /* vertex */
            invokevirtual sun.security.provider.certpath.Vertex.getCertificate:()Ljava/security/cert/X509Certificate;
            astore 11 /* cert */
        start local 11 // java.security.cert.X509Certificate cert
        15: .line 374
            aload 3 /* builder */
            aload 11 /* cert */
            aload 10 /* nextState */
            aload 5 /* cpList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.verifyCert:(Ljava/security/cert/X509Certificate;Lsun/security/provider/certpath/State;Ljava/util/List;)V
        16: .line 375
            goto 25
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate
      StackMap stack: java.security.GeneralSecurityException
        17: astore 12 /* gse */
        start local 12 // java.security.GeneralSecurityException gse
        18: .line 376
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 23
        19: .line 377
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchForward(): validation failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        20: .line 378
            aload 12 /* gse */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 377
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        22: .line 379
            aload 12 /* gse */
            invokevirtual java.security.GeneralSecurityException.printStackTrace:()V
        23: .line 381
      StackMap locals: java.security.GeneralSecurityException
      StackMap stack:
            aload 8 /* vertex */
            aload 12 /* gse */
            invokevirtual sun.security.provider.certpath.Vertex.setThrowable:(Ljava/lang/Throwable;)V
        24: .line 382
            goto 175
        end local 12 // java.security.GeneralSecurityException gse
        25: .line 394
      StackMap locals:
      StackMap stack:
            aload 3 /* builder */
            aload 11 /* cert */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.isPathCompleted:(Ljava/security/cert/X509Certificate;)Z
            ifeq 163
        26: .line 396
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 28
        27: .line 397
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.depthFirstSearchForward(): commencing final verification"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        28: .line 400
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            aload 5 /* cpList */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            astore 12 /* appendedCerts */
        start local 12 // java.util.List appendedCerts
        29: .line 408
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            ifnonnull 31
        30: .line 409
            aload 12 /* appendedCerts */
            iconst_0
            aload 11 /* cert */
            invokeinterface java.util.List.add:(ILjava/lang/Object;)V
        31: .line 413
      StackMap locals: java.util.List
      StackMap stack:
            ldc "2.5.29.32.0"
            invokestatic java.util.Collections.singleton:(Ljava/lang/Object;)Ljava/util/Set;
        32: .line 412
            astore 13 /* initExpPolSet */
        start local 13 // java.util.Set initExpPolSet
        33: .line 415
            new sun.security.provider.certpath.PolicyNodeImpl
            dup
            aconst_null
        34: .line 416
            ldc "2.5.29.32.0"
            aconst_null
            iconst_0
            aload 13 /* initExpPolSet */
            iconst_0
        35: .line 415
            invokespecial sun.security.provider.certpath.PolicyNodeImpl.<init>:(Lsun/security/provider/certpath/PolicyNodeImpl;Ljava/lang/String;Ljava/util/Set;ZLjava/util/Set;Z)V
            astore 14 /* rootNode */
        start local 14 // sun.security.provider.certpath.PolicyNodeImpl rootNode
        36: .line 418
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 15 /* checkers */
        start local 15 // java.util.List checkers
        37: .line 420
            new sun.security.provider.certpath.PolicyChecker
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.initialPolicies:()Ljava/util/Set;
        38: .line 421
            aload 12 /* appendedCerts */
            invokeinterface java.util.List.size:()I
        39: .line 422
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.explicitPolicyRequired:()Z
        40: .line 423
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.policyMappingInhibited:()Z
        41: .line 424
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.anyPolicyInhibited:()Z
        42: .line 425
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.policyQualifiersRejected:()Z
        43: .line 426
            aload 14 /* rootNode */
        44: .line 420
            invokespecial sun.security.provider.certpath.PolicyChecker.<init>:(Ljava/util/Set;IZZZZLsun/security/provider/certpath/PolicyNodeImpl;)V
        45: .line 419
            astore 16 /* policyChecker */
        start local 16 // sun.security.provider.certpath.PolicyChecker policyChecker
        46: .line 428
            aload 15 /* checkers */
            aload 16 /* policyChecker */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        47: .line 431
            aload 15 /* checkers */
            new sun.security.provider.certpath.AlgorithmChecker
            dup
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        48: .line 432
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.date:()Ljava/util/Date;
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.variant:()Ljava/lang/String;
            invokespecial sun.security.provider.certpath.AlgorithmChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/util/Date;Ljava/lang/String;)V
        49: .line 431
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        50: .line 434
            aconst_null
            astore 17 /* basicChecker */
        start local 17 // sun.security.provider.certpath.BasicChecker basicChecker
        51: .line 435
            aload 10 /* nextState */
            invokevirtual sun.security.provider.certpath.ForwardState.keyParamsNeeded:()Z
            ifeq 69
        52: .line 436
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 18 /* rootKey */
        start local 18 // java.security.PublicKey rootKey
        53: .line 437
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            ifnonnull 61
        54: .line 438
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
            astore 18 /* rootKey */
        55: .line 439
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 61
        56: .line 440
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
        57: .line 441
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchForward using buildParams public key: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        58: .line 443
            aload 18 /* rootKey */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        59: .line 441
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        60: .line 440
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        61: .line 445
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate java.util.List java.util.Set sun.security.provider.certpath.PolicyNodeImpl java.util.List sun.security.provider.certpath.PolicyChecker sun.security.provider.certpath.BasicChecker java.security.PublicKey
      StackMap stack:
            new java.security.cert.TrustAnchor
            dup
        62: .line 446
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            aload 18 /* rootKey */
            aconst_null
        63: .line 445
            invokespecial java.security.cert.TrustAnchor.<init>:(Ljavax/security/auth/x500/X500Principal;Ljava/security/PublicKey;[B)V
            astore 19 /* anchor */
        start local 19 // java.security.cert.TrustAnchor anchor
        64: .line 449
            new sun.security.provider.certpath.BasicChecker
            dup
            aload 19 /* anchor */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.date:()Ljava/util/Date;
        65: .line 450
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.sigProvider:()Ljava/lang/String;
        66: .line 451
            iconst_1
        67: .line 449
            invokespecial sun.security.provider.certpath.BasicChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/util/Date;Ljava/lang/String;Z)V
            astore 17 /* basicChecker */
        68: .line 452
            aload 15 /* checkers */
            aload 17 /* basicChecker */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 19 // java.security.cert.TrustAnchor anchor
        end local 18 // java.security.PublicKey rootKey
        69: .line 455
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.cf:Ljava/security/cert/CertificateFactory;
            aload 12 /* appendedCerts */
            invokevirtual java.security.cert.CertificateFactory.generateCertPath:(Ljava/util/List;)Ljava/security/cert/CertPath;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.setCertPath:(Ljava/security/cert/CertPath;)V
        70: .line 457
            iconst_0
            istore 18 /* revCheckerAdded */
        start local 18 // boolean revCheckerAdded
        71: .line 458
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.certPathCheckers:()Ljava/util/List;
            astore 19 /* ckrs */
        start local 19 // java.util.List ckrs
        72: .line 459
            aload 19 /* ckrs */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 21
            goto 80
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate java.util.List java.util.Set sun.security.provider.certpath.PolicyNodeImpl java.util.List sun.security.provider.certpath.PolicyChecker sun.security.provider.certpath.BasicChecker int java.util.List top java.util.Iterator
      StackMap stack:
        73: aload 21
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 20 /* ckr */
        start local 20 // java.security.cert.PKIXCertPathChecker ckr
        74: .line 460
            aload 20 /* ckr */
            instanceof sun.security.provider.certpath.PKIXRevocationChecker
            ifeq 80
        75: .line 461
            iconst_1
            istore 18 /* revCheckerAdded */
        76: .line 463
            aload 20 /* ckr */
            instanceof sun.security.provider.certpath.RevocationChecker
            ifeq 80
        77: .line 464
            aload 20 /* ckr */
            checkcast sun.security.provider.certpath.RevocationChecker
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        78: .line 465
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
        79: .line 464
            invokevirtual sun.security.provider.certpath.RevocationChecker.init:(Ljava/security/cert/TrustAnchor;Lsun/security/provider/certpath/PKIX$ValidatorParams;)V
        end local 20 // java.security.cert.PKIXCertPathChecker ckr
        80: .line 459
      StackMap locals:
      StackMap stack:
            aload 21
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 73
        81: .line 470
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.revocationEnabled:()Z
            ifeq 85
            iload 18 /* revCheckerAdded */
            ifne 85
        82: .line 471
            aload 15 /* checkers */
            new sun.security.provider.certpath.RevocationChecker
            dup
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        83: .line 472
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokespecial sun.security.provider.certpath.RevocationChecker.<init>:(Ljava/security/cert/TrustAnchor;Lsun/security/provider/certpath/PKIX$ValidatorParams;)V
        84: .line 471
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        85: .line 475
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate java.util.List java.util.Set sun.security.provider.certpath.PolicyNodeImpl java.util.List sun.security.provider.certpath.PolicyChecker sun.security.provider.certpath.BasicChecker int java.util.List
      StackMap stack:
            aload 15 /* checkers */
            aload 19 /* ckrs */
            invokeinterface java.util.List.addAll:(Ljava/util/Collection;)Z
            pop
        86: .line 480
            iconst_0
            istore 20 /* i */
        start local 20 // int i
        87: goto 146
        88: .line 481
      StackMap locals: int
      StackMap stack:
            aload 12 /* appendedCerts */
            iload 20 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 21 /* currCert */
        start local 21 // java.security.cert.X509Certificate currCert
        89: .line 482
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 93
        90: .line 483
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "current subject = "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        91: .line 484
            aload 21 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        92: .line 483
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        93: .line 486
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 21 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getCriticalExtensionOIDs:()Ljava/util/Set;
        94: .line 485
            astore 22 /* unresCritExts */
        start local 22 // java.util.Set unresCritExts
        95: .line 487
            aload 22 /* unresCritExts */
            ifnonnull 97
        96: .line 488
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 22 /* unresCritExts */
        97: .line 491
      StackMap locals: java.util.Set
      StackMap stack:
            aload 15 /* checkers */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 24
            goto 119
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate java.util.List java.util.Set sun.security.provider.certpath.PolicyNodeImpl java.util.List sun.security.provider.certpath.PolicyChecker sun.security.provider.certpath.BasicChecker int java.util.List int java.security.cert.X509Certificate java.util.Set top java.util.Iterator
      StackMap stack:
        98: aload 24
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 23 /* currChecker */
        start local 23 // java.security.cert.PKIXCertPathChecker currChecker
        99: .line 492
            aload 23 /* currChecker */
            invokevirtual java.security.cert.PKIXCertPathChecker.isForwardCheckingSupported:()Z
            ifne 119
       100: .line 493
            iload 20 /* i */
            ifne 105
       101: .line 494
            aload 23 /* currChecker */
            iconst_0
            invokevirtual java.security.cert.PKIXCertPathChecker.init:(Z)V
       102: .line 499
            aload 23 /* currChecker */
            instanceof sun.security.provider.certpath.AlgorithmChecker
            ifeq 105
       103: .line 500
            aload 23 /* currChecker */
            checkcast sun.security.provider.certpath.AlgorithmChecker
       104: .line 501
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            invokevirtual sun.security.provider.certpath.AlgorithmChecker.trySetTrustAnchor:(Ljava/security/cert/TrustAnchor;)V
       105: .line 506
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate java.util.List java.util.Set sun.security.provider.certpath.PolicyNodeImpl java.util.List sun.security.provider.certpath.PolicyChecker sun.security.provider.certpath.BasicChecker int java.util.List int java.security.cert.X509Certificate java.util.Set java.security.cert.PKIXCertPathChecker java.util.Iterator
      StackMap stack:
            aload 23 /* currChecker */
            aload 21 /* currCert */
            aload 22 /* unresCritExts */
            invokevirtual java.security.cert.PKIXCertPathChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
       106: .line 507
            goto 119
      StackMap locals:
      StackMap stack: java.security.cert.CertPathValidatorException
       107: astore 25 /* cpve */
        start local 25 // java.security.cert.CertPathValidatorException cpve
       108: .line 508
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 114
       109: .line 509
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
       110: .line 510
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchForward(): final verification failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
       111: .line 511
            aload 25 /* cpve */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
       112: .line 510
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       113: .line 509
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       114: .line 514
      StackMap locals: java.security.cert.CertPathValidatorException
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.targetCertConstraints:()Ljava/security/cert/CertSelector;
            aload 21 /* currCert */
            invokeinterface java.security.cert.CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 117
       115: .line 515
            aload 25 /* cpve */
            invokevirtual java.security.cert.CertPathValidatorException.getReason:()Ljava/security/cert/CertPathValidatorException$Reason;
            getstatic java.security.cert.CertPathValidatorException$BasicReason.REVOKED:Ljava/security/cert/CertPathValidatorException$BasicReason;
            if_acmpne 117
       116: .line 516
            aload 25 /* cpve */
            athrow
       117: .line 518
      StackMap locals:
      StackMap stack:
            aload 8 /* vertex */
            aload 25 /* cpve */
            invokevirtual sun.security.provider.certpath.Vertex.setThrowable:(Ljava/lang/Throwable;)V
       118: .line 519
            goto 175
        end local 25 // java.security.cert.CertPathValidatorException cpve
        end local 23 // java.security.cert.PKIXCertPathChecker currChecker
       119: .line 491
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate java.util.List java.util.Set sun.security.provider.certpath.PolicyNodeImpl java.util.List sun.security.provider.certpath.PolicyChecker sun.security.provider.certpath.BasicChecker int java.util.List int java.security.cert.X509Certificate java.util.Set top java.util.Iterator
      StackMap stack:
            aload 24
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 98
       120: .line 531
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.certPathCheckers:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 24
            goto 127
      StackMap locals:
      StackMap stack:
       121: aload 24
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 23 /* checker */
        start local 23 // java.security.cert.PKIXCertPathChecker checker
       122: .line 533
            aload 23 /* checker */
            invokevirtual java.security.cert.PKIXCertPathChecker.isForwardCheckingSupported:()Z
            ifeq 127
       123: .line 535
            aload 23 /* checker */
            invokevirtual java.security.cert.PKIXCertPathChecker.getSupportedExtensions:()Ljava/util/Set;
       124: .line 534
            astore 25 /* suppExts */
        start local 25 // java.util.Set suppExts
       125: .line 536
            aload 25 /* suppExts */
            ifnull 127
       126: .line 537
            aload 22 /* unresCritExts */
            aload 25 /* suppExts */
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
        end local 25 // java.util.Set suppExts
        end local 23 // java.security.cert.PKIXCertPathChecker checker
       127: .line 530
      StackMap locals:
      StackMap stack:
            aload 24
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 121
       128: .line 542
            aload 22 /* unresCritExts */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 145
       129: .line 543
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.BasicConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       130: .line 544
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.NameConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       131: .line 545
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.CertificatePolicies_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       132: .line 546
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.PolicyMappings_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       133: .line 547
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.PolicyConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       134: .line 548
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.InhibitAnyPolicy_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       135: .line 549
            aload 22 /* unresCritExts */
       136: .line 550
            getstatic sun.security.x509.PKIXExtensions.SubjectAlternativeName_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       137: .line 549
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       138: .line 551
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.KeyUsage_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       139: .line 552
            aload 22 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.ExtendedKeyUsage_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       140: .line 554
            aload 22 /* unresCritExts */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 145
       141: .line 555
            new java.security.cert.CertPathValidatorException
            dup
       142: .line 556
            ldc "unrecognized critical extension(s)"
            aconst_null
       143: .line 557
            aconst_null
            iconst_m1
            getstatic java.security.cert.PKIXReason.UNRECOGNIZED_CRIT_EXT:Ljava/security/cert/PKIXReason;
       144: .line 555
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;Ljava/security/cert/CertPath;ILjava/security/cert/CertPathValidatorException$Reason;)V
            athrow
        end local 22 // java.util.Set unresCritExts
        end local 21 // java.security.cert.X509Certificate currCert
       145: .line 480
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate java.util.List java.util.Set sun.security.provider.certpath.PolicyNodeImpl java.util.List sun.security.provider.certpath.PolicyChecker sun.security.provider.certpath.BasicChecker int java.util.List int
      StackMap stack:
            iinc 20 /* i */ 1
      StackMap locals:
      StackMap stack:
       146: iload 20 /* i */
            aload 12 /* appendedCerts */
            invokeinterface java.util.List.size:()I
            if_icmplt 88
        end local 20 // int i
       147: .line 561
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 149
       148: .line 562
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.depthFirstSearchForward(): final verification succeeded - path completed!"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       149: .line 564
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
       150: .line 571
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            ifnonnull 152
       151: .line 572
            aload 3 /* builder */
            aload 11 /* cert */
            aload 5 /* cpList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.addCertToPath:(Ljava/security/cert/X509Certificate;Ljava/util/LinkedList;)V
       152: .line 574
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            putfield sun.security.provider.certpath.SunCertPathBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
       153: .line 579
            aload 17 /* basicChecker */
            ifnull 156
       154: .line 580
            aload 0 /* this */
            aload 17 /* basicChecker */
            invokevirtual sun.security.provider.certpath.BasicChecker.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
       155: .line 581
            goto 161
       156: .line 583
      StackMap locals:
      StackMap stack:
            aload 5 /* cpList */
            invokevirtual java.util.LinkedList.isEmpty:()Z
            ifeq 159
       157: .line 584
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            astore 20 /* finalCert */
        start local 20 // java.security.cert.Certificate finalCert
       158: .line 585
            goto 160
        end local 20 // java.security.cert.Certificate finalCert
       159: .line 586
      StackMap locals:
      StackMap stack:
            aload 5 /* cpList */
            invokevirtual java.util.LinkedList.getLast:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate
            astore 20 /* finalCert */
        start local 20 // java.security.cert.Certificate finalCert
       160: .line 588
      StackMap locals: java.security.cert.Certificate
      StackMap stack:
            aload 0 /* this */
            aload 20 /* finalCert */
            invokevirtual java.security.cert.Certificate.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        end local 20 // java.security.cert.Certificate finalCert
       161: .line 591
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 16 /* policyChecker */
            invokevirtual sun.security.provider.certpath.PolicyChecker.getPolicyTree:()Ljava/security/cert/PolicyNode;
            putfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
       162: .line 592
            return
        end local 19 // java.util.List ckrs
        end local 18 // boolean revCheckerAdded
        end local 17 // sun.security.provider.certpath.BasicChecker basicChecker
        end local 16 // sun.security.provider.certpath.PolicyChecker policyChecker
        end local 15 // java.util.List checkers
        end local 14 // sun.security.provider.certpath.PolicyNodeImpl rootNode
        end local 13 // java.util.Set initExpPolSet
        end local 12 // java.util.List appendedCerts
       163: .line 594
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate
      StackMap stack:
            aload 3 /* builder */
            aload 11 /* cert */
            aload 5 /* cpList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.addCertToPath:(Ljava/security/cert/X509Certificate;Ljava/util/LinkedList;)V
       164: .line 598
            aload 10 /* nextState */
            aload 11 /* cert */
            invokevirtual sun.security.provider.certpath.ForwardState.updateState:(Ljava/security/cert/X509Certificate;)V
       165: .line 604
            aload 4 /* adjList */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
       166: .line 605
            aload 8 /* vertex */
            aload 4 /* adjList */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokevirtual sun.security.provider.certpath.Vertex.setIndex:(I)V
       167: .line 608
            aload 0 /* this */
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            aload 10 /* nextState */
       168: .line 609
            aload 3 /* builder */
            aload 4 /* adjList */
            aload 5 /* cpList */
       169: .line 608
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.depthFirstSearchForward:(Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ForwardState;Lsun/security/provider/certpath/ForwardBuilder;Ljava/util/List;Ljava/util/LinkedList;)V
       170: .line 614
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 172
       171: .line 615
            return
       172: .line 623
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 174
       173: .line 624
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.depthFirstSearchForward(): backtracking"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       174: .line 626
      StackMap locals:
      StackMap stack:
            aload 3 /* builder */
            aload 5 /* cpList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.removeFinalCertFromPath:(Ljava/util/LinkedList;)V
        end local 11 // java.security.cert.X509Certificate cert
        end local 10 // sun.security.provider.certpath.ForwardState nextState
        end local 8 // sun.security.provider.certpath.Vertex vertex
       175: .line 362
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ForwardState sun.security.provider.certpath.ForwardBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
       176: .line 629
            return
        end local 7 // java.util.List vertices
        end local 6 // java.util.Collection certs
        end local 5 // java.util.LinkedList cpList
        end local 4 // java.util.List adjList
        end local 3 // sun.security.provider.certpath.ForwardBuilder builder
        end local 2 // sun.security.provider.certpath.ForwardState currentState
        end local 1 // javax.security.auth.x500.X500Principal dN
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0  177     0             this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0  177     1               dN  Ljavax/security/auth/x500/X500Principal;
            0  177     2     currentState  Lsun/security/provider/certpath/ForwardState;
            0  177     3          builder  Lsun/security/provider/certpath/ForwardBuilder;
            0  177     4          adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0  177     5           cpList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            6  177     6            certs  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            7  177     7         vertices  Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;
           13  175     8           vertex  Lsun/security/provider/certpath/Vertex;
           14  175    10        nextState  Lsun/security/provider/certpath/ForwardState;
           15  175    11             cert  Ljava/security/cert/X509Certificate;
           18   25    12              gse  Ljava/security/GeneralSecurityException;
           29  163    12    appendedCerts  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
           33  163    13    initExpPolSet  Ljava/util/Set<Ljava/lang/String;>;
           36  163    14         rootNode  Lsun/security/provider/certpath/PolicyNodeImpl;
           37  163    15         checkers  Ljava/util/List<Ljava/security/cert/PKIXCertPathChecker;>;
           46  163    16    policyChecker  Lsun/security/provider/certpath/PolicyChecker;
           51  163    17     basicChecker  Lsun/security/provider/certpath/BasicChecker;
           53   69    18          rootKey  Ljava/security/PublicKey;
           64   69    19           anchor  Ljava/security/cert/TrustAnchor;
           71  163    18  revCheckerAdded  Z
           72  163    19             ckrs  Ljava/util/List<Ljava/security/cert/PKIXCertPathChecker;>;
           74   80    20              ckr  Ljava/security/cert/PKIXCertPathChecker;
           87  147    20                i  I
           89  145    21         currCert  Ljava/security/cert/X509Certificate;
           95  145    22    unresCritExts  Ljava/util/Set<Ljava/lang/String;>;
           99  119    23      currChecker  Ljava/security/cert/PKIXCertPathChecker;
          108  119    25             cpve  Ljava/security/cert/CertPathValidatorException;
          122  127    23          checker  Ljava/security/cert/PKIXCertPathChecker;
          125  127    25         suppExts  Ljava/util/Set<Ljava/lang/String;>;
          158  159    20        finalCert  Ljava/security/cert/Certificate;
          160  161    20        finalCert  Ljava/security/cert/Certificate;
      Exception table:
        from    to  target  type
          15    16      17  Class java.security.GeneralSecurityException
         105   106     107  Class java.security.cert.CertPathValidatorException
    Exceptions:
      throws java.security.GeneralSecurityException, java.io.IOException
    Signature: (Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ForwardState;Lsun/security/provider/certpath/ForwardBuilder;Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      dN            
      currentState  
      builder       
      adjList       
      cpList        

  private void depthFirstSearchReverse(javax.security.auth.x500.X500Principal, sun.security.provider.certpath.ReverseState, sun.security.provider.certpath.ReverseBuilder, java.util.List<java.util.List<sun.security.provider.certpath.Vertex>>, java.util.LinkedList<java.security.cert.X509Certificate>);
    descriptor: (Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ReverseState;Lsun/security/provider/certpath/ReverseBuilder;Ljava/util/List;Ljava/util/LinkedList;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=13, args_size=6
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // javax.security.auth.x500.X500Principal dN
        start local 2 // sun.security.provider.certpath.ReverseState currentState
        start local 3 // sun.security.provider.certpath.ReverseBuilder builder
        start local 4 // java.util.List adjList
        start local 5 // java.util.LinkedList cpList
         0: .line 653
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 654
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchReverse("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* dN */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         2: .line 655
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ReverseState.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 654
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 662
      StackMap locals:
      StackMap stack:
            aload 3 /* builder */
            aload 2 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Lsun/security/provider/certpath/PKIX$BuilderParams;
            invokevirtual sun.security.provider.certpath.PKIX$BuilderParams.certStores:()Ljava/util/List;
            invokevirtual sun.security.provider.certpath.ReverseBuilder.getMatchingCerts:(Lsun/security/provider/certpath/State;Ljava/util/List;)Ljava/util/Collection;
         5: .line 661
            astore 6 /* certs */
        start local 6 // java.util.Collection certs
         6: .line 663
            aload 6 /* certs */
            aload 4 /* adjList */
            invokestatic sun.security.provider.certpath.SunCertPathBuilder.addVertices:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            astore 7 /* vertices */
        start local 7 // java.util.List vertices
         7: .line 664
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 11
         8: .line 665
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchReverse(): certs.size="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         9: .line 666
            aload 7 /* vertices */
            invokeinterface java.util.List.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 665
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 674
      StackMap locals: java.util.Collection java.util.List
      StackMap stack:
            aload 7 /* vertices */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 55
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ReverseState sun.security.provider.certpath.ReverseBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List top java.util.Iterator
      StackMap stack:
        12: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.Vertex
            astore 8 /* vertex */
        start local 8 // sun.security.provider.certpath.Vertex vertex
        13: .line 682
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ReverseState.clone:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.ReverseState
            astore 10 /* nextState */
        start local 10 // sun.security.provider.certpath.ReverseState nextState
        14: .line 683
            aload 8 /* vertex */
            invokevirtual sun.security.provider.certpath.Vertex.getCertificate:()Ljava/security/cert/X509Certificate;
            astore 11 /* cert */
        start local 11 // java.security.cert.X509Certificate cert
        15: .line 685
            aload 3 /* builder */
            aload 11 /* cert */
            aload 10 /* nextState */
            aload 5 /* cpList */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.verifyCert:(Ljava/security/cert/X509Certificate;Lsun/security/provider/certpath/State;Ljava/util/List;)V
        16: .line 686
            goto 24
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ReverseState sun.security.provider.certpath.ReverseBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ReverseState java.security.cert.X509Certificate
      StackMap stack: java.security.GeneralSecurityException
        17: astore 12 /* gse */
        start local 12 // java.security.GeneralSecurityException gse
        18: .line 687
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 22
        19: .line 688
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchReverse(): validation failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        20: .line 689
            aload 12 /* gse */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 688
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        22: .line 690
      StackMap locals: java.security.GeneralSecurityException
      StackMap stack:
            aload 8 /* vertex */
            aload 12 /* gse */
            invokevirtual sun.security.provider.certpath.Vertex.setThrowable:(Ljava/lang/Throwable;)V
        23: .line 691
            goto 55
        end local 12 // java.security.GeneralSecurityException gse
        24: .line 698
      StackMap locals:
      StackMap stack:
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ReverseState.isInitial:()Z
            ifne 26
        25: .line 699
            aload 3 /* builder */
            aload 11 /* cert */
            aload 5 /* cpList */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.addCertToPath:(Ljava/security/cert/X509Certificate;Ljava/util/LinkedList;)V
        26: .line 701
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* currentState */
            getfield sun.security.provider.certpath.ReverseState.trustAnchor:Ljava/security/cert/TrustAnchor;
            putfield sun.security.provider.certpath.SunCertPathBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        27: .line 706
            aload 3 /* builder */
            aload 11 /* cert */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.isPathCompleted:(Ljava/security/cert/X509Certificate;)Z
            ifeq 43
        28: .line 707
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 30
        29: .line 708
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.depthFirstSearchReverse(): path completed!"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        30: .line 710
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
        31: .line 712
            aload 10 /* nextState */
            getfield sun.security.provider.certpath.ReverseState.rootNode:Lsun/security/provider/certpath/PolicyNodeImpl;
            astore 12 /* rootNode */
        start local 12 // sun.security.provider.certpath.PolicyNodeImpl rootNode
        32: .line 714
            aload 12 /* rootNode */
            ifnonnull 34
        33: .line 715
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
            goto 36
        34: .line 717
      StackMap locals: sun.security.provider.certpath.PolicyNodeImpl
      StackMap stack:
            aload 0 /* this */
            aload 12 /* rootNode */
            invokevirtual sun.security.provider.certpath.PolicyNodeImpl.copyTree:()Lsun/security/provider/certpath/PolicyNodeImpl;
            putfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
        35: .line 718
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
            checkcast sun.security.provider.certpath.PolicyNodeImpl
            invokevirtual sun.security.provider.certpath.PolicyNodeImpl.setImmutable:()V
        36: .line 724
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        37: .line 725
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
            invokestatic sun.security.provider.certpath.PKIX.isDSAPublicKeyWithoutParams:(Ljava/security/PublicKey;)Z
            ifeq 42
        38: .line 726
            aload 0 /* this */
        39: .line 728
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
            aload 2 /* currentState */
            getfield sun.security.provider.certpath.ReverseState.pubKey:Ljava/security/PublicKey;
        40: .line 727
            invokestatic sun.security.provider.certpath.BasicChecker.makeInheritedParamsKey:(Ljava/security/PublicKey;Ljava/security/PublicKey;)Ljava/security/PublicKey;
        41: .line 726
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        42: .line 731
      StackMap locals:
      StackMap stack:
            return
        end local 12 // sun.security.provider.certpath.PolicyNodeImpl rootNode
        43: .line 735
      StackMap locals:
      StackMap stack:
            aload 10 /* nextState */
            aload 11 /* cert */
            invokevirtual sun.security.provider.certpath.ReverseState.updateState:(Ljava/security/cert/X509Certificate;)V
        44: .line 741
            aload 4 /* adjList */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        45: .line 742
            aload 8 /* vertex */
            aload 4 /* adjList */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokevirtual sun.security.provider.certpath.Vertex.setIndex:(I)V
        46: .line 745
            aload 0 /* this */
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            aload 10 /* nextState */
        47: .line 746
            aload 3 /* builder */
            aload 4 /* adjList */
            aload 5 /* cpList */
        48: .line 745
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.depthFirstSearchReverse:(Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ReverseState;Lsun/security/provider/certpath/ReverseBuilder;Ljava/util/List;Ljava/util/LinkedList;)V
        49: .line 751
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 51
        50: .line 752
            return
        51: .line 760
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 53
        52: .line 761
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.depthFirstSearchReverse(): backtracking"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        53: .line 763
      StackMap locals:
      StackMap stack:
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ReverseState.isInitial:()Z
            ifne 55
        54: .line 764
            aload 3 /* builder */
            aload 5 /* cpList */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.removeFinalCertFromPath:(Ljava/util/LinkedList;)V
        end local 11 // java.security.cert.X509Certificate cert
        end local 10 // sun.security.provider.certpath.ReverseState nextState
        end local 8 // sun.security.provider.certpath.Vertex vertex
        55: .line 674
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ReverseState sun.security.provider.certpath.ReverseBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        56: .line 767
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 58
        57: .line 768
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ldc "SunCertPathBuilder.depthFirstSearchReverse() all certs in this adjacency list checked"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        58: .line 770
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder javax.security.auth.x500.X500Principal sun.security.provider.certpath.ReverseState sun.security.provider.certpath.ReverseBuilder java.util.List java.util.LinkedList java.util.Collection java.util.List
      StackMap stack:
            return
        end local 7 // java.util.List vertices
        end local 6 // java.util.Collection certs
        end local 5 // java.util.LinkedList cpList
        end local 4 // java.util.List adjList
        end local 3 // sun.security.provider.certpath.ReverseBuilder builder
        end local 2 // sun.security.provider.certpath.ReverseState currentState
        end local 1 // javax.security.auth.x500.X500Principal dN
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   59     0          this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   59     1            dN  Ljavax/security/auth/x500/X500Principal;
            0   59     2  currentState  Lsun/security/provider/certpath/ReverseState;
            0   59     3       builder  Lsun/security/provider/certpath/ReverseBuilder;
            0   59     4       adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0   59     5        cpList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            6   59     6         certs  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            7   59     7      vertices  Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;
           13   55     8        vertex  Lsun/security/provider/certpath/Vertex;
           14   55    10     nextState  Lsun/security/provider/certpath/ReverseState;
           15   55    11          cert  Ljava/security/cert/X509Certificate;
           18   24    12           gse  Ljava/security/GeneralSecurityException;
           32   43    12      rootNode  Lsun/security/provider/certpath/PolicyNodeImpl;
      Exception table:
        from    to  target  type
          15    16      17  Class java.security.GeneralSecurityException
    Exceptions:
      throws java.security.GeneralSecurityException, java.io.IOException
    Signature: (Ljavax/security/auth/x500/X500Principal;Lsun/security/provider/certpath/ReverseState;Lsun/security/provider/certpath/ReverseBuilder;Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      dN            
      currentState  
      builder       
      adjList       
      cpList        

  private static java.util.List<sun.security.provider.certpath.Vertex> addVertices(java.util.Collection<java.security.cert.X509Certificate>, java.util.List<java.util.List<sun.security.provider.certpath.Vertex>>);
    descriptor: (Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // java.util.Collection certs
        start local 1 // java.util.List adjList
         0: .line 779
            aload 1 /* adjList */
            aload 1 /* adjList */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.util.List
            astore 2 /* l */
        start local 2 // java.util.List l
         1: .line 781
            aload 0 /* certs */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 5
      StackMap locals: java.util.Collection java.util.List java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 3 /* cert */
        start local 3 // java.security.cert.X509Certificate cert
         3: .line 782
            new sun.security.provider.certpath.Vertex
            dup
            aload 3 /* cert */
            invokespecial sun.security.provider.certpath.Vertex.<init>:(Ljava/security/cert/X509Certificate;)V
            astore 5 /* v */
        start local 5 // sun.security.provider.certpath.Vertex v
         4: .line 783
            aload 2 /* l */
            aload 5 /* v */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 5 // sun.security.provider.certpath.Vertex v
        end local 3 // java.security.cert.X509Certificate cert
         5: .line 781
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 786
            aload 2 /* l */
            areturn
        end local 2 // java.util.List l
        end local 1 // java.util.List adjList
        end local 0 // java.util.Collection certs
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0    certs  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            0    7     1  adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            1    7     2        l  Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;
            3    5     3     cert  Ljava/security/cert/X509Certificate;
            4    5     5        v  Lsun/security/provider/certpath/Vertex;
    Signature: (Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;)Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;
    MethodParameters:
         Name  Flags
      certs    
      adjList  

  private static boolean anchorIsTarget(java.security.cert.TrustAnchor, java.security.cert.CertSelector);
    descriptor: (Ljava/security/cert/TrustAnchor;Ljava/security/cert/CertSelector;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // java.security.cert.TrustAnchor anchor
        start local 1 // java.security.cert.CertSelector sel
         0: .line 796
            aload 0 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            astore 2 /* anchorCert */
        start local 2 // java.security.cert.X509Certificate anchorCert
         1: .line 797
            aload 2 /* anchorCert */
            ifnull 3
         2: .line 798
            aload 1 /* sel */
            aload 2 /* anchorCert */
            invokeinterface java.security.cert.CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ireturn
         3: .line 800
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.security.cert.X509Certificate anchorCert
        end local 1 // java.security.cert.CertSelector sel
        end local 0 // java.security.cert.TrustAnchor anchor
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0      anchor  Ljava/security/cert/TrustAnchor;
            0    4     1         sel  Ljava/security/cert/CertSelector;
            1    4     2  anchorCert  Ljava/security/cert/X509Certificate;
    MethodParameters:
        Name  Flags
      anchor  
      sel     
}
SourceFile: "SunCertPathBuilder.java"
InnerClasses:
  public final BasicReason = java.security.cert.CertPathValidatorException$BasicReason of java.security.cert.CertPathValidatorException
  public abstract Reason = java.security.cert.CertPathValidatorException$Reason of java.security.cert.CertPathValidatorException
  BuilderParams = sun.security.provider.certpath.PKIX$BuilderParams of sun.security.provider.certpath.PKIX
  ValidatorParams = sun.security.provider.certpath.PKIX$ValidatorParams of sun.security.provider.certpath.PKIX