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 java.security.cert.PKIXBuilderParameters buildParams;
    descriptor: Ljava/security/cert/PKIXBuilderParameters;
    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 javax.security.auth.x500.X500Principal targetSubjectDN;
    descriptor: Ljavax/security/auth/x500/X500Principal;
    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

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

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

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 77
            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=4, locals=2, args_size=1
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
         0: .line 98
            aload 0 /* this */
            invokespecial java.security.cert.CertPathBuilderSpi.<init>:()V
         1: .line 84
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
         2: .line 91
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.SunCertPathBuilder.onlyEECert:Z
         3: .line 100
            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;
         4: .line 101
            goto 7
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder
      StackMap stack: java.security.cert.CertificateException
         5: astore 1 /* e */
        start local 1 // java.security.cert.CertificateException e
         6: .line 102
            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
         7: .line 104
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
         8: .line 105
            new sun.security.action.GetBooleanSecurityPropertyAction
            dup
         9: .line 106
            ldc "com.sun.security.onlyCheckRevocationOfEECert"
        10: .line 105
            invokespecial sun.security.action.GetBooleanSecurityPropertyAction.<init>:(Ljava/lang/String;)V
        11: .line 104
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            putfield sun.security.provider.certpath.SunCertPathBuilder.onlyEECert:Z
        12: .line 107
            return
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lsun/security/provider/certpath/SunCertPathBuilder;
            6    7     1     e  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.cert.CertPathBuilderException

  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=6, locals=6, args_size=2
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // java.security.cert.CertPathParameters params
         0: .line 132
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 133
            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 136
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            instanceof java.security.cert.PKIXBuilderParameters
            ifne 4
         3: .line 137
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "inappropriate parameter type, must be an instance of PKIXBuilderParameters"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 141
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 2 /* buildForward */
        start local 2 // boolean buildForward
         5: .line 142
            aload 1 /* params */
            instanceof sun.security.provider.certpath.SunCertPathBuilderParameters
            ifeq 8
         6: .line 144
            aload 1 /* params */
            checkcast sun.security.provider.certpath.SunCertPathBuilderParameters
            invokevirtual sun.security.provider.certpath.SunCertPathBuilderParameters.getBuildForward:()Z
         7: .line 143
            istore 2 /* buildForward */
         8: .line 147
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aload 1 /* params */
            checkcast java.security.cert.PKIXBuilderParameters
            putfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
         9: .line 153
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getTrustAnchors:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 15
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder java.security.cert.CertPathParameters int top java.util.Iterator
      StackMap stack:
        10: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.TrustAnchor
            astore 3 /* anchor */
        start local 3 // java.security.cert.TrustAnchor anchor
        11: .line 154
            aload 3 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getNameConstraints:()[B
            ifnull 15
        12: .line 155
            new java.security.InvalidAlgorithmParameterException
            dup
        13: .line 156
            ldc "name constraints in trust anchor not supported"
        14: .line 155
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // java.security.cert.TrustAnchor anchor
        15: .line 153
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        16: .line 160
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getTargetCertConstraints:()Ljava/security/cert/CertSelector;
            astore 3 /* sel */
        start local 3 // java.security.cert.CertSelector sel
        17: .line 161
            aload 3 /* sel */
            instanceof java.security.cert.X509CertSelector
            ifne 19
        18: .line 162
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "the targetCertConstraints parameter must be an X509CertSelector"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 166
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder java.security.cert.CertPathParameters int java.security.cert.CertSelector
      StackMap stack:
            aload 0 /* this */
            aload 3 /* sel */
            checkcast java.security.cert.X509CertSelector
            putfield sun.security.provider.certpath.SunCertPathBuilder.targetSel:Ljava/security/cert/X509CertSelector;
        20: .line 167
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSel:Ljava/security/cert/X509CertSelector;
            invokevirtual java.security.cert.X509CertSelector.getSubject:()Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
        21: .line 168
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
            ifnonnull 25
        22: .line 169
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSel:Ljava/security/cert/X509CertSelector;
            invokevirtual java.security.cert.X509CertSelector.getCertificate:()Ljava/security/cert/X509Certificate;
            astore 4 /* targetCert */
        start local 4 // java.security.cert.X509Certificate targetCert
        23: .line 170
            aload 4 /* targetCert */
            ifnull 25
        24: .line 171
            aload 0 /* this */
            aload 4 /* targetCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
        end local 4 // java.security.cert.X509Certificate targetCert
        25: .line 175
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        26: .line 176
            new java.util.ArrayList
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getCertStores:()Ljava/util/List;
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
        27: .line 175
            putfield sun.security.provider.certpath.SunCertPathBuilder.orderedCertStores:Ljava/util/List;
        28: .line 177
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.orderedCertStores:Ljava/util/List;
            new sun.security.provider.certpath.SunCertPathBuilder$CertStoreComparator
            dup
            invokespecial sun.security.provider.certpath.SunCertPathBuilder$CertStoreComparator.<init>:()V
            invokestatic java.util.Collections.sort:(Ljava/util/List;Ljava/util/Comparator;)V
        29: .line 178
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
            ifnonnull 31
        30: .line 179
            aload 0 /* this */
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.orderedCertStores:Ljava/util/List;
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSel:Ljava/security/cert/X509CertSelector;
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.getTargetSubjectDN:(Ljava/util/List;Ljava/security/cert/X509CertSelector;)Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
        31: .line 181
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
            ifnonnull 35
        32: .line 182
            new java.security.InvalidAlgorithmParameterException
            dup
        33: .line 183
            ldc "Could not determine unique target subject"
        34: .line 182
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        35: .line 186
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 4 /* adjList */
        start local 4 // java.util.List adjList
        36: .line 188
            aload 0 /* this */
            iload 2 /* buildForward */
            iconst_0
            aload 4 /* adjList */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildCertPath:(ZZLjava/util/List;)Ljava/security/cert/CertPathBuilderResult;
        37: .line 187
            astore 5 /* result */
        start local 5 // java.security.cert.CertPathBuilderResult result
        38: .line 189
            aload 5 /* result */
            ifnonnull 47
        39: .line 190
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 41
        40: .line 191
            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
        41: .line 194
      StackMap locals: java.util.List java.security.cert.CertPathBuilderResult
      StackMap stack:
            aload 4 /* adjList */
            invokeinterface java.util.List.clear:()V
        42: .line 195
            aload 0 /* this */
            iload 2 /* buildForward */
            iconst_1
            aload 4 /* adjList */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildCertPath:(ZZLjava/util/List;)Ljava/security/cert/CertPathBuilderResult;
            astore 5 /* result */
        43: .line 196
            aload 5 /* result */
            ifnonnull 47
        44: .line 197
            new sun.security.provider.certpath.SunCertPathBuilderException
            dup
            ldc "unable to find valid certification path to requested target"
        45: .line 199
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 4 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        46: .line 197
            invokespecial sun.security.provider.certpath.SunCertPathBuilderException.<init>:(Ljava/lang/String;Lsun/security/provider/certpath/AdjacencyList;)V
            athrow
        47: .line 202
      StackMap locals:
      StackMap stack:
            aload 5 /* result */
            areturn
        end local 5 // java.security.cert.CertPathBuilderResult result
        end local 4 // java.util.List adjList
        end local 3 // java.security.cert.CertSelector sel
        end local 2 // boolean buildForward
        end local 1 // java.security.cert.CertPathParameters params
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   48     0          this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   48     1        params  Ljava/security/cert/CertPathParameters;
            5   48     2  buildForward  Z
           11   15     3        anchor  Ljava/security/cert/TrustAnchor;
           17   48     3           sel  Ljava/security/cert/CertSelector;
           23   25     4    targetCert  Ljava/security/cert/X509Certificate;
           36   48     4       adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
           38   48     5        result  Ljava/security/cert/CertPathBuilderResult;
    Exceptions:
      throws java.security.cert.CertPathBuilderException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      params  

  private java.security.cert.CertPathBuilderResult buildCertPath(boolean, boolean, java.util.List<java.util.List<sun.security.provider.certpath.Vertex>>);
    descriptor: (ZZLjava/util/List;)Ljava/security/cert/CertPathBuilderResult;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=6, args_size=4
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // boolean buildForward
        start local 2 // boolean searchAllCertStores
        start local 3 // java.util.List adjList
         0: .line 210
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
         1: .line 211
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
         2: .line 212
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
         3: .line 213
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
         4: .line 215
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
         5: .line 214
            astore 4 /* certPathList */
        start local 4 // java.util.LinkedList certPathList
         6: .line 217
            iload 1 /* buildForward */
            ifeq 9
         7: .line 218
            aload 0 /* this */
            aload 3 /* adjList */
            aload 4 /* certPathList */
            iload 2 /* searchAllCertStores */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildForward:(Ljava/util/List;Ljava/util/LinkedList;Z)V
         8: .line 219
            goto 19
         9: .line 220
      StackMap locals: java.util.LinkedList
      StackMap stack:
            aload 0 /* this */
            aload 3 /* adjList */
            aload 4 /* certPathList */
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.buildReverse:(Ljava/util/List;Ljava/util/LinkedList;)V
        10: .line 222
            goto 19
      StackMap locals:
      StackMap stack: java.lang.Exception
        11: astore 5 /* e */
        start local 5 // java.lang.Exception e
        12: .line 223
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 15
        13: .line 224
            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
        14: .line 226
            aload 5 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        15: .line 228
      StackMap locals: java.lang.Exception
      StackMap stack:
            new sun.security.provider.certpath.SunCertPathBuilderException
            dup
            ldc "unable to find valid certification path to requested target"
        16: .line 229
            aload 5 /* e */
        17: .line 230
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 3 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        18: .line 228
            invokespecial sun.security.provider.certpath.SunCertPathBuilderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;Lsun/security/provider/certpath/AdjacencyList;)V
            athrow
        end local 5 // java.lang.Exception e
        19: .line 235
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 37
        20: .line 236
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 22
        21: .line 237
            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
        22: .line 243
      StackMap locals:
      StackMap stack:
            aload 4 /* certPathList */
            invokestatic java.util.Collections.reverse:(Ljava/util/List;)V
        23: .line 245
            new sun.security.provider.certpath.SunCertPathBuilderResult
            dup
        24: .line 246
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.cf:Ljava/security/cert/CertificateFactory;
            aload 4 /* 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;
        25: .line 247
            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;
        26: .line 248
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 3 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        27: .line 245
            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
        28: areturn
        29: .line 250
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 5 /* e */
        start local 5 // java.lang.Exception e
        30: .line 251
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 33
        31: .line 252
            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
        32: .line 254
            aload 5 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        33: .line 256
      StackMap locals: java.lang.Exception
      StackMap stack:
            new sun.security.provider.certpath.SunCertPathBuilderException
            dup
            ldc "unable to find valid certification path to requested target"
        34: .line 257
            aload 5 /* e */
        35: .line 258
            new sun.security.provider.certpath.AdjacencyList
            dup
            aload 3 /* adjList */
            invokespecial sun.security.provider.certpath.AdjacencyList.<init>:(Ljava/util/List;)V
        36: .line 256
            invokespecial sun.security.provider.certpath.SunCertPathBuilderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;Lsun/security/provider/certpath/AdjacencyList;)V
            athrow
        end local 5 // java.lang.Exception e
        37: .line 261
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 4 // java.util.LinkedList certPathList
        end local 3 // java.util.List adjList
        end local 2 // boolean searchAllCertStores
        end local 1 // boolean buildForward
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   38     0                 this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   38     1         buildForward  Z
            0   38     2  searchAllCertStores  Z
            0   38     3              adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            6   38     4         certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
           12   19     5                    e  Ljava/lang/Exception;
           30   37     5                    e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           6    10      11  Class java.lang.Exception
          19    28      29  Class java.lang.Exception
    Exceptions:
      throws java.security.cert.CertPathBuilderException
    Signature: (ZZLjava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;)Ljava/security/cert/CertPathBuilderResult;
    MethodParameters:
                     Name  Flags
      buildForward         
      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=7, locals=7, 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 271
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 5
         1: .line 272
            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 273
            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 274
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getInitialPolicies:()Ljava/util/Set;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         4: .line 273
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         5: .line 277
      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 279
            aload 1 /* adjacencyList */
            invokeinterface java.util.List.clear:()V
         7: .line 280
            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 286
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getTrustAnchors:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4 /* iter */
        start local 4 // java.util.Iterator iter
         9: .line 287
            goto 39
        10: .line 288
      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 290
            aload 0 /* this */
            aload 5 /* anchor */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSel:Ljava/security/cert/X509CertSelector;
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.anchorIsTarget:(Ljava/security/cert/TrustAnchor;Ljava/security/cert/X509CertSelector;)Z
            ifeq 16
        12: .line 291
            aload 0 /* this */
            aload 5 /* anchor */
            putfield sun.security.provider.certpath.SunCertPathBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        13: .line 292
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
        14: .line 293
            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 294
            goto 40
        16: .line 298
      StackMap locals: java.security.cert.TrustAnchor
      StackMap stack:
            aload 3 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getMaxPathLength:()I
        17: .line 299
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isExplicitPolicyRequired:()Z
        18: .line 300
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isPolicyMappingInhibited:()Z
        19: .line 301
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isAnyPolicyInhibited:()Z
        20: .line 302
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getCertPathCheckers:()Ljava/util/List;
        21: .line 298
            invokevirtual sun.security.provider.certpath.ReverseState.initState:(IZZZLjava/util/List;)V
        22: .line 303
            aload 3 /* currentState */
            aload 5 /* anchor */
            invokevirtual sun.security.provider.certpath.ReverseState.updateState:(Ljava/security/cert/TrustAnchor;)V
        23: .line 305
            aload 3 /* currentState */
        24: .line 306
            new sun.security.provider.certpath.CrlRevocationChecker
            dup
            aconst_null
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            aconst_null
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.onlyEECert:Z
            invokespecial sun.security.provider.certpath.CrlRevocationChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/security/cert/PKIXParameters;Ljava/util/Collection;Z)V
        25: .line 305
            putfield sun.security.provider.certpath.ReverseState.crlChecker:Lsun/security/provider/certpath/CrlRevocationChecker;
        26: .line 307
            aload 3 /* currentState */
            new sun.security.provider.certpath.AlgorithmChecker
            dup
            aload 5 /* anchor */
            aconst_null
            invokespecial sun.security.provider.certpath.AlgorithmChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/lang/String;)V
            putfield sun.security.provider.certpath.ReverseState.algorithmChecker:Lsun/security/provider/certpath/AlgorithmChecker;
        27: .line 308
            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;
        28: .line 310
            aload 0 /* this */
            aconst_null
            aload 3 /* currentState */
        29: .line 311
            new sun.security.provider.certpath.ReverseBuilder
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
            invokespecial sun.security.provider.certpath.ReverseBuilder.<init>:(Ljava/security/cert/PKIXBuilderParameters;Ljavax/security/auth/x500/X500Principal;)V
            aload 1 /* adjacencyList */
        30: .line 312
            aload 2 /* certPathList */
        31: .line 310
            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
        32: .line 313
            goto 37
      StackMap locals:
      StackMap stack: java.lang.Exception
        33: astore 6 /* e */
        start local 6 // java.lang.Exception e
        34: .line 315
            aload 4 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifeq 36
        35: .line 316
            goto 39
        36: .line 318
      StackMap locals: java.lang.Exception
      StackMap stack:
            aload 6 /* e */
            athrow
        end local 6 // java.lang.Exception e
        37: .line 322
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 39
        38: .line 323
            goto 40
        end local 5 // java.security.cert.TrustAnchor anchor
        39: .line 287
      StackMap locals:
      StackMap stack:
            aload 4 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        40: .line 327
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 45
        41: .line 328
            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
        42: .line 330
            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
        43: .line 331
            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;
        44: .line 330
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        45: .line 333
      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   46     0           this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   46     1  adjacencyList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0   46     2   certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            6   46     3   currentState  Lsun/security/provider/certpath/ReverseState;
            9   46     4           iter  Ljava/util/Iterator<Ljava/security/cert/TrustAnchor;>;
           11   39     5         anchor  Ljava/security/cert/TrustAnchor;
           34   37     6              e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          28    32      33  Class java.lang.Exception
    Exceptions:
      throws java.lang.Exception
    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=9, 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 342
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 343
            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 347
      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 348
            aload 4 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getCertPathCheckers:()Ljava/util/List;
            invokevirtual sun.security.provider.certpath.ForwardState.initState:(Ljava/util/List;)V
         4: .line 351
            aload 1 /* adjacencyList */
            invokeinterface java.util.List.clear:()V
         5: .line 352
            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 355
            aload 4 /* currentState */
         7: .line 356
            new sun.security.provider.certpath.CrlRevocationChecker
            dup
            aconst_null
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            aconst_null
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.onlyEECert:Z
            invokespecial sun.security.provider.certpath.CrlRevocationChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/security/cert/PKIXParameters;Ljava/util/Collection;Z)V
         8: .line 355
            putfield sun.security.provider.certpath.ForwardState.crlChecker:Lsun/security/provider/certpath/CrlRevocationChecker;
         9: .line 357
            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;
        10: .line 359
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
            aload 4 /* currentState */
        11: .line 360
            new sun.security.provider.certpath.ForwardBuilder
            dup
        12: .line 361
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.targetSubjectDN:Ljavax/security/auth/x500/X500Principal;
            iload 3 /* searchAllCertStores */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.onlyEECert:Z
        13: .line 360
            invokespecial sun.security.provider.certpath.ForwardBuilder.<init>:(Ljava/security/cert/PKIXBuilderParameters;Ljavax/security/auth/x500/X500Principal;ZZ)V
        14: .line 362
            aload 1 /* adjacencyList */
            aload 2 /* certPathList */
        15: .line 359
            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
        16: .line 363
            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   17     0                 this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   17     1        adjacencyList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0   17     2         certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            0   17     3  searchAllCertStores  Z
            3   17     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  

  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: (0x0000) 
    Code:
      stack=9, locals=25, 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 certPathList
         0: .line 387
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 388
            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 389
            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 388
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 396
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
         5: .line 397
            aload 3 /* builder */
            aload 2 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.orderedCertStores:Ljava/util/List;
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getMatchingCerts:(Lsun/security/provider/certpath/State;Ljava/util/List;)Ljava/util/Collection;
            aload 4 /* adjList */
         6: .line 396
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.addVertices:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            astore 6 /* vertices */
        start local 6 // java.util.List vertices
         7: .line 398
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 11
         8: .line 399
            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 400
            aload 6 /* 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 399
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 411
      StackMap locals: java.util.List
      StackMap stack:
            aload 6 /* vertices */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 190
      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.List top java.util.Iterator
      StackMap stack:
        12: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.Vertex
            astore 7 /* vertex */
        start local 7 // sun.security.provider.certpath.Vertex vertex
        13: .line 419
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ForwardState.clone:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.ForwardState
            astore 9 /* nextState */
        start local 9 // sun.security.provider.certpath.ForwardState nextState
        14: .line 420
            aload 7 /* vertex */
            invokevirtual sun.security.provider.certpath.Vertex.getCertificate:()Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
            astore 10 /* cert */
        start local 10 // java.security.cert.X509Certificate cert
        15: .line 423
            aload 3 /* builder */
            aload 10 /* cert */
            aload 9 /* nextState */
            aload 5 /* certPathList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.verifyCert:(Ljava/security/cert/X509Certificate;Lsun/security/provider/certpath/State;Ljava/util/List;)V
        16: .line 424
            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.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 11 /* gse */
        start local 11 // java.security.GeneralSecurityException gse
        18: .line 425
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 23
        19: .line 426
            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 427
            aload 11 /* gse */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 426
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        22: .line 428
            aload 11 /* gse */
            invokevirtual java.security.GeneralSecurityException.printStackTrace:()V
        23: .line 430
      StackMap locals: java.security.GeneralSecurityException
      StackMap stack:
            aload 7 /* vertex */
            aload 11 /* gse */
            invokevirtual sun.security.provider.certpath.Vertex.setThrowable:(Ljava/lang/Throwable;)V
        24: .line 431
            goto 190
        end local 11 // java.security.GeneralSecurityException gse
        25: .line 443
      StackMap locals:
      StackMap stack:
            aload 3 /* builder */
            aload 10 /* cert */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.isPathCompleted:(Ljava/security/cert/X509Certificate;)Z
            ifeq 178
        26: .line 445
            aconst_null
            astore 11 /* basicChecker */
        start local 11 // sun.security.provider.certpath.BasicChecker basicChecker
        27: .line 446
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 29
        28: .line 447
            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
        29: .line 451
      StackMap locals: sun.security.provider.certpath.BasicChecker
      StackMap stack:
            new java.util.ArrayList
            dup
            aload 5 /* certPathList */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
        30: .line 450
            astore 12 /* appendedCerts */
        start local 12 // java.util.ArrayList appendedCerts
        31: .line 459
            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 33
        32: .line 460
            aload 12 /* appendedCerts */
            iconst_0
            aload 10 /* cert */
            invokevirtual java.util.ArrayList.add:(ILjava/lang/Object;)V
        33: .line 463
      StackMap locals: java.util.ArrayList
      StackMap stack:
            new java.util.HashSet
            dup
            iconst_1
            invokespecial java.util.HashSet.<init>:(I)V
            astore 13 /* initExpPolSet */
        start local 13 // java.util.HashSet initExpPolSet
        34: .line 464
            aload 13 /* initExpPolSet */
            ldc "2.5.29.32.0"
            invokevirtual java.util.HashSet.add:(Ljava/lang/Object;)Z
            pop
        35: .line 466
            new sun.security.provider.certpath.PolicyNodeImpl
            dup
            aconst_null
        36: .line 467
            ldc "2.5.29.32.0"
            aconst_null
            iconst_0
            aload 13 /* initExpPolSet */
            iconst_0
        37: .line 466
            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
        38: .line 470
            new sun.security.provider.certpath.PolicyChecker
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getInitialPolicies:()Ljava/util/Set;
        39: .line 471
            aload 12 /* appendedCerts */
            invokevirtual java.util.ArrayList.size:()I
        40: .line 472
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isExplicitPolicyRequired:()Z
        41: .line 473
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isPolicyMappingInhibited:()Z
        42: .line 474
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isAnyPolicyInhibited:()Z
        43: .line 475
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getPolicyQualifiersRejected:()Z
        44: .line 476
            aload 14 /* rootNode */
        45: .line 470
            invokespecial sun.security.provider.certpath.PolicyChecker.<init>:(Ljava/util/Set;IZZZZLsun/security/provider/certpath/PolicyNodeImpl;)V
        46: .line 469
            astore 15 /* policyChecker */
        start local 15 // sun.security.provider.certpath.PolicyChecker policyChecker
        47: .line 479
            new java.util.ArrayList
            dup
        48: .line 480
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getCertPathCheckers:()Ljava/util/List;
        49: .line 478
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            astore 16 /* userCheckers */
        start local 16 // java.util.List userCheckers
        50: .line 481
            iconst_0
            istore 17 /* mustCheck */
        start local 17 // int mustCheck
        51: .line 482
            aload 16 /* userCheckers */
            iload 17 /* mustCheck */
            aload 15 /* policyChecker */
            invokeinterface java.util.List.add:(ILjava/lang/Object;)V
        52: .line 483
            iinc 17 /* mustCheck */ 1
        53: .line 485
            aconst_null
            astore 18 /* variant */
        start local 18 // java.lang.String variant
        54: .line 487
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            instanceof sun.security.provider.certpath.PKIXExtendedParameters
            ifeq 56
        55: .line 488
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            checkcast sun.security.provider.certpath.PKIXExtendedParameters
            invokevirtual sun.security.provider.certpath.PKIXExtendedParameters.getVariant:()Ljava/lang/String;
            astore 18 /* variant */
        56: .line 492
      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.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate sun.security.provider.certpath.BasicChecker java.util.ArrayList java.util.HashSet sun.security.provider.certpath.PolicyNodeImpl sun.security.provider.certpath.PolicyChecker java.util.List int java.lang.String
      StackMap stack:
            aload 16 /* userCheckers */
            iload 17 /* mustCheck */
        57: .line 493
            new sun.security.provider.certpath.AlgorithmChecker
            dup
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        58: .line 494
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getDate:()Ljava/util/Date;
            aload 18 /* variant */
        59: .line 493
            invokespecial sun.security.provider.certpath.AlgorithmChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/util/Date;Ljava/lang/String;)V
        60: .line 492
            invokeinterface java.util.List.add:(ILjava/lang/Object;)V
        61: .line 495
            iinc 17 /* mustCheck */ 1
        62: .line 497
            aload 9 /* nextState */
            invokevirtual sun.security.provider.certpath.ForwardState.keyParamsNeeded:()Z
            ifeq 87
        63: .line 498
            aload 10 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 19 /* rootKey */
        start local 19 // java.security.PublicKey rootKey
        64: .line 499
            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 72
        65: .line 500
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
            astore 19 /* rootKey */
        66: .line 501
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 72
        67: .line 502
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
        68: .line 503
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchForward using buildParams public key: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        69: .line 505
            aload 19 /* rootKey */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        70: .line 503
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        71: .line 502
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        72: .line 507
      StackMap locals: java.security.PublicKey
      StackMap stack:
            new java.security.cert.TrustAnchor
            dup
        73: .line 508
            aload 10 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            aload 19 /* rootKey */
            aconst_null
        74: .line 507
            invokespecial java.security.cert.TrustAnchor.<init>:(Ljavax/security/auth/x500/X500Principal;Ljava/security/PublicKey;[B)V
            astore 20 /* anchor */
        start local 20 // java.security.cert.TrustAnchor anchor
        75: .line 511
            new sun.security.provider.certpath.BasicChecker
            dup
            aload 20 /* anchor */
        76: .line 512
            aload 3 /* builder */
            getfield sun.security.provider.certpath.ForwardBuilder.date:Ljava/util/Date;
        77: .line 513
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getSigProvider:()Ljava/lang/String;
        78: .line 514
            iconst_1
        79: .line 511
            invokespecial sun.security.provider.certpath.BasicChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/util/Date;Ljava/lang/String;Z)V
            astore 11 /* basicChecker */
        80: .line 515
            aload 16 /* userCheckers */
            iload 17 /* mustCheck */
            aload 11 /* basicChecker */
            invokeinterface java.util.List.add:(ILjava/lang/Object;)V
        81: .line 516
            iinc 17 /* mustCheck */ 1
        82: .line 519
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isRevocationEnabled:()Z
            ifeq 87
        83: .line 520
            aload 16 /* userCheckers */
            iload 17 /* mustCheck */
            new sun.security.provider.certpath.CrlRevocationChecker
            dup
        84: .line 521
            aload 20 /* anchor */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            aconst_null
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.onlyEECert:Z
            invokespecial sun.security.provider.certpath.CrlRevocationChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/security/cert/PKIXParameters;Ljava/util/Collection;Z)V
        85: .line 520
            invokeinterface java.util.List.add:(ILjava/lang/Object;)V
        86: .line 522
            iinc 17 /* mustCheck */ 1
        end local 20 // java.security.cert.TrustAnchor anchor
        end local 19 // java.security.PublicKey rootKey
        87: .line 528
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 19 /* i */
        start local 19 // int i
        88: goto 161
        89: .line 529
      StackMap locals: int
      StackMap stack:
            aload 12 /* appendedCerts */
            iload 19 /* i */
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 20 /* currCert */
        start local 20 // java.security.cert.X509Certificate currCert
        90: .line 530
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 94
        91: .line 531
            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
        92: .line 532
            aload 20 /* 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;
        93: .line 531
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        94: .line 534
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 20 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getCriticalExtensionOIDs:()Ljava/util/Set;
        95: .line 533
            astore 21 /* unresCritExts */
        start local 21 // java.util.Set unresCritExts
        96: .line 535
            aload 21 /* unresCritExts */
            ifnonnull 98
        97: .line 536
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 21 /* unresCritExts */
        98: .line 539
      StackMap locals: java.util.Set
      StackMap stack:
            iconst_0
            istore 22 /* j */
        start local 22 // int j
        99: goto 121
       100: .line 540
      StackMap locals: int
      StackMap stack:
            aload 16 /* userCheckers */
            iload 22 /* j */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 23 /* currChecker */
        start local 23 // java.security.cert.PKIXCertPathChecker currChecker
       101: .line 541
            iload 22 /* j */
            iload 17 /* mustCheck */
            if_icmplt 103
       102: .line 542
            aload 23 /* currChecker */
            invokevirtual java.security.cert.PKIXCertPathChecker.isForwardCheckingSupported:()Z
            ifne 120
       103: .line 543
      StackMap locals: java.security.cert.PKIXCertPathChecker
      StackMap stack:
            iload 19 /* i */
            ifne 109
       104: .line 544
            aload 23 /* currChecker */
            iconst_0
            invokevirtual java.security.cert.PKIXCertPathChecker.init:(Z)V
       105: .line 549
            iload 22 /* j */
            iload 17 /* mustCheck */
            if_icmplt 109
       106: .line 550
            aload 23 /* currChecker */
            instanceof sun.security.provider.certpath.AlgorithmChecker
            ifeq 109
       107: .line 551
            aload 23 /* currChecker */
            checkcast sun.security.provider.certpath.AlgorithmChecker
       108: .line 552
            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
       109: .line 557
      StackMap locals:
      StackMap stack:
            aload 23 /* currChecker */
            aload 20 /* currCert */
            aload 21 /* unresCritExts */
            invokevirtual java.security.cert.PKIXCertPathChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
       110: .line 558
            goto 120
      StackMap locals:
      StackMap stack: java.security.cert.CertPathValidatorException
       111: astore 24 /* cpve */
        start local 24 // java.security.cert.CertPathValidatorException cpve
       112: .line 559
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 118
       113: .line 560
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
       114: .line 561
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.depthFirstSearchForward(): final verification failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
       115: .line 562
            aload 24 /* cpve */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
       116: .line 561
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       117: .line 560
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       118: .line 563
      StackMap locals: java.security.cert.CertPathValidatorException
      StackMap stack:
            aload 7 /* vertex */
            aload 24 /* cpve */
            invokevirtual sun.security.provider.certpath.Vertex.setThrowable:(Ljava/lang/Throwable;)V
       119: .line 564
            goto 190
        end local 24 // java.security.cert.CertPathValidatorException cpve
        end local 23 // java.security.cert.PKIXCertPathChecker currChecker
       120: .line 539
      StackMap locals:
      StackMap stack:
            iinc 22 /* j */ 1
      StackMap locals:
      StackMap stack:
       121: iload 22 /* j */
            aload 16 /* userCheckers */
            invokeinterface java.util.List.size:()I
            if_icmplt 100
        end local 22 // int j
       122: .line 576
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getCertPathCheckers:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 23
            goto 129
      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.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate sun.security.provider.certpath.BasicChecker java.util.ArrayList java.util.HashSet sun.security.provider.certpath.PolicyNodeImpl sun.security.provider.certpath.PolicyChecker java.util.List int java.lang.String int java.security.cert.X509Certificate java.util.Set top java.util.Iterator
      StackMap stack:
       123: aload 23
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 22 /* checker */
        start local 22 // java.security.cert.PKIXCertPathChecker checker
       124: .line 578
            aload 22 /* checker */
            invokevirtual java.security.cert.PKIXCertPathChecker.isForwardCheckingSupported:()Z
            ifeq 129
       125: .line 580
            aload 22 /* checker */
            invokevirtual java.security.cert.PKIXCertPathChecker.getSupportedExtensions:()Ljava/util/Set;
       126: .line 579
            astore 24 /* suppExts */
        start local 24 // java.util.Set suppExts
       127: .line 581
            aload 24 /* suppExts */
            ifnull 129
       128: .line 582
            aload 21 /* unresCritExts */
            aload 24 /* suppExts */
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
        end local 24 // java.util.Set suppExts
        end local 22 // java.security.cert.PKIXCertPathChecker checker
       129: .line 575
      StackMap locals:
      StackMap stack:
            aload 23
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 123
       130: .line 587
            aload 21 /* unresCritExts */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 160
       131: .line 588
            aload 21 /* unresCritExts */
       132: .line 589
            getstatic sun.security.x509.PKIXExtensions.BasicConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       133: .line 588
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       134: .line 590
            aload 21 /* unresCritExts */
       135: .line 591
            getstatic sun.security.x509.PKIXExtensions.NameConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       136: .line 590
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       137: .line 592
            aload 21 /* unresCritExts */
       138: .line 593
            getstatic sun.security.x509.PKIXExtensions.CertificatePolicies_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       139: .line 592
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       140: .line 594
            aload 21 /* unresCritExts */
       141: .line 595
            getstatic sun.security.x509.PKIXExtensions.PolicyMappings_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       142: .line 594
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       143: .line 596
            aload 21 /* unresCritExts */
       144: .line 597
            getstatic sun.security.x509.PKIXExtensions.PolicyConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       145: .line 596
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       146: .line 598
            aload 21 /* unresCritExts */
       147: .line 599
            getstatic sun.security.x509.PKIXExtensions.InhibitAnyPolicy_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       148: .line 598
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       149: .line 600
            aload 21 /* unresCritExts */
       150: .line 601
            getstatic sun.security.x509.PKIXExtensions.SubjectAlternativeName_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       151: .line 600
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       152: .line 602
            aload 21 /* unresCritExts */
       153: .line 603
            getstatic sun.security.x509.PKIXExtensions.KeyUsage_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       154: .line 602
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       155: .line 604
            aload 21 /* unresCritExts */
       156: .line 605
            getstatic sun.security.x509.PKIXExtensions.ExtendedKeyUsage_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
       157: .line 604
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
       158: .line 607
            aload 21 /* unresCritExts */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 160
       159: .line 608
            new java.security.cert.CertPathValidatorException
            dup
            ldc "unrecognized critical extension(s)"
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;)V
            athrow
        end local 21 // java.util.Set unresCritExts
        end local 20 // java.security.cert.X509Certificate currCert
       160: .line 528
      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.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate sun.security.provider.certpath.BasicChecker java.util.ArrayList java.util.HashSet sun.security.provider.certpath.PolicyNodeImpl sun.security.provider.certpath.PolicyChecker java.util.List int java.lang.String int
      StackMap stack:
            iinc 19 /* i */ 1
      StackMap locals:
      StackMap stack:
       161: iload 19 /* i */
            aload 12 /* appendedCerts */
            invokevirtual java.util.ArrayList.size:()I
            if_icmplt 89
        end local 19 // int i
       162: .line 613
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 164
       163: .line 614
            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
       164: .line 616
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
       165: .line 623
            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 167
       166: .line 624
            aload 3 /* builder */
            aload 10 /* cert */
            aload 5 /* certPathList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.addCertToPath:(Ljava/security/cert/X509Certificate;Ljava/util/LinkedList;)V
       167: .line 626
      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;
       168: .line 631
            aload 11 /* basicChecker */
            ifnull 171
       169: .line 632
            aload 0 /* this */
            aload 11 /* basicChecker */
            invokevirtual sun.security.provider.certpath.BasicChecker.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
       170: .line 633
            goto 176
       171: .line 635
      StackMap locals:
      StackMap stack:
            aload 5 /* certPathList */
            invokevirtual java.util.LinkedList.size:()I
            ifne 174
       172: .line 636
            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 19 /* finalCert */
        start local 19 // java.security.cert.Certificate finalCert
       173: .line 637
            goto 175
        end local 19 // java.security.cert.Certificate finalCert
       174: .line 638
      StackMap locals:
      StackMap stack:
            aload 5 /* certPathList */
            aload 5 /* certPathList */
            invokevirtual java.util.LinkedList.size:()I
            iconst_1
            isub
            invokevirtual java.util.LinkedList.get:(I)Ljava/lang/Object;
            checkcast java.security.cert.Certificate
            astore 19 /* finalCert */
        start local 19 // java.security.cert.Certificate finalCert
       175: .line 640
      StackMap locals: java.security.cert.Certificate
      StackMap stack:
            aload 0 /* this */
            aload 19 /* finalCert */
            invokevirtual java.security.cert.Certificate.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        end local 19 // java.security.cert.Certificate finalCert
       176: .line 643
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 15 /* policyChecker */
            invokevirtual sun.security.provider.certpath.PolicyChecker.getPolicyTree:()Ljava/security/cert/PolicyNode;
            putfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
       177: .line 644
            return
        end local 18 // java.lang.String variant
        end local 17 // int mustCheck
        end local 16 // java.util.List userCheckers
        end local 15 // sun.security.provider.certpath.PolicyChecker policyChecker
        end local 14 // sun.security.provider.certpath.PolicyNodeImpl rootNode
        end local 13 // java.util.HashSet initExpPolSet
        end local 12 // java.util.ArrayList appendedCerts
        end local 11 // sun.security.provider.certpath.BasicChecker basicChecker
       178: .line 646
      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.List sun.security.provider.certpath.Vertex java.util.Iterator sun.security.provider.certpath.ForwardState java.security.cert.X509Certificate
      StackMap stack:
            aload 3 /* builder */
            aload 10 /* cert */
            aload 5 /* certPathList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.addCertToPath:(Ljava/security/cert/X509Certificate;Ljava/util/LinkedList;)V
       179: .line 650
            aload 9 /* nextState */
            aload 10 /* cert */
            invokevirtual sun.security.provider.certpath.ForwardState.updateState:(Ljava/security/cert/X509Certificate;)V
       180: .line 656
            aload 4 /* adjList */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
       181: .line 657
            aload 7 /* vertex */
            aload 4 /* adjList */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokevirtual sun.security.provider.certpath.Vertex.setIndex:(I)V
       182: .line 660
            aload 0 /* this */
            aload 10 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
       183: .line 661
            aload 9 /* nextState */
            aload 3 /* builder */
            aload 4 /* adjList */
            aload 5 /* certPathList */
       184: .line 660
            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
       185: .line 666
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 187
       186: .line 667
            return
       187: .line 675
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 189
       188: .line 676
            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
       189: .line 678
      StackMap locals:
      StackMap stack:
            aload 3 /* builder */
            aload 5 /* certPathList */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.removeFinalCertFromPath:(Ljava/util/LinkedList;)V
        end local 10 // java.security.cert.X509Certificate cert
        end local 9 // sun.security.provider.certpath.ForwardState nextState
        end local 7 // sun.security.provider.certpath.Vertex vertex
       190: .line 411
      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.List top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
       191: .line 681
            return
        end local 6 // java.util.List vertices
        end local 5 // java.util.LinkedList certPathList
        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  192     0           this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0  192     1             dN  Ljavax/security/auth/x500/X500Principal;
            0  192     2   currentState  Lsun/security/provider/certpath/ForwardState;
            0  192     3        builder  Lsun/security/provider/certpath/ForwardBuilder;
            0  192     4        adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0  192     5   certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            7  192     6       vertices  Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;
           13  190     7         vertex  Lsun/security/provider/certpath/Vertex;
           14  190     9      nextState  Lsun/security/provider/certpath/ForwardState;
           15  190    10           cert  Ljava/security/cert/X509Certificate;
           18   25    11            gse  Ljava/security/GeneralSecurityException;
           27  178    11   basicChecker  Lsun/security/provider/certpath/BasicChecker;
           31  178    12  appendedCerts  Ljava/util/ArrayList<Ljava/security/cert/X509Certificate;>;
           34  178    13  initExpPolSet  Ljava/util/HashSet<Ljava/lang/String;>;
           38  178    14       rootNode  Lsun/security/provider/certpath/PolicyNodeImpl;
           47  178    15  policyChecker  Lsun/security/provider/certpath/PolicyChecker;
           50  178    16   userCheckers  Ljava/util/List<Ljava/security/cert/PKIXCertPathChecker;>;
           51  178    17      mustCheck  I
           54  178    18        variant  Ljava/lang/String;
           64   87    19        rootKey  Ljava/security/PublicKey;
           75   87    20         anchor  Ljava/security/cert/TrustAnchor;
           88  162    19              i  I
           90  160    20       currCert  Ljava/security/cert/X509Certificate;
           96  160    21  unresCritExts  Ljava/util/Set<Ljava/lang/String;>;
           99  122    22              j  I
          101  120    23    currChecker  Ljava/security/cert/PKIXCertPathChecker;
          112  120    24           cpve  Ljava/security/cert/CertPathValidatorException;
          124  129    22        checker  Ljava/security/cert/PKIXCertPathChecker;
          127  129    24       suppExts  Ljava/util/Set<Ljava/lang/String;>;
          173  174    19      finalCert  Ljava/security/cert/Certificate;
          175  176    19      finalCert  Ljava/security/cert/Certificate;
      Exception table:
        from    to  target  type
          15    16      17  Class java.security.GeneralSecurityException
         109   110     111  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       
      certPathList  

  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: (0x0000) 
    Code:
      stack=6, locals=12, 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 certPathList
         0: .line 703
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 704
            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 705
            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 704
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 711
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
         5: .line 712
            aload 3 /* builder */
            aload 2 /* currentState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.orderedCertStores:Ljava/util/List;
            invokevirtual sun.security.provider.certpath.ReverseBuilder.getMatchingCerts:(Lsun/security/provider/certpath/State;Ljava/util/List;)Ljava/util/Collection;
            aload 4 /* adjList */
         6: .line 711
            invokevirtual sun.security.provider.certpath.SunCertPathBuilder.addVertices:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            astore 6 /* vertices */
        start local 6 // java.util.List vertices
         7: .line 713
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 11
         8: .line 714
            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 715
            aload 6 /* 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 714
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 723
      StackMap locals: java.util.List
      StackMap stack:
            aload 6 /* vertices */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 56
      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.List top java.util.Iterator
      StackMap stack:
        12: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.Vertex
            astore 7 /* vertex */
        start local 7 // sun.security.provider.certpath.Vertex vertex
        13: .line 731
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ReverseState.clone:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.ReverseState
            astore 9 /* nextState */
        start local 9 // sun.security.provider.certpath.ReverseState nextState
        14: .line 732
            aload 7 /* vertex */
            invokevirtual sun.security.provider.certpath.Vertex.getCertificate:()Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
            astore 10 /* cert */
        start local 10 // java.security.cert.X509Certificate cert
        15: .line 734
            aload 3 /* builder */
            aload 10 /* cert */
            aload 9 /* nextState */
            aload 5 /* certPathList */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.verifyCert:(Ljava/security/cert/X509Certificate;Lsun/security/provider/certpath/State;Ljava/util/List;)V
        16: .line 735
            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.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 11 /* gse */
        start local 11 // java.security.GeneralSecurityException gse
        18: .line 736
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 22
        19: .line 737
            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 738
            aload 11 /* gse */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 737
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        22: .line 739
      StackMap locals: java.security.GeneralSecurityException
      StackMap stack:
            aload 7 /* vertex */
            aload 11 /* gse */
            invokevirtual sun.security.provider.certpath.Vertex.setThrowable:(Ljava/lang/Throwable;)V
        23: .line 740
            goto 56
        end local 11 // java.security.GeneralSecurityException gse
        24: .line 747
      StackMap locals:
      StackMap stack:
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ReverseState.isInitial:()Z
            ifne 26
        25: .line 748
            aload 3 /* builder */
            aload 10 /* cert */
            aload 5 /* certPathList */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.addCertToPath:(Ljava/security/cert/X509Certificate;Ljava/util/LinkedList;)V
        26: .line 750
      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 755
            aload 3 /* builder */
            aload 10 /* cert */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.isPathCompleted:(Ljava/security/cert/X509Certificate;)Z
            ifeq 44
        28: .line 756
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 30
        29: .line 757
            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 759
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
        31: .line 761
            aload 9 /* nextState */
            getfield sun.security.provider.certpath.ReverseState.rootNode:Lsun/security/provider/certpath/PolicyNodeImpl;
            astore 11 /* rootNode */
        start local 11 // sun.security.provider.certpath.PolicyNodeImpl rootNode
        32: .line 763
            aload 11 /* rootNode */
            ifnonnull 34
        33: .line 764
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.certpath.SunCertPathBuilder.policyTreeResult:Ljava/security/cert/PolicyNode;
            goto 36
        34: .line 766
      StackMap locals: sun.security.provider.certpath.PolicyNodeImpl
      StackMap stack:
            aload 0 /* this */
            aload 11 /* 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 767
            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 773
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 10 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        37: .line 774
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
            instanceof java.security.interfaces.DSAPublicKey
            ifeq 43
        38: .line 775
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
            checkcast java.security.interfaces.DSAPublicKey
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            ifnonnull 43
        39: .line 777
            aload 0 /* this */
        40: .line 779
            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;
        41: .line 778
            invokestatic sun.security.provider.certpath.BasicChecker.makeInheritedParamsKey:(Ljava/security/PublicKey;Ljava/security/PublicKey;)Ljava/security/PublicKey;
        42: .line 777
            putfield sun.security.provider.certpath.SunCertPathBuilder.finalPublicKey:Ljava/security/PublicKey;
        43: .line 782
      StackMap locals:
      StackMap stack:
            return
        end local 11 // sun.security.provider.certpath.PolicyNodeImpl rootNode
        44: .line 786
      StackMap locals:
      StackMap stack:
            aload 9 /* nextState */
            aload 10 /* cert */
            invokevirtual sun.security.provider.certpath.ReverseState.updateState:(Ljava/security/cert/X509Certificate;)V
        45: .line 792
            aload 4 /* adjList */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        46: .line 793
            aload 7 /* vertex */
            aload 4 /* adjList */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokevirtual sun.security.provider.certpath.Vertex.setIndex:(I)V
        47: .line 796
            aload 0 /* this */
            aload 10 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            aload 9 /* nextState */
        48: .line 797
            aload 3 /* builder */
            aload 4 /* adjList */
            aload 5 /* certPathList */
        49: .line 796
            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
        50: .line 802
            aload 0 /* this */
            getfield sun.security.provider.certpath.SunCertPathBuilder.pathCompleted:Z
            ifeq 52
        51: .line 803
            return
        52: .line 811
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 54
        53: .line 812
            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
        54: .line 814
      StackMap locals:
      StackMap stack:
            aload 2 /* currentState */
            invokevirtual sun.security.provider.certpath.ReverseState.isInitial:()Z
            ifne 56
        55: .line 815
            aload 3 /* builder */
            aload 5 /* certPathList */
            invokevirtual sun.security.provider.certpath.ReverseBuilder.removeFinalCertFromPath:(Ljava/util/LinkedList;)V
        end local 10 // java.security.cert.X509Certificate cert
        end local 9 // sun.security.provider.certpath.ReverseState nextState
        end local 7 // sun.security.provider.certpath.Vertex vertex
        56: .line 723
      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.List top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        57: .line 818
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 59
        58: .line 819
            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
        59: .line 821
      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.List
      StackMap stack:
            return
        end local 6 // java.util.List vertices
        end local 5 // java.util.LinkedList certPathList
        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   60     0          this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   60     1            dN  Ljavax/security/auth/x500/X500Principal;
            0   60     2  currentState  Lsun/security/provider/certpath/ReverseState;
            0   60     3       builder  Lsun/security/provider/certpath/ReverseBuilder;
            0   60     4       adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            0   60     5  certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
            7   60     6      vertices  Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;
           13   56     7        vertex  Lsun/security/provider/certpath/Vertex;
           14   56     9     nextState  Lsun/security/provider/certpath/ReverseState;
           15   56    10          cert  Ljava/security/cert/X509Certificate;
           18   24    11           gse  Ljava/security/GeneralSecurityException;
           32   44    11      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       
      certPathList  

  private 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: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=7, args_size=3
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // java.util.Collection certs
        start local 2 // java.util.List adjList
         0: .line 829
            aload 2 /* adjList */
            aload 2 /* adjList */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.util.List
            astore 3 /* l */
        start local 3 // java.util.List l
         1: .line 831
            aload 1 /* certs */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 5
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder java.util.Collection java.util.List java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 4 /* cert */
        start local 4 // java.security.cert.X509Certificate cert
         3: .line 832
            new sun.security.provider.certpath.Vertex
            dup
            aload 4 /* cert */
            invokespecial sun.security.provider.certpath.Vertex.<init>:(Ljava/security/cert/Certificate;)V
            astore 6 /* v */
        start local 6 // sun.security.provider.certpath.Vertex v
         4: .line 833
            aload 3 /* l */
            aload 6 /* v */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 6 // sun.security.provider.certpath.Vertex v
        end local 4 // java.security.cert.X509Certificate cert
         5: .line 831
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 836
            aload 3 /* l */
            areturn
        end local 3 // java.util.List l
        end local 2 // java.util.List adjList
        end local 1 // java.util.Collection certs
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0    7     1    certs  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            0    7     2  adjList  Ljava/util/List<Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;>;
            1    7     3        l  Ljava/util/List<Lsun/security/provider/certpath/Vertex;>;
            3    5     4     cert  Ljava/security/cert/X509Certificate;
            4    5     6        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 boolean anchorIsTarget(java.security.cert.TrustAnchor, java.security.cert.X509CertSelector);
    descriptor: (Ljava/security/cert/TrustAnchor;Ljava/security/cert/X509CertSelector;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // java.security.cert.TrustAnchor anchor
        start local 2 // java.security.cert.X509CertSelector sel
         0: .line 844
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            astore 3 /* anchorCert */
        start local 3 // java.security.cert.X509Certificate anchorCert
         1: .line 845
            aload 3 /* anchorCert */
            ifnull 3
         2: .line 846
            aload 2 /* sel */
            aload 3 /* anchorCert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ireturn
         3: .line 848
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            iconst_0
            ireturn
        end local 3 // java.security.cert.X509Certificate anchorCert
        end local 2 // java.security.cert.X509CertSelector sel
        end local 1 // java.security.cert.TrustAnchor anchor
        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      anchor  Ljava/security/cert/TrustAnchor;
            0    4     2         sel  Ljava/security/cert/X509CertSelector;
            1    4     3  anchorCert  Ljava/security/cert/X509Certificate;
    MethodParameters:
        Name  Flags
      anchor  
      sel     

  private javax.security.auth.x500.X500Principal getTargetSubjectDN(java.util.List<java.security.cert.CertStore>, java.security.cert.X509CertSelector);
    descriptor: (Ljava/util/List;Ljava/security/cert/X509CertSelector;)Ljavax/security/auth/x500/X500Principal;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=3
        start local 0 // sun.security.provider.certpath.SunCertPathBuilder this
        start local 1 // java.util.List stores
        start local 2 // java.security.cert.X509CertSelector targetSel
         0: .line 871
            aload 1 /* stores */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 15
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder java.util.List java.security.cert.X509CertSelector top java.util.Iterator
      StackMap stack:
         1: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.CertStore
            astore 3 /* store */
        start local 3 // java.security.cert.CertStore store
         2: .line 875
            aload 3 /* store */
            aload 2 /* targetSel */
            invokevirtual java.security.cert.CertStore.getCertificates:(Ljava/security/cert/CertSelector;)Ljava/util/Collection;
         3: .line 873
            astore 5 /* targetCerts */
        start local 5 // java.util.Collection targetCerts
         4: .line 876
            aload 5 /* targetCerts */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 15
         5: .line 878
            aload 5 /* targetCerts */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
         6: .line 877
            astore 6 /* targetCert */
        start local 6 // java.security.cert.X509Certificate targetCert
         7: .line 879
            aload 6 /* targetCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
         8: areturn
        end local 6 // java.security.cert.X509Certificate targetCert
        end local 5 // java.util.Collection targetCerts
         9: .line 881
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder java.util.List java.security.cert.X509CertSelector java.security.cert.CertStore java.util.Iterator
      StackMap stack: java.security.cert.CertStoreException
            astore 5 /* e */
        start local 5 // java.security.cert.CertStoreException e
        10: .line 883
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            ifnull 15
        11: .line 884
            getstatic sun.security.provider.certpath.SunCertPathBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "SunCertPathBuilder.getTargetSubjectDN: non-fatal exception retrieving certs: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        12: .line 885
            aload 5 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 884
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 886
            aload 5 /* e */
            invokevirtual java.security.cert.CertStoreException.printStackTrace:()V
        end local 5 // java.security.cert.CertStoreException e
        end local 3 // java.security.cert.CertStore store
        15: .line 871
      StackMap locals: sun.security.provider.certpath.SunCertPathBuilder java.util.List java.security.cert.X509CertSelector top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
        16: .line 890
            aconst_null
            areturn
        end local 2 // java.security.cert.X509CertSelector targetSel
        end local 1 // java.util.List stores
        end local 0 // sun.security.provider.certpath.SunCertPathBuilder this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   17     0         this  Lsun/security/provider/certpath/SunCertPathBuilder;
            0   17     1       stores  Ljava/util/List<Ljava/security/cert/CertStore;>;
            0   17     2    targetSel  Ljava/security/cert/X509CertSelector;
            2   15     3        store  Ljava/security/cert/CertStore;
            4    9     5  targetCerts  Ljava/util/Collection<+Ljava/security/cert/Certificate;>;
            7    9     6   targetCert  Ljava/security/cert/X509Certificate;
           10   15     5            e  Ljava/security/cert/CertStoreException;
      Exception table:
        from    to  target  type
           2     8       9  Class java.security.cert.CertStoreException
    Signature: (Ljava/util/List<Ljava/security/cert/CertStore;>;Ljava/security/cert/X509CertSelector;)Ljavax/security/auth/x500/X500Principal;
    MethodParameters:
           Name  Flags
      stores     
      targetSel  
}
SourceFile: "SunCertPathBuilder.java"
NestMembers:
  sun.security.provider.certpath.SunCertPathBuilder$CertStoreComparator
InnerClasses:
  private CertStoreComparator = sun.security.provider.certpath.SunCertPathBuilder$CertStoreComparator of sun.security.provider.certpath.SunCertPathBuilder