class sun.security.provider.certpath.ForwardBuilder extends sun.security.provider.certpath.Builder
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.provider.certpath.ForwardBuilder
  super_class: sun.security.provider.certpath.Builder
{
  private static final sun.security.util.Debug debug;
    descriptor: Lsun/security/util/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final java.util.Set<java.security.cert.X509Certificate> trustedCerts;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Ljava/security/cert/X509Certificate;>;

  private final java.util.Set<javax.security.auth.x500.X500Principal> trustedSubjectDNs;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Ljavax/security/auth/x500/X500Principal;>;

  private final java.util.Set<java.security.cert.TrustAnchor> trustAnchors;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Ljava/security/cert/TrustAnchor;>;

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

  private sun.security.provider.certpath.AdaptableX509CertSelector caSelector;
    descriptor: Lsun/security/provider/certpath/AdaptableX509CertSelector;
    flags: (0x0002) ACC_PRIVATE

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

  java.security.cert.TrustAnchor trustAnchor;
    descriptor: Ljava/security/cert/TrustAnchor;
    flags: (0x0000) 

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

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

  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 74
            ldc "certpath"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.security.cert.PKIXBuilderParameters, javax.security.auth.x500.X500Principal, boolean, boolean);
    descriptor: (Ljava/security/cert/PKIXBuilderParameters;Ljavax/security/auth/x500/X500Principal;ZZ)V
    flags: (0x0000) 
    Code:
      stack=4, locals=8, args_size=5
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // java.security.cert.PKIXBuilderParameters buildParams
        start local 2 // javax.security.auth.x500.X500Principal targetSubjectDN
        start local 3 // boolean searchAllCertStores
        start local 4 // boolean onlyEECert
         0: .line 95
            aload 0 /* this */
            aload 1 /* buildParams */
            aload 2 /* targetSubjectDN */
            invokespecial sun.security.provider.certpath.Builder.<init>:(Ljava/security/cert/PKIXBuilderParameters;Ljavax/security/auth/x500/X500Principal;)V
         1: .line 83
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ForwardBuilder.searchAllCertStores:Z
         2: .line 84
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ForwardBuilder.onlyEECert:Z
         3: .line 98
            aload 0 /* this */
            aload 1 /* buildParams */
            invokevirtual java.security.cert.PKIXBuilderParameters.getTrustAnchors:()Ljava/util/Set;
            putfield sun.security.provider.certpath.ForwardBuilder.trustAnchors:Ljava/util/Set;
         4: .line 99
            aload 0 /* this */
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchors:Ljava/util/Set;
            invokeinterface java.util.Set.size:()I
            invokespecial java.util.HashSet.<init>:(I)V
            putfield sun.security.provider.certpath.ForwardBuilder.trustedCerts:Ljava/util/Set;
         5: .line 100
            aload 0 /* this */
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchors:Ljava/util/Set;
            invokeinterface java.util.Set.size:()I
            invokespecial java.util.HashSet.<init>:(I)V
            putfield sun.security.provider.certpath.ForwardBuilder.trustedSubjectDNs:Ljava/util/Set;
         6: .line 101
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchors:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6
            goto 14
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.PKIXBuilderParameters javax.security.auth.x500.X500Principal int int top java.util.Iterator
      StackMap stack:
         7: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.TrustAnchor
            astore 5 /* anchor */
        start local 5 // java.security.cert.TrustAnchor anchor
         8: .line 102
            aload 5 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            astore 7 /* trustedCert */
        start local 7 // java.security.cert.X509Certificate trustedCert
         9: .line 103
            aload 7 /* trustedCert */
            ifnull 13
        10: .line 104
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustedCerts:Ljava/util/Set;
            aload 7 /* trustedCert */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        11: .line 105
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustedSubjectDNs:Ljava/util/Set;
            aload 7 /* trustedCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        12: .line 106
            goto 14
        13: .line 107
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.PKIXBuilderParameters javax.security.auth.x500.X500Principal int int java.security.cert.TrustAnchor java.util.Iterator java.security.cert.X509Certificate
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustedSubjectDNs:Ljava/util/Set;
            aload 5 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCA:()Ljavax/security/auth/x500/X500Principal;
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // java.security.cert.X509Certificate trustedCert
        end local 5 // java.security.cert.TrustAnchor anchor
        14: .line 101
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.PKIXBuilderParameters javax.security.auth.x500.X500Principal int int top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        15: .line 110
            aload 0 /* this */
            new sun.security.provider.certpath.ForwardBuilder$PKIXCertComparator
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustedSubjectDNs:Ljava/util/Set;
            invokespecial sun.security.provider.certpath.ForwardBuilder$PKIXCertComparator.<init>:(Ljava/util/Set;)V
            putfield sun.security.provider.certpath.ForwardBuilder.comparator:Ljava/util/Comparator;
        16: .line 111
            aload 0 /* this */
            iload 3 /* searchAllCertStores */
            putfield sun.security.provider.certpath.ForwardBuilder.searchAllCertStores:Z
        17: .line 112
            aload 0 /* this */
            iload 4 /* onlyEECert */
            putfield sun.security.provider.certpath.ForwardBuilder.onlyEECert:Z
        18: .line 113
            return
        end local 4 // boolean onlyEECert
        end local 3 // boolean searchAllCertStores
        end local 2 // javax.security.auth.x500.X500Principal targetSubjectDN
        end local 1 // java.security.cert.PKIXBuilderParameters buildParams
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   19     0                 this  Lsun/security/provider/certpath/ForwardBuilder;
            0   19     1          buildParams  Ljava/security/cert/PKIXBuilderParameters;
            0   19     2      targetSubjectDN  Ljavax/security/auth/x500/X500Principal;
            0   19     3  searchAllCertStores  Z
            0   19     4           onlyEECert  Z
            8   14     5               anchor  Ljava/security/cert/TrustAnchor;
            9   14     7          trustedCert  Ljava/security/cert/X509Certificate;
    MethodParameters:
                     Name  Flags
      buildParams          
      targetSubjectDN      
      searchAllCertStores  
      onlyEECert           

  java.util.Collection<java.security.cert.X509Certificate> getMatchingCerts(sun.security.provider.certpath.State, java.util.List<java.security.cert.CertStore>);
    descriptor: (Lsun/security/provider/certpath/State;Ljava/util/List;)Ljava/util/Collection;
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=3
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // sun.security.provider.certpath.State currentState
        start local 2 // java.util.List certStores
         0: .line 128
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 129
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.getMatchingCerts()..."
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 132
      StackMap locals:
      StackMap stack:
            aload 1 /* currentState */
            checkcast sun.security.provider.certpath.ForwardState
            astore 3 /* currState */
        start local 3 // sun.security.provider.certpath.ForwardState currState
         3: .line 139
            new java.util.TreeSet
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.comparator:Ljava/util/Comparator;
            invokespecial java.util.TreeSet.<init>:(Ljava/util/Comparator;)V
            astore 4 /* certs */
        start local 4 // java.util.Set certs
         4: .line 144
            aload 3 /* currState */
            invokevirtual sun.security.provider.certpath.ForwardState.isInitial:()Z
            ifeq 6
         5: .line 145
            aload 0 /* this */
            aload 3 /* currState */
            aload 2 /* certStores */
            aload 4 /* certs */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getMatchingEECerts:(Lsun/security/provider/certpath/ForwardState;Ljava/util/List;Ljava/util/Collection;)V
         6: .line 147
      StackMap locals: sun.security.provider.certpath.ForwardState java.util.Set
      StackMap stack:
            aload 0 /* this */
            aload 3 /* currState */
            aload 2 /* certStores */
            aload 4 /* certs */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getMatchingCACerts:(Lsun/security/provider/certpath/ForwardState;Ljava/util/List;Ljava/util/Collection;)V
         7: .line 149
            aload 4 /* certs */
            areturn
        end local 4 // java.util.Set certs
        end local 3 // sun.security.provider.certpath.ForwardState currState
        end local 2 // java.util.List certStores
        end local 1 // sun.security.provider.certpath.State currentState
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    8     0          this  Lsun/security/provider/certpath/ForwardBuilder;
            0    8     1  currentState  Lsun/security/provider/certpath/State;
            0    8     2    certStores  Ljava/util/List<Ljava/security/cert/CertStore;>;
            3    8     3     currState  Lsun/security/provider/certpath/ForwardState;
            4    8     4         certs  Ljava/util/Set<Ljava/security/cert/X509Certificate;>;
    Exceptions:
      throws java.security.cert.CertStoreException, java.security.cert.CertificateException, java.io.IOException
    Signature: (Lsun/security/provider/certpath/State;Ljava/util/List<Ljava/security/cert/CertStore;>;)Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
              Name  Flags
      currentState  
      certStores    

  private void getMatchingEECerts(sun.security.provider.certpath.ForwardState, java.util.List<java.security.cert.CertStore>, java.util.Collection<java.security.cert.X509Certificate>);
    descriptor: (Lsun/security/provider/certpath/ForwardState;Ljava/util/List;Ljava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // sun.security.provider.certpath.ForwardState currentState
        start local 2 // java.util.List certStores
        start local 3 // java.util.Collection eeCerts
         0: .line 160
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 161
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.getMatchingEECerts()..."
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 171
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.eeSelector:Ljava/security/cert/X509CertSelector;
            ifnonnull 8
         3: .line 172
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.targetCertConstraints:Ljava/security/cert/X509CertSelector;
            invokevirtual java.security.cert.X509CertSelector.clone:()Ljava/lang/Object;
            checkcast java.security.cert.X509CertSelector
            putfield sun.security.provider.certpath.ForwardBuilder.eeSelector:Ljava/security/cert/X509CertSelector;
         4: .line 177
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.eeSelector:Ljava/security/cert/X509CertSelector;
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.date:Ljava/util/Date;
            invokevirtual java.security.cert.X509CertSelector.setCertificateValid:(Ljava/util/Date;)V
         5: .line 182
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isExplicitPolicyRequired:()Z
            ifeq 7
         6: .line 183
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.eeSelector:Ljava/security/cert/X509CertSelector;
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getMatchingPolicies:()Ljava/util/Set;
            invokevirtual java.security.cert.X509CertSelector.setPolicy:(Ljava/util/Set;)V
         7: .line 188
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.eeSelector:Ljava/security/cert/X509CertSelector;
            bipush -2
            invokevirtual java.security.cert.X509CertSelector.setBasicConstraints:(I)V
         8: .line 192
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.eeSelector:Ljava/security/cert/X509CertSelector;
            aload 2 /* certStores */
            aload 3 /* eeCerts */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.searchAllCertStores:Z
            invokevirtual sun.security.provider.certpath.ForwardBuilder.addMatchingCerts:(Ljava/security/cert/X509CertSelector;Ljava/util/Collection;Ljava/util/Collection;Z)Z
            pop
         9: .line 193
            return
        end local 3 // java.util.Collection eeCerts
        end local 2 // java.util.List certStores
        end local 1 // sun.security.provider.certpath.ForwardState currentState
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   10     0          this  Lsun/security/provider/certpath/ForwardBuilder;
            0   10     1  currentState  Lsun/security/provider/certpath/ForwardState;
            0   10     2    certStores  Ljava/util/List<Ljava/security/cert/CertStore;>;
            0   10     3       eeCerts  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    Exceptions:
      throws java.io.IOException
    Signature: (Lsun/security/provider/certpath/ForwardState;Ljava/util/List<Ljava/security/cert/CertStore;>;Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      currentState  
      certStores    
      eeCerts       

  private void getMatchingCACerts(sun.security.provider.certpath.ForwardState, java.util.List<java.security.cert.CertStore>, java.util.Collection<java.security.cert.X509Certificate>);
    descriptor: (Lsun/security/provider/certpath/ForwardState;Ljava/util/List;Ljava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=4
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // sun.security.provider.certpath.ForwardState currentState
        start local 2 // java.util.List certStores
        start local 3 // java.util.Collection caCerts
         0: .line 203
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 204
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.getMatchingCACerts()..."
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 206
      StackMap locals:
      StackMap stack:
            aload 3 /* caCerts */
            invokeinterface java.util.Collection.size:()I
            istore 4 /* initialSize */
        start local 4 // int initialSize
         3: .line 212
            aconst_null
            astore 5 /* sel */
        start local 5 // java.security.cert.X509CertSelector sel
         4: .line 214
            aload 1 /* currentState */
            invokevirtual sun.security.provider.certpath.ForwardState.isInitial:()Z
            ifeq 18
         5: .line 215
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.targetCertConstraints:Ljava/security/cert/X509CertSelector;
            invokevirtual java.security.cert.X509CertSelector.getBasicConstraints:()I
            bipush -2
            if_icmpne 7
         6: .line 217
            return
         7: .line 223
      StackMap locals: int java.security.cert.X509CertSelector
      StackMap stack:
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 9
         8: .line 224
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.getMatchingCACerts(): ca is target"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         9: .line 227
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caTargetSelector:Ljava/security/cert/X509CertSelector;
            ifnonnull 15
        10: .line 228
            aload 0 /* this */
        11: .line 229
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.targetCertConstraints:Ljava/security/cert/X509CertSelector;
            invokevirtual java.security.cert.X509CertSelector.clone:()Ljava/lang/Object;
        12: .line 228
            checkcast java.security.cert.X509CertSelector
            putfield sun.security.provider.certpath.ForwardBuilder.caTargetSelector:Ljava/security/cert/X509CertSelector;
        13: .line 241
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isExplicitPolicyRequired:()Z
            ifeq 15
        14: .line 242
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caTargetSelector:Ljava/security/cert/X509CertSelector;
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getMatchingPolicies:()Ljava/util/Set;
            invokevirtual java.security.cert.X509CertSelector.setPolicy:(Ljava/util/Set;)V
        15: .line 249
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caTargetSelector:Ljava/security/cert/X509CertSelector;
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.traversedCACerts:I
            invokevirtual java.security.cert.X509CertSelector.setBasicConstraints:(I)V
        16: .line 251
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caTargetSelector:Ljava/security/cert/X509CertSelector;
            astore 5 /* sel */
        17: .line 252
            goto 33
        18: .line 254
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            ifnonnull 22
        19: .line 255
            aload 0 /* this */
            new sun.security.provider.certpath.AdaptableX509CertSelector
            dup
            invokespecial sun.security.provider.certpath.AdaptableX509CertSelector.<init>:()V
            putfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
        20: .line 267
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isExplicitPolicyRequired:()Z
            ifeq 22
        21: .line 268
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getMatchingPolicies:()Ljava/util/Set;
            invokevirtual sun.security.provider.certpath.AdaptableX509CertSelector.setPolicy:(Ljava/util/Set;)V
        22: .line 274
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.issuerDN:Ljavax/security/auth/x500/X500Principal;
            invokevirtual sun.security.provider.certpath.AdaptableX509CertSelector.setSubject:(Ljavax/security/auth/x500/X500Principal;)V
        23: .line 282
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.subjectNamesTraversed:Ljava/util/HashSet;
        24: .line 281
            invokestatic sun.security.provider.certpath.CertPathHelper.setPathToNames:(Ljava/security/cert/X509CertSelector;Ljava/util/Set;)V
        25: .line 288
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.traversedCACerts:I
            invokevirtual sun.security.provider.certpath.AdaptableX509CertSelector.setBasicConstraints:(I)V
        26: .line 295
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.cert:Lsun/security/x509/X509CertImpl;
            invokevirtual sun.security.x509.X509CertImpl.getAuthorityKeyIdentifierExtension:()Lsun/security/x509/AuthorityKeyIdentifierExtension;
        27: .line 294
            astore 6 /* akidext */
        start local 6 // sun.security.x509.AuthorityKeyIdentifierExtension akidext
        28: .line 296
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            aload 6 /* akidext */
            invokevirtual sun.security.provider.certpath.AdaptableX509CertSelector.parseAuthorityKeyIdentifierExtension:(Lsun/security/x509/AuthorityKeyIdentifierExtension;)V
        29: .line 301
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.cert:Lsun/security/x509/X509CertImpl;
            invokevirtual sun.security.x509.X509CertImpl.getNotBefore:()Ljava/util/Date;
        30: .line 302
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.cert:Lsun/security/x509/X509CertImpl;
            invokevirtual sun.security.x509.X509CertImpl.getNotAfter:()Ljava/util/Date;
        31: .line 301
            invokevirtual sun.security.provider.certpath.AdaptableX509CertSelector.setValidityPeriod:(Ljava/util/Date;Ljava/util/Date;)V
        32: .line 304
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            astore 5 /* sel */
        end local 6 // sun.security.x509.AuthorityKeyIdentifierExtension akidext
        33: .line 307
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustedCerts:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 7
            goto 40
      StackMap locals: sun.security.provider.certpath.ForwardBuilder sun.security.provider.certpath.ForwardState java.util.List java.util.Collection int java.security.cert.X509CertSelector top java.util.Iterator
      StackMap stack:
        34: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 6 /* trustedCert */
        start local 6 // java.security.cert.X509Certificate trustedCert
        35: .line 308
            aload 5 /* sel */
            aload 6 /* trustedCert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 40
        36: .line 309
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 38
        37: .line 310
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.getMatchingCACerts: found matching trust anchor"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        38: .line 313
      StackMap locals: sun.security.provider.certpath.ForwardBuilder sun.security.provider.certpath.ForwardState java.util.List java.util.Collection int java.security.cert.X509CertSelector java.security.cert.X509Certificate java.util.Iterator
      StackMap stack:
            aload 3 /* caCerts */
            aload 6 /* trustedCert */
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            ifeq 40
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.searchAllCertStores:Z
            ifne 40
        39: .line 314
            return
        end local 6 // java.security.cert.X509Certificate trustedCert
        40: .line 307
      StackMap locals: sun.security.provider.certpath.ForwardBuilder sun.security.provider.certpath.ForwardState java.util.List java.util.Collection int java.security.cert.X509CertSelector top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 34
        41: .line 323
            aload 5 /* sel */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.date:Ljava/util/Date;
            invokevirtual java.security.cert.X509CertSelector.setCertificateValid:(Ljava/util/Date;)V
        42: .line 332
            aload 1 /* currentState */
            invokevirtual sun.security.provider.certpath.ForwardState.isInitial:()Z
            ifne 45
        43: .line 333
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getMaxPathLength:()I
            iconst_m1
            if_icmpeq 45
        44: .line 334
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getMaxPathLength:()I
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.traversedCACerts:I
            if_icmple 50
        45: .line 336
      StackMap locals: sun.security.provider.certpath.ForwardBuilder sun.security.provider.certpath.ForwardState java.util.List java.util.Collection int java.security.cert.X509CertSelector
      StackMap stack:
            aload 0 /* this */
            aload 5 /* sel */
            aload 2 /* certStores */
        46: .line 337
            aload 3 /* caCerts */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.searchAllCertStores:Z
        47: .line 336
            invokevirtual sun.security.provider.certpath.ForwardBuilder.addMatchingCerts:(Ljava/security/cert/X509CertSelector;Ljava/util/Collection;Ljava/util/Collection;Z)Z
        48: .line 337
            ifeq 50
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.searchAllCertStores:Z
            ifne 50
        49: .line 338
            return
        50: .line 342
      StackMap locals:
      StackMap stack:
            aload 1 /* currentState */
            invokevirtual sun.security.provider.certpath.ForwardState.isInitial:()Z
            ifne 55
            getstatic sun.security.provider.certpath.Builder.USE_AIA:Z
            ifeq 55
        51: .line 345
            aload 1 /* currentState */
            getfield sun.security.provider.certpath.ForwardState.cert:Lsun/security/x509/X509CertImpl;
            invokevirtual sun.security.x509.X509CertImpl.getAuthorityInfoAccessExtension:()Lsun/security/x509/AuthorityInfoAccessExtension;
        52: .line 344
            astore 6 /* aiaExt */
        start local 6 // sun.security.x509.AuthorityInfoAccessExtension aiaExt
        53: .line 346
            aload 6 /* aiaExt */
            ifnull 55
        54: .line 347
            aload 0 /* this */
            aload 6 /* aiaExt */
            aload 3 /* caCerts */
            invokevirtual sun.security.provider.certpath.ForwardBuilder.getCerts:(Lsun/security/x509/AuthorityInfoAccessExtension;Ljava/util/Collection;)Z
            pop
        end local 6 // sun.security.x509.AuthorityInfoAccessExtension aiaExt
        55: .line 351
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 60
        56: .line 352
            aload 3 /* caCerts */
            invokeinterface java.util.Collection.size:()I
            iload 4 /* initialSize */
            isub
            istore 6 /* numCerts */
        start local 6 // int numCerts
        57: .line 353
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "ForwardBuilder.getMatchingCACerts: found "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        58: .line 354
            iload 6 /* numCerts */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " CA certs"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        59: .line 353
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 6 // int numCerts
        60: .line 356
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.security.cert.X509CertSelector sel
        end local 4 // int initialSize
        end local 3 // java.util.Collection caCerts
        end local 2 // java.util.List certStores
        end local 1 // sun.security.provider.certpath.ForwardState currentState
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   61     0          this  Lsun/security/provider/certpath/ForwardBuilder;
            0   61     1  currentState  Lsun/security/provider/certpath/ForwardState;
            0   61     2    certStores  Ljava/util/List<Ljava/security/cert/CertStore;>;
            0   61     3       caCerts  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            3   61     4   initialSize  I
            4   61     5           sel  Ljava/security/cert/X509CertSelector;
           28   33     6       akidext  Lsun/security/x509/AuthorityKeyIdentifierExtension;
           35   40     6   trustedCert  Ljava/security/cert/X509Certificate;
           53   55     6        aiaExt  Lsun/security/x509/AuthorityInfoAccessExtension;
           57   60     6      numCerts  I
    Exceptions:
      throws java.io.IOException
    Signature: (Lsun/security/provider/certpath/ForwardState;Ljava/util/List<Ljava/security/cert/CertStore;>;Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      currentState  
      certStores    
      caCerts       

  private boolean getCerts(sun.security.x509.AuthorityInfoAccessExtension, java.util.Collection<java.security.cert.X509Certificate>);
    descriptor: (Lsun/security/x509/AuthorityInfoAccessExtension;Ljava/util/Collection;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=9, args_size=3
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // sun.security.x509.AuthorityInfoAccessExtension aiaExt
        start local 2 // java.util.Collection certs
         0: .line 367
            getstatic sun.security.provider.certpath.Builder.USE_AIA:Z
            ifne 2
         1: .line 368
            iconst_0
            ireturn
         2: .line 370
      StackMap locals:
      StackMap stack:
            aload 1 /* aiaExt */
            invokevirtual sun.security.x509.AuthorityInfoAccessExtension.getAccessDescriptions:()Ljava/util/List;
            astore 3 /* adList */
        start local 3 // java.util.List adList
         3: .line 371
            aload 3 /* adList */
            ifnull 4
            aload 3 /* adList */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 5
         4: .line 372
      StackMap locals: java.util.List
      StackMap stack:
            iconst_0
            ireturn
         5: .line 375
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 4 /* add */
        start local 4 // boolean add
         6: .line 376
            aload 3 /* adList */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 20
      StackMap locals: sun.security.provider.certpath.ForwardBuilder sun.security.x509.AuthorityInfoAccessExtension java.util.Collection java.util.List int top java.util.Iterator
      StackMap stack:
         7: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.x509.AccessDescription
            astore 5 /* ad */
        start local 5 // sun.security.x509.AccessDescription ad
         8: .line 377
            aload 5 /* ad */
            invokestatic sun.security.provider.certpath.URICertStore.getInstance:(Lsun/security/x509/AccessDescription;)Ljava/security/cert/CertStore;
            astore 7 /* cs */
        start local 7 // java.security.cert.CertStore cs
         9: .line 379
            aload 2 /* certs */
        10: .line 380
            aload 7 /* cs */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.caSelector:Lsun/security/provider/certpath/AdaptableX509CertSelector;
            invokevirtual java.security.cert.CertStore.getCertificates:(Ljava/security/cert/CertSelector;)Ljava/util/Collection;
        11: .line 379
            invokeinterface java.util.Collection.addAll:(Ljava/util/Collection;)Z
        12: .line 380
            ifeq 20
        13: .line 381
            iconst_1
            istore 4 /* add */
        14: .line 382
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.searchAllCertStores:Z
            ifne 20
        15: .line 383
            iconst_1
            ireturn
        16: .line 386
      StackMap locals: sun.security.provider.certpath.ForwardBuilder sun.security.x509.AuthorityInfoAccessExtension java.util.Collection java.util.List int sun.security.x509.AccessDescription java.util.Iterator java.security.cert.CertStore
      StackMap stack: java.security.cert.CertStoreException
            astore 8 /* cse */
        start local 8 // java.security.cert.CertStoreException cse
        17: .line 387
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 20
        18: .line 388
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "exception getting certs from CertStore:"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        19: .line 389
            aload 8 /* cse */
            invokevirtual java.security.cert.CertStoreException.printStackTrace:()V
        end local 8 // java.security.cert.CertStoreException cse
        end local 7 // java.security.cert.CertStore cs
        end local 5 // sun.security.x509.AccessDescription ad
        20: .line 376
      StackMap locals: sun.security.provider.certpath.ForwardBuilder sun.security.x509.AuthorityInfoAccessExtension java.util.Collection java.util.List int top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        21: .line 394
            iload 4 /* add */
            ireturn
        end local 4 // boolean add
        end local 3 // java.util.List adList
        end local 2 // java.util.Collection certs
        end local 1 // sun.security.x509.AuthorityInfoAccessExtension aiaExt
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   22     0    this  Lsun/security/provider/certpath/ForwardBuilder;
            0   22     1  aiaExt  Lsun/security/x509/AuthorityInfoAccessExtension;
            0   22     2   certs  Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
            3   22     3  adList  Ljava/util/List<Lsun/security/x509/AccessDescription;>;
            6   22     4     add  Z
            8   20     5      ad  Lsun/security/x509/AccessDescription;
            9   20     7      cs  Ljava/security/cert/CertStore;
           17   20     8     cse  Ljava/security/cert/CertStoreException;
      Exception table:
        from    to  target  type
           9    15      16  Class java.security.cert.CertStoreException
    Signature: (Lsun/security/x509/AuthorityInfoAccessExtension;Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;)Z
    MethodParameters:
        Name  Flags
      aiaExt  
      certs   

  void verifyCert(java.security.cert.X509Certificate, sun.security.provider.certpath.State, java.util.List<java.security.cert.X509Certificate>);
    descriptor: (Ljava/security/cert/X509Certificate;Lsun/security/provider/certpath/State;Ljava/util/List;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=10, args_size=4
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // sun.security.provider.certpath.State currentState
        start local 3 // java.util.List certPathList
         0: .line 664
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 6
         1: .line 665
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "ForwardBuilder.verifyCert(SN: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 666
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSerialNumber:()Ljava/math/BigInteger;
            invokestatic sun.security.util.Debug.toHexString:(Ljava/math/BigInteger;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         3: .line 667
            ldc "\n  Issuer: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 668
            ldc "\n  Subject: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            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;
         5: .line 665
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         6: .line 671
      StackMap locals:
      StackMap stack:
            aload 2 /* currentState */
            checkcast sun.security.provider.certpath.ForwardState
            astore 4 /* currState */
        start local 4 // sun.security.provider.certpath.ForwardState currState
         7: .line 674
            aload 4 /* currState */
            getfield sun.security.provider.certpath.ForwardState.untrustedChecker:Lsun/security/provider/certpath/UntrustedChecker;
            aload 1 /* cert */
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            invokevirtual sun.security.provider.certpath.UntrustedChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
         8: .line 683
            aload 3 /* certPathList */
            ifnull 26
         9: .line 684
            iconst_0
            istore 5 /* policyMappingFound */
        start local 5 // boolean policyMappingFound
        10: .line 685
            aload 3 /* certPathList */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 25
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate sun.security.provider.certpath.State java.util.List sun.security.provider.certpath.ForwardState int top java.util.Iterator
      StackMap stack:
        11: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 6 /* cpListCert */
        start local 6 // java.security.cert.X509Certificate cpListCert
        12: .line 686
            aload 6 /* cpListCert */
            invokestatic sun.security.x509.X509CertImpl.toImpl:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            astore 8 /* cpListCertImpl */
        start local 8 // sun.security.x509.X509CertImpl cpListCertImpl
        13: .line 688
            aload 8 /* cpListCertImpl */
            invokevirtual sun.security.x509.X509CertImpl.getPolicyMappingsExtension:()Lsun/security/x509/PolicyMappingsExtension;
        14: .line 687
            astore 9 /* policyMappingsExt */
        start local 9 // sun.security.x509.PolicyMappingsExtension policyMappingsExt
        15: .line 689
            aload 9 /* policyMappingsExt */
            ifnull 17
        16: .line 690
            iconst_1
            istore 5 /* policyMappingFound */
        17: .line 692
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate sun.security.provider.certpath.State java.util.List sun.security.provider.certpath.ForwardState int java.security.cert.X509Certificate java.util.Iterator sun.security.x509.X509CertImpl sun.security.x509.PolicyMappingsExtension
      StackMap stack:
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 19
        18: .line 693
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "policyMappingFound = "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 5 /* policyMappingFound */
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        19: .line 695
      StackMap locals:
      StackMap stack:
            aload 1 /* cert */
            aload 6 /* cpListCert */
            invokevirtual java.security.cert.X509Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 25
        20: .line 696
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isPolicyMappingInhibited:()Z
            ifne 22
        21: .line 697
            iload 5 /* policyMappingFound */
            ifne 25
        22: .line 698
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 24
        23: .line 699
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "loop detected!!"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        24: .line 701
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertPathValidatorException
            dup
            ldc "loop detected"
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;)V
            athrow
        end local 9 // sun.security.x509.PolicyMappingsExtension policyMappingsExt
        end local 8 // sun.security.x509.X509CertImpl cpListCertImpl
        end local 6 // java.security.cert.X509Certificate cpListCert
        25: .line 685
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate sun.security.provider.certpath.State java.util.List sun.security.provider.certpath.ForwardState int top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        end local 5 // boolean policyMappingFound
        26: .line 708
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate sun.security.provider.certpath.State java.util.List sun.security.provider.certpath.ForwardState
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustedCerts:Ljava/util/Set;
            aload 1 /* cert */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            istore 5 /* isTrustedCert */
        start local 5 // boolean isTrustedCert
        27: .line 711
            iload 5 /* isTrustedCert */
            ifne 70
        28: .line 717
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getCriticalExtensionOIDs:()Ljava/util/Set;
            astore 6 /* unresCritExts */
        start local 6 // java.util.Set unresCritExts
        29: .line 718
            aload 6 /* unresCritExts */
            ifnonnull 31
        30: .line 719
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 6 /* unresCritExts */
        31: .line 721
      StackMap locals: int java.util.Set
      StackMap stack:
            aload 4 /* currState */
            getfield sun.security.provider.certpath.ForwardState.forwardCheckers:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
            astore 8
            goto 34
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate sun.security.provider.certpath.State java.util.List sun.security.provider.certpath.ForwardState int java.util.Set top java.util.Iterator
      StackMap stack:
        32: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 7 /* checker */
        start local 7 // java.security.cert.PKIXCertPathChecker checker
        33: .line 722
            aload 7 /* checker */
            aload 1 /* cert */
            aload 6 /* unresCritExts */
            invokevirtual java.security.cert.PKIXCertPathChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
        end local 7 // java.security.cert.PKIXCertPathChecker checker
        34: .line 721
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 32
        35: .line 731
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getCertPathCheckers:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 41
      StackMap locals:
      StackMap stack:
        36: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 7 /* checker */
        start local 7 // java.security.cert.PKIXCertPathChecker checker
        37: .line 732
            aload 7 /* checker */
            invokevirtual java.security.cert.PKIXCertPathChecker.isForwardCheckingSupported:()Z
            ifne 41
        38: .line 733
            aload 7 /* checker */
            invokevirtual java.security.cert.PKIXCertPathChecker.getSupportedExtensions:()Ljava/util/Set;
            astore 9 /* supportedExts */
        start local 9 // java.util.Set supportedExts
        39: .line 734
            aload 9 /* supportedExts */
            ifnull 41
        40: .line 735
            aload 6 /* unresCritExts */
            aload 9 /* supportedExts */
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
        end local 9 // java.util.Set supportedExts
        end local 7 // java.security.cert.PKIXCertPathChecker checker
        41: .line 731
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 36
        42: .line 744
            aload 6 /* unresCritExts */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 70
        43: .line 745
            aload 6 /* unresCritExts */
        44: .line 746
            getstatic sun.security.x509.PKIXExtensions.BasicConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        45: .line 745
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        46: .line 747
            aload 6 /* unresCritExts */
        47: .line 748
            getstatic sun.security.x509.PKIXExtensions.NameConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        48: .line 747
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        49: .line 749
            aload 6 /* unresCritExts */
        50: .line 750
            getstatic sun.security.x509.PKIXExtensions.CertificatePolicies_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        51: .line 749
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        52: .line 751
            aload 6 /* unresCritExts */
        53: .line 752
            getstatic sun.security.x509.PKIXExtensions.PolicyMappings_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        54: .line 751
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        55: .line 753
            aload 6 /* unresCritExts */
        56: .line 754
            getstatic sun.security.x509.PKIXExtensions.PolicyConstraints_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        57: .line 753
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        58: .line 755
            aload 6 /* unresCritExts */
        59: .line 756
            getstatic sun.security.x509.PKIXExtensions.InhibitAnyPolicy_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        60: .line 755
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        61: .line 757
            aload 6 /* unresCritExts */
        62: .line 758
            getstatic sun.security.x509.PKIXExtensions.SubjectAlternativeName_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        63: .line 757
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        64: .line 759
            aload 6 /* unresCritExts */
            getstatic sun.security.x509.PKIXExtensions.KeyUsage_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        65: .line 760
            aload 6 /* unresCritExts */
        66: .line 761
            getstatic sun.security.x509.PKIXExtensions.ExtendedKeyUsage_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        67: .line 760
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
        68: .line 763
            aload 6 /* unresCritExts */
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 70
        69: .line 764
            new java.security.cert.CertificateException
            dup
            ldc "Unrecognized critical extension(s)"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 6 // java.util.Set unresCritExts
        70: .line 773
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate sun.security.provider.certpath.State java.util.List sun.security.provider.certpath.ForwardState int
      StackMap stack:
            aload 4 /* currState */
            invokevirtual sun.security.provider.certpath.ForwardState.isInitial:()Z
            ifeq 72
        71: .line 774
            return
        72: .line 778
      StackMap locals:
      StackMap stack:
            iload 5 /* isTrustedCert */
            ifne 76
        73: .line 780
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getBasicConstraints:()I
            iconst_m1
            if_icmpne 75
        74: .line 781
            new java.security.cert.CertificateException
            dup
            ldc "cert is NOT a CA cert"
            invokespecial java.security.cert.CertificateException.<init>:(Ljava/lang/String;)V
            athrow
        75: .line 787
      StackMap locals:
      StackMap stack:
            aload 1 /* cert */
            invokestatic sun.security.provider.certpath.KeyChecker.verifyCAKeyUsage:(Ljava/security/cert/X509Certificate;)V
        76: .line 800
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isRevocationEnabled:()Z
            ifeq 83
        77: .line 803
            aload 1 /* cert */
            invokestatic sun.security.provider.certpath.CrlRevocationChecker.certCanSignCrl:(Ljava/security/cert/X509Certificate;)Z
            ifeq 83
        78: .line 806
            aload 4 /* currState */
            invokevirtual sun.security.provider.certpath.ForwardState.keyParamsNeeded:()Z
            ifne 83
        79: .line 810
            aload 4 /* currState */
            getfield sun.security.provider.certpath.ForwardState.crlChecker:Lsun/security/provider/certpath/CrlRevocationChecker;
            aload 4 /* currState */
            getfield sun.security.provider.certpath.ForwardState.cert:Lsun/security/x509/X509CertImpl;
        80: .line 811
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
        81: .line 812
            iconst_1
        82: .line 810
            invokevirtual sun.security.provider.certpath.CrlRevocationChecker.check:(Ljava/security/cert/X509Certificate;Ljava/security/PublicKey;Z)Z
            pop
        83: .line 820
      StackMap locals:
      StackMap stack:
            aload 4 /* currState */
            invokevirtual sun.security.provider.certpath.ForwardState.keyParamsNeeded:()Z
            ifne 87
        84: .line 821
            aload 4 /* currState */
            getfield sun.security.provider.certpath.ForwardState.cert:Lsun/security/x509/X509CertImpl;
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
        85: .line 822
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getSigProvider:()Ljava/lang/String;
        86: .line 821
            invokevirtual sun.security.x509.X509CertImpl.verify:(Ljava/security/PublicKey;Ljava/lang/String;)V
        87: .line 824
      StackMap locals:
      StackMap stack:
            return
        end local 5 // boolean isTrustedCert
        end local 4 // sun.security.provider.certpath.ForwardState currState
        end local 3 // java.util.List certPathList
        end local 2 // sun.security.provider.certpath.State currentState
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   88     0                this  Lsun/security/provider/certpath/ForwardBuilder;
            0   88     1                cert  Ljava/security/cert/X509Certificate;
            0   88     2        currentState  Lsun/security/provider/certpath/State;
            0   88     3        certPathList  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
            7   88     4           currState  Lsun/security/provider/certpath/ForwardState;
           10   26     5  policyMappingFound  Z
           12   25     6          cpListCert  Ljava/security/cert/X509Certificate;
           13   25     8      cpListCertImpl  Lsun/security/x509/X509CertImpl;
           15   25     9   policyMappingsExt  Lsun/security/x509/PolicyMappingsExtension;
           27   88     5       isTrustedCert  Z
           29   70     6       unresCritExts  Ljava/util/Set<Ljava/lang/String;>;
           33   34     7             checker  Ljava/security/cert/PKIXCertPathChecker;
           37   41     7             checker  Ljava/security/cert/PKIXCertPathChecker;
           39   41     9       supportedExts  Ljava/util/Set<Ljava/lang/String;>;
    Exceptions:
      throws java.security.GeneralSecurityException
    Signature: (Ljava/security/cert/X509Certificate;Lsun/security/provider/certpath/State;Ljava/util/List<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      cert          
      currentState  
      certPathList  

  boolean isPathCompleted(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)Z
    flags: (0x0000) 
    Code:
      stack=6, locals=6, args_size=2
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // java.security.cert.X509Certificate cert
         0: .line 839
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.trustAnchors:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 42
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.TrustAnchor
            astore 2 /* anchor */
        start local 2 // java.security.cert.TrustAnchor anchor
         2: .line 840
            aload 2 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            ifnull 6
         3: .line 841
            aload 1 /* cert */
            aload 2 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 42
         4: .line 842
            aload 0 /* this */
            aload 2 /* anchor */
            putfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
         5: .line 843
            iconst_1
            ireturn
         6: .line 848
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate java.security.cert.TrustAnchor java.util.Iterator
      StackMap stack:
            aload 2 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCA:()Ljavax/security/auth/x500/X500Principal;
            astore 4 /* principal */
        start local 4 // javax.security.auth.x500.X500Principal principal
         7: .line 849
            aload 2 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
            astore 5 /* publicKey */
        start local 5 // java.security.PublicKey publicKey
         8: .line 851
            aload 4 /* principal */
            ifnull 13
            aload 5 /* publicKey */
            ifnull 13
         9: .line 852
            aload 4 /* principal */
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifeq 13
        10: .line 853
            aload 5 /* publicKey */
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 13
        11: .line 855
            aload 0 /* this */
            aload 2 /* anchor */
            putfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        12: .line 856
            iconst_1
            ireturn
        13: .line 862
      StackMap locals: javax.security.auth.x500.X500Principal java.security.PublicKey
      StackMap stack:
            aload 4 /* principal */
            ifnull 42
        14: .line 863
            aload 4 /* principal */
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 16
        15: .line 864
            goto 42
        end local 5 // java.security.PublicKey publicKey
        end local 4 // javax.security.auth.x500.X500Principal principal
        16: .line 869
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.isRevocationEnabled:()Z
            ifeq 27
        17: .line 871
            new sun.security.provider.certpath.CrlRevocationChecker
            dup
        18: .line 872
            aload 2 /* anchor */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            aconst_null
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.onlyEECert:Z
        19: .line 871
            invokespecial sun.security.provider.certpath.CrlRevocationChecker.<init>:(Ljava/security/cert/TrustAnchor;Ljava/security/cert/PKIXParameters;Ljava/util/Collection;Z)V
            astore 4 /* crlChecker */
        start local 4 // sun.security.provider.certpath.CrlRevocationChecker crlChecker
        20: .line 873
            aload 4 /* crlChecker */
            aload 1 /* cert */
            aload 2 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
            iconst_1
            invokevirtual sun.security.provider.certpath.CrlRevocationChecker.check:(Ljava/security/cert/X509Certificate;Ljava/security/PublicKey;Z)Z
            pop
        end local 4 // sun.security.provider.certpath.CrlRevocationChecker crlChecker
        21: .line 874
            goto 27
      StackMap locals:
      StackMap stack: java.security.cert.CertPathValidatorException
        22: astore 4 /* cpve */
        start local 4 // java.security.cert.CertPathValidatorException cpve
        23: .line 875
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 42
        24: .line 876
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.isPathCompleted() cpve"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        25: .line 877
            aload 4 /* cpve */
            invokevirtual java.security.cert.CertPathValidatorException.printStackTrace:()V
        26: .line 879
            goto 42
        end local 4 // java.security.cert.CertPathValidatorException cpve
        27: .line 891
      StackMap locals:
      StackMap stack:
            aload 1 /* cert */
            aload 2 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
        28: .line 892
            aload 0 /* this */
            getfield sun.security.provider.certpath.ForwardBuilder.buildParams:Ljava/security/cert/PKIXBuilderParameters;
            invokevirtual java.security.cert.PKIXBuilderParameters.getSigProvider:()Ljava/lang/String;
        29: .line 891
            invokevirtual java.security.cert.X509Certificate.verify:(Ljava/security/PublicKey;Ljava/lang/String;)V
        30: .line 893
            goto 40
      StackMap locals:
      StackMap stack: java.security.InvalidKeyException
        31: pop
        32: .line 894
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 42
        33: .line 895
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.isPathCompleted() invalid DSA key found"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        34: .line 898
            goto 42
        35: .line 899
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 4 /* e */
        start local 4 // java.lang.Exception e
        36: .line 900
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ifnull 42
        37: .line 901
            getstatic sun.security.provider.certpath.ForwardBuilder.debug:Lsun/security/util/Debug;
            ldc "ForwardBuilder.isPathCompleted() unexpected exception"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        38: .line 903
            aload 4 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        39: .line 905
            goto 42
        end local 4 // java.lang.Exception e
        40: .line 908
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* anchor */
            putfield sun.security.provider.certpath.ForwardBuilder.trustAnchor:Ljava/security/cert/TrustAnchor;
        41: .line 909
            iconst_1
            ireturn
        end local 2 // java.security.cert.TrustAnchor anchor
        42: .line 839
      StackMap locals: sun.security.provider.certpath.ForwardBuilder java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
        43: .line 912
            iconst_0
            ireturn
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   44     0        this  Lsun/security/provider/certpath/ForwardBuilder;
            0   44     1        cert  Ljava/security/cert/X509Certificate;
            2   42     2      anchor  Ljava/security/cert/TrustAnchor;
            7   16     4   principal  Ljavax/security/auth/x500/X500Principal;
            8   16     5   publicKey  Ljava/security/PublicKey;
           20   21     4  crlChecker  Lsun/security/provider/certpath/CrlRevocationChecker;
           23   27     4        cpve  Ljava/security/cert/CertPathValidatorException;
           36   40     4           e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          17    21      22  Class java.security.cert.CertPathValidatorException
          27    30      31  Class java.security.InvalidKeyException
          27    30      35  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      cert  

  void addCertToPath(java.security.cert.X509Certificate, java.util.LinkedList<java.security.cert.X509Certificate>);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/util/LinkedList;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.util.LinkedList certPathList
         0: .line 922
            aload 2 /* certPathList */
            aload 1 /* cert */
            invokevirtual java.util.LinkedList.addFirst:(Ljava/lang/Object;)V
         1: .line 923
            return
        end local 2 // java.util.LinkedList certPathList
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    2     0          this  Lsun/security/provider/certpath/ForwardBuilder;
            0    2     1          cert  Ljava/security/cert/X509Certificate;
            0    2     2  certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
    Signature: (Ljava/security/cert/X509Certificate;Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      cert          
      certPathList  

  void removeFinalCertFromPath(java.util.LinkedList<java.security.cert.X509Certificate>);
    descriptor: (Ljava/util/LinkedList;)V
    flags: (0x0000) 
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.provider.certpath.ForwardBuilder this
        start local 1 // java.util.LinkedList certPathList
         0: .line 930
            aload 1 /* certPathList */
            invokevirtual java.util.LinkedList.removeFirst:()Ljava/lang/Object;
            pop
         1: .line 931
            return
        end local 1 // java.util.LinkedList certPathList
        end local 0 // sun.security.provider.certpath.ForwardBuilder this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    2     0          this  Lsun/security/provider/certpath/ForwardBuilder;
            0    2     1  certPathList  Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;
    Signature: (Ljava/util/LinkedList<Ljava/security/cert/X509Certificate;>;)V
    MethodParameters:
              Name  Flags
      certPathList  
}
SourceFile: "ForwardBuilder.java"
NestMembers:
  sun.security.provider.certpath.ForwardBuilder$PKIXCertComparator
InnerClasses:
  PKIXCertComparator = sun.security.provider.certpath.ForwardBuilder$PKIXCertComparator of sun.security.provider.certpath.ForwardBuilder