class sun.security.provider.certpath.ReverseState implements sun.security.provider.certpath.State
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.provider.certpath.ReverseState
  super_class: java.lang.Object
{
  private static final sun.security.util.Debug debug;
    descriptor: Lsun/security/util/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  javax.security.auth.x500.X500Principal subjectDN;
    descriptor: Ljavax/security/auth/x500/X500Principal;
    flags: (0x0000) 

  java.security.PublicKey pubKey;
    descriptor: Ljava/security/PublicKey;
    flags: (0x0000) 

  sun.security.x509.SubjectKeyIdentifierExtension subjKeyId;
    descriptor: Lsun/security/x509/SubjectKeyIdentifierExtension;
    flags: (0x0000) 

  sun.security.x509.NameConstraintsExtension nc;
    descriptor: Lsun/security/x509/NameConstraintsExtension;
    flags: (0x0000) 

  int explicitPolicy;
    descriptor: I
    flags: (0x0000) 

  int policyMapping;
    descriptor: I
    flags: (0x0000) 

  int inhibitAnyPolicy;
    descriptor: I
    flags: (0x0000) 

  int certIndex;
    descriptor: I
    flags: (0x0000) 

  sun.security.provider.certpath.PolicyNodeImpl rootNode;
    descriptor: Lsun/security/provider/certpath/PolicyNodeImpl;
    flags: (0x0000) 

  int remainingCACerts;
    descriptor: I
    flags: (0x0000) 

  java.util.ArrayList<java.security.cert.PKIXCertPathChecker> userCheckers;
    descriptor: Ljava/util/ArrayList;
    flags: (0x0000) 
    Signature: Ljava/util/ArrayList<Ljava/security/cert/PKIXCertPathChecker;>;

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

  public sun.security.provider.certpath.CrlRevocationChecker crlChecker;
    descriptor: Lsun/security/provider/certpath/CrlRevocationChecker;
    flags: (0x0001) ACC_PUBLIC

  sun.security.provider.certpath.UntrustedChecker untrustedChecker;
    descriptor: Lsun/security/provider/certpath/UntrustedChecker;
    flags: (0x0000) 

  sun.security.provider.certpath.AlgorithmChecker algorithmChecker;
    descriptor: Lsun/security/provider/certpath/AlgorithmChecker;
    flags: (0x0000) 

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

  public boolean crlSign;
    descriptor: Z
    flags: (0x0001) ACC_PUBLIC

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

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.ReverseState this
         0: .line 57
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 94
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ReverseState.init:Z
         2: .line 111
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ReverseState.crlSign:Z
         3: .line 57
            return
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/provider/certpath/ReverseState;

  public boolean isInitial();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.ReverseState this
         0: .line 120
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.init:Z
            ireturn
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/ReverseState;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // sun.security.provider.certpath.ReverseState this
         0: .line 127
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuffer sb
         1: .line 129
            aload 1 /* sb */
            ldc "State ["
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         2: .line 130
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  subjectDN of last cert: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.subjectDN:Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         3: .line 131
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  subjectKeyIdentifier: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.subjKeyId:Lsun/security/x509/SubjectKeyIdentifierExtension;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         4: .line 132
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  nameConstraints: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         5: .line 133
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  certIndex: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.certIndex:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         6: .line 134
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  explicitPolicy: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.explicitPolicy:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         7: .line 135
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  policyMapping:  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.policyMapping:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         8: .line 136
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  inhibitAnyPolicy:  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.inhibitAnyPolicy:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         9: .line 137
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  rootNode: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.rootNode:Lsun/security/provider/certpath/PolicyNodeImpl;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        10: .line 138
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  remainingCACerts: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.remainingCACerts:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        11: .line 139
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  crlSign: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.crlSign:Z
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        12: .line 140
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc "\n  init: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.init:Z
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        13: .line 141
            aload 1 /* sb */
            ldc "\n]\n"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        14: .line 142
            goto 19
      StackMap locals: sun.security.provider.certpath.ReverseState java.lang.StringBuffer
      StackMap stack: java.lang.Exception
        15: astore 2 /* e */
        start local 2 // java.lang.Exception e
        16: .line 143
            getstatic sun.security.provider.certpath.ReverseState.debug:Lsun/security/util/Debug;
            ifnull 19
        17: .line 144
            getstatic sun.security.provider.certpath.ReverseState.debug:Lsun/security/util/Debug;
            ldc "ReverseState.toString() unexpected exception"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        18: .line 145
            aload 2 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        end local 2 // java.lang.Exception e
        19: .line 148
      StackMap locals:
      StackMap stack:
            aload 1 /* sb */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuffer sb
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   20     0  this  Lsun/security/provider/certpath/ReverseState;
            1   20     1    sb  Ljava/lang/StringBuffer;
           16   19     2     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    14      15  Class java.lang.Exception

  public void initState(int, boolean, boolean, boolean, java.util.List<java.security.cert.PKIXCertPathChecker>);
    descriptor: (IZZZLjava/util/List;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=9, args_size=6
        start local 0 // sun.security.provider.certpath.ReverseState this
        start local 1 // int maxPathLen
        start local 2 // boolean explicitPolicyRequired
        start local 3 // boolean policyMappingInhibited
        start local 4 // boolean anyPolicyInhibited
        start local 5 // java.util.List certPathCheckers
         0: .line 171
            aload 0 /* this */
            iload 1 /* maxPathLen */
            iconst_m1
            if_icmpne 1
            ldc 2147483647
            goto 2
      StackMap locals:
      StackMap stack: sun.security.provider.certpath.ReverseState
         1: iload 1 /* maxPathLen */
      StackMap locals: sun.security.provider.certpath.ReverseState int int int int java.util.List
      StackMap stack: sun.security.provider.certpath.ReverseState int
         2: putfield sun.security.provider.certpath.ReverseState.remainingCACerts:I
         3: .line 174
            iload 2 /* explicitPolicyRequired */
            ifeq 6
         4: .line 175
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ReverseState.explicitPolicy:I
         5: .line 176
            goto 10
         6: .line 180
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* maxPathLen */
            iconst_m1
            if_icmpne 8
         7: .line 181
            iload 1 /* maxPathLen */
            goto 9
         8: .line 182
      StackMap locals:
      StackMap stack: sun.security.provider.certpath.ReverseState
            iload 1 /* maxPathLen */
            iconst_2
            iadd
         9: .line 180
      StackMap locals: sun.security.provider.certpath.ReverseState int int int int java.util.List
      StackMap stack: sun.security.provider.certpath.ReverseState int
            putfield sun.security.provider.certpath.ReverseState.explicitPolicy:I
        10: .line 186
      StackMap locals:
      StackMap stack:
            iload 3 /* policyMappingInhibited */
            ifeq 13
        11: .line 187
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ReverseState.policyMapping:I
        12: .line 188
            goto 17
        13: .line 189
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* maxPathLen */
            iconst_m1
            if_icmpne 15
        14: .line 190
            iload 1 /* maxPathLen */
            goto 16
        15: .line 191
      StackMap locals:
      StackMap stack: sun.security.provider.certpath.ReverseState
            iload 1 /* maxPathLen */
            iconst_2
            iadd
        16: .line 189
      StackMap locals: sun.security.provider.certpath.ReverseState int int int int java.util.List
      StackMap stack: sun.security.provider.certpath.ReverseState int
            putfield sun.security.provider.certpath.ReverseState.policyMapping:I
        17: .line 195
      StackMap locals:
      StackMap stack:
            iload 4 /* anyPolicyInhibited */
            ifeq 20
        18: .line 196
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ReverseState.inhibitAnyPolicy:I
        19: .line 197
            goto 24
        20: .line 198
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* maxPathLen */
            iconst_m1
            if_icmpne 22
        21: .line 199
            iload 1 /* maxPathLen */
            goto 23
        22: .line 200
      StackMap locals:
      StackMap stack: sun.security.provider.certpath.ReverseState
            iload 1 /* maxPathLen */
            iconst_2
            iadd
        23: .line 198
      StackMap locals: sun.security.provider.certpath.ReverseState int int int int java.util.List
      StackMap stack: sun.security.provider.certpath.ReverseState int
            putfield sun.security.provider.certpath.ReverseState.inhibitAnyPolicy:I
        24: .line 204
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ReverseState.certIndex:I
        25: .line 207
            new java.util.HashSet
            dup
            iconst_1
            invokespecial java.util.HashSet.<init>:(I)V
            astore 6 /* initExpPolSet */
        start local 6 // java.util.Set initExpPolSet
        26: .line 208
            aload 6 /* initExpPolSet */
            ldc "2.5.29.32.0"
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        27: .line 210
            aload 0 /* this */
            new sun.security.provider.certpath.PolicyNodeImpl
            dup
        28: .line 211
            aconst_null
            ldc "2.5.29.32.0"
            aconst_null
            iconst_0
            aload 6 /* initExpPolSet */
            iconst_0
            invokespecial sun.security.provider.certpath.PolicyNodeImpl.<init>:(Lsun/security/provider/certpath/PolicyNodeImpl;Ljava/lang/String;Ljava/util/Set;ZLjava/util/Set;Z)V
        29: .line 210
            putfield sun.security.provider.certpath.ReverseState.rootNode:Lsun/security/provider/certpath/PolicyNodeImpl;
        30: .line 216
            aload 5 /* certPathCheckers */
            ifnull 37
        31: .line 218
            aload 0 /* this */
            new java.util.ArrayList
            dup
            aload 5 /* certPathCheckers */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            putfield sun.security.provider.certpath.ReverseState.userCheckers:Ljava/util/ArrayList;
        32: .line 220
            aload 5 /* certPathCheckers */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 35
      StackMap locals: sun.security.provider.certpath.ReverseState int int int int java.util.List java.util.Set top java.util.Iterator
      StackMap stack:
        33: 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
        34: .line 221
            aload 7 /* checker */
            iconst_0
            invokevirtual java.security.cert.PKIXCertPathChecker.init:(Z)V
        end local 7 // java.security.cert.PKIXCertPathChecker checker
        35: .line 220
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 33
        36: .line 223
            goto 38
        37: .line 224
      StackMap locals: sun.security.provider.certpath.ReverseState int int int int java.util.List java.util.Set
      StackMap stack:
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield sun.security.provider.certpath.ReverseState.userCheckers:Ljava/util/ArrayList;
        38: .line 228
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ReverseState.crlSign:Z
        39: .line 230
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ReverseState.init:Z
        40: .line 231
            return
        end local 6 // java.util.Set initExpPolSet
        end local 5 // java.util.List certPathCheckers
        end local 4 // boolean anyPolicyInhibited
        end local 3 // boolean policyMappingInhibited
        end local 2 // boolean explicitPolicyRequired
        end local 1 // int maxPathLen
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0   41     0                    this  Lsun/security/provider/certpath/ReverseState;
            0   41     1              maxPathLen  I
            0   41     2  explicitPolicyRequired  Z
            0   41     3  policyMappingInhibited  Z
            0   41     4      anyPolicyInhibited  Z
            0   41     5        certPathCheckers  Ljava/util/List<Ljava/security/cert/PKIXCertPathChecker;>;
           26   41     6           initExpPolSet  Ljava/util/Set<Ljava/lang/String;>;
           34   35     7                 checker  Ljava/security/cert/PKIXCertPathChecker;
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    Signature: (IZZZLjava/util/List<Ljava/security/cert/PKIXCertPathChecker;>;)V
    MethodParameters:
                        Name  Flags
      maxPathLen              
      explicitPolicyRequired  
      policyMappingInhibited  
      anyPolicyInhibited      
      certPathCheckers        

  public void updateState(java.security.cert.TrustAnchor);
    descriptor: (Ljava/security/cert/TrustAnchor;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // sun.security.provider.certpath.ReverseState this
        start local 1 // java.security.cert.TrustAnchor anchor
         0: .line 241
            aload 0 /* this */
            aload 1 /* anchor */
            putfield sun.security.provider.certpath.ReverseState.trustAnchor:Ljava/security/cert/TrustAnchor;
         1: .line 242
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            astore 2 /* trustedCert */
        start local 2 // java.security.cert.X509Certificate trustedCert
         2: .line 243
            aload 2 /* trustedCert */
            ifnull 5
         3: .line 244
            aload 0 /* this */
            aload 2 /* trustedCert */
            invokevirtual sun.security.provider.certpath.ReverseState.updateState:(Ljava/security/cert/X509Certificate;)V
         4: .line 245
            goto 7
         5: .line 246
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCA:()Ljavax/security/auth/x500/X500Principal;
            astore 3 /* caName */
        start local 3 // javax.security.auth.x500.X500Principal caName
         6: .line 247
            aload 0 /* this */
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
            aload 3 /* caName */
            invokevirtual sun.security.provider.certpath.ReverseState.updateState:(Ljava/security/PublicKey;Ljavax/security/auth/x500/X500Principal;)V
        end local 3 // javax.security.auth.x500.X500Principal caName
         7: .line 252
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.userCheckers:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
            astore 4
            goto 11
      StackMap locals: sun.security.provider.certpath.ReverseState java.security.cert.TrustAnchor java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
         8: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 3 /* checker */
        start local 3 // java.security.cert.PKIXCertPathChecker checker
         9: .line 253
            aload 3 /* checker */
            instanceof sun.security.provider.certpath.AlgorithmChecker
            ifeq 11
        10: .line 254
            aload 3 /* checker */
            checkcast sun.security.provider.certpath.AlgorithmChecker
            aload 1 /* anchor */
            invokevirtual sun.security.provider.certpath.AlgorithmChecker.trySetTrustAnchor:(Ljava/security/cert/TrustAnchor;)V
        end local 3 // java.security.cert.PKIXCertPathChecker checker
        11: .line 252
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        12: .line 258
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ReverseState.init:Z
        13: .line 259
            return
        end local 2 // java.security.cert.X509Certificate trustedCert
        end local 1 // java.security.cert.TrustAnchor anchor
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   14     0         this  Lsun/security/provider/certpath/ReverseState;
            0   14     1       anchor  Ljava/security/cert/TrustAnchor;
            2   14     2  trustedCert  Ljava/security/cert/X509Certificate;
            6    7     3       caName  Ljavax/security/auth/x500/X500Principal;
            9   11     3      checker  Ljava/security/cert/PKIXCertPathChecker;
    Exceptions:
      throws java.security.cert.CertificateException, java.io.IOException, java.security.cert.CertPathValidatorException
    MethodParameters:
        Name  Flags
      anchor  

  private void updateState(java.security.PublicKey, javax.security.auth.x500.X500Principal);
    descriptor: (Ljava/security/PublicKey;Ljavax/security/auth/x500/X500Principal;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.provider.certpath.ReverseState this
        start local 1 // java.security.PublicKey pubKey
        start local 2 // javax.security.auth.x500.X500Principal subjectDN
         0: .line 271
            aload 0 /* this */
            aload 2 /* subjectDN */
            putfield sun.security.provider.certpath.ReverseState.subjectDN:Ljavax/security/auth/x500/X500Principal;
         1: .line 274
            aload 0 /* this */
            aload 1 /* pubKey */
            putfield sun.security.provider.certpath.ReverseState.pubKey:Ljava/security/PublicKey;
         2: .line 275
            return
        end local 2 // javax.security.auth.x500.X500Principal subjectDN
        end local 1 // java.security.PublicKey pubKey
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lsun/security/provider/certpath/ReverseState;
            0    3     1     pubKey  Ljava/security/PublicKey;
            0    3     2  subjectDN  Ljavax/security/auth/x500/X500Principal;
    MethodParameters:
           Name  Flags
      pubKey     
      subjectDN  

  public void updateState(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // sun.security.provider.certpath.ReverseState this
        start local 1 // java.security.cert.X509Certificate cert
         0: .line 285
            aload 1 /* cert */
            ifnonnull 2
         1: .line 286
            return
         2: .line 290
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.ReverseState.subjectDN:Ljavax/security/auth/x500/X500Principal;
         3: .line 293
            aload 1 /* cert */
            invokestatic sun.security.x509.X509CertImpl.toImpl:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            astore 2 /* icert */
        start local 2 // sun.security.x509.X509CertImpl icert
         4: .line 294
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 3 /* newKey */
        start local 3 // java.security.PublicKey newKey
         5: .line 295
            aload 3 /* newKey */
            instanceof java.security.interfaces.DSAPublicKey
            ifeq 8
         6: .line 296
            aload 3 /* newKey */
            checkcast java.security.interfaces.DSAPublicKey
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            ifnonnull 8
         7: .line 297
            aload 3 /* newKey */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.pubKey:Ljava/security/PublicKey;
            invokestatic sun.security.provider.certpath.BasicChecker.makeInheritedParamsKey:(Ljava/security/PublicKey;Ljava/security/PublicKey;)Ljava/security/PublicKey;
            astore 3 /* newKey */
         8: .line 301
      StackMap locals: sun.security.x509.X509CertImpl java.security.PublicKey
      StackMap stack:
            aload 0 /* this */
            aload 3 /* newKey */
            putfield sun.security.provider.certpath.ReverseState.pubKey:Ljava/security/PublicKey;
         9: .line 307
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.init:Z
            ifeq 12
        10: .line 308
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ReverseState.init:Z
        11: .line 309
            return
        12: .line 313
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* icert */
            invokevirtual sun.security.x509.X509CertImpl.getSubjectKeyIdentifierExtension:()Lsun/security/x509/SubjectKeyIdentifierExtension;
            putfield sun.security.provider.certpath.ReverseState.subjKeyId:Lsun/security/x509/SubjectKeyIdentifierExtension;
        13: .line 316
            aload 0 /* this */
            aload 1 /* cert */
            invokestatic sun.security.provider.certpath.CrlRevocationChecker.certCanSignCrl:(Ljava/security/cert/X509Certificate;)Z
            putfield sun.security.provider.certpath.ReverseState.crlSign:Z
        14: .line 319
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
            ifnull 17
        15: .line 320
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
            aload 2 /* icert */
            invokevirtual sun.security.x509.X509CertImpl.getNameConstraintsExtension:()Lsun/security/x509/NameConstraintsExtension;
            invokevirtual sun.security.x509.NameConstraintsExtension.merge:(Lsun/security/x509/NameConstraintsExtension;)V
        16: .line 321
            goto 20
        17: .line 322
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* icert */
            invokevirtual sun.security.x509.X509CertImpl.getNameConstraintsExtension:()Lsun/security/x509/NameConstraintsExtension;
            putfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
        18: .line 323
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
            ifnull 20
        19: .line 327
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
            invokevirtual sun.security.x509.NameConstraintsExtension.clone:()Ljava/lang/Object;
            checkcast sun.security.x509.NameConstraintsExtension
            putfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
        20: .line 332
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        21: .line 333
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.explicitPolicy:I
            aload 2 /* icert */
            iconst_0
            invokestatic sun.security.provider.certpath.PolicyChecker.mergeExplicitPolicy:(ILsun/security/x509/X509CertImpl;Z)I
        22: .line 332
            putfield sun.security.provider.certpath.ReverseState.explicitPolicy:I
        23: .line 334
            aload 0 /* this */
        24: .line 335
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.policyMapping:I
            aload 2 /* icert */
            invokestatic sun.security.provider.certpath.PolicyChecker.mergePolicyMapping:(ILsun/security/x509/X509CertImpl;)I
        25: .line 334
            putfield sun.security.provider.certpath.ReverseState.policyMapping:I
        26: .line 336
            aload 0 /* this */
        27: .line 337
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.inhibitAnyPolicy:I
            aload 2 /* icert */
            invokestatic sun.security.provider.certpath.PolicyChecker.mergeInhibitAnyPolicy:(ILsun/security/x509/X509CertImpl;)I
        28: .line 336
            putfield sun.security.provider.certpath.ReverseState.inhibitAnyPolicy:I
        29: .line 338
            aload 0 /* this */
            dup
            getfield sun.security.provider.certpath.ReverseState.certIndex:I
            iconst_1
            iadd
            putfield sun.security.provider.certpath.ReverseState.certIndex:I
        30: .line 343
            aload 0 /* this */
        31: .line 344
            aload 1 /* cert */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.remainingCACerts:I
            invokestatic sun.security.provider.certpath.ConstraintsChecker.mergeBasicConstraints:(Ljava/security/cert/X509Certificate;I)I
        32: .line 343
            putfield sun.security.provider.certpath.ReverseState.remainingCACerts:I
        33: .line 346
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ReverseState.init:Z
        34: .line 347
            return
        end local 3 // java.security.PublicKey newKey
        end local 2 // sun.security.x509.X509CertImpl icert
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   35     0    this  Lsun/security/provider/certpath/ReverseState;
            0   35     1    cert  Ljava/security/cert/X509Certificate;
            4   35     2   icert  Lsun/security/x509/X509CertImpl;
            5   35     3  newKey  Ljava/security/PublicKey;
    Exceptions:
      throws java.security.cert.CertificateException, java.io.IOException, java.security.cert.CertPathValidatorException
    MethodParameters:
      Name  Flags
      cert  

  public boolean keyParamsNeeded();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.ReverseState this
         0: .line 359
            iconst_0
            ireturn
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/ReverseState;

  public java.lang.Object clone();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // sun.security.provider.certpath.ReverseState this
         0: .line 374
            aload 0 /* this */
            invokespecial java.lang.Object.clone:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.ReverseState
            astore 1 /* clonedState */
        start local 1 // sun.security.provider.certpath.ReverseState clonedState
         1: .line 377
            aload 1 /* clonedState */
         2: .line 378
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.userCheckers:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clone:()Ljava/lang/Object;
            checkcast java.util.ArrayList
         3: .line 377
            putfield sun.security.provider.certpath.ReverseState.userCheckers:Ljava/util/ArrayList;
         4: .line 380
            aload 1 /* clonedState */
            getfield sun.security.provider.certpath.ReverseState.userCheckers:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.listIterator:()Ljava/util/ListIterator;
         5: .line 379
            astore 2 /* li */
        start local 2 // java.util.ListIterator li
         6: .line 381
            goto 10
         7: .line 382
      StackMap locals: sun.security.provider.certpath.ReverseState java.util.ListIterator
      StackMap stack:
            aload 2 /* li */
            invokeinterface java.util.ListIterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            astore 3 /* checker */
        start local 3 // java.security.cert.PKIXCertPathChecker checker
         8: .line 383
            aload 3 /* checker */
            instanceof java.lang.Cloneable
            ifeq 10
         9: .line 384
            aload 2 /* li */
            aload 3 /* checker */
            invokevirtual java.security.cert.PKIXCertPathChecker.clone:()Ljava/lang/Object;
            checkcast java.security.cert.PKIXCertPathChecker
            invokeinterface java.util.ListIterator.set:(Ljava/lang/Object;)V
        end local 3 // java.security.cert.PKIXCertPathChecker checker
        10: .line 381
      StackMap locals:
      StackMap stack:
            aload 2 /* li */
            invokeinterface java.util.ListIterator.hasNext:()Z
            ifne 7
        11: .line 389
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
            ifnull 13
        12: .line 390
            aload 1 /* clonedState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
            invokevirtual sun.security.x509.NameConstraintsExtension.clone:()Ljava/lang/Object;
            checkcast sun.security.x509.NameConstraintsExtension
            putfield sun.security.provider.certpath.ReverseState.nc:Lsun/security/x509/NameConstraintsExtension;
        13: .line 394
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.rootNode:Lsun/security/provider/certpath/PolicyNodeImpl;
            ifnull 15
        14: .line 395
            aload 1 /* clonedState */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ReverseState.rootNode:Lsun/security/provider/certpath/PolicyNodeImpl;
            invokevirtual sun.security.provider.certpath.PolicyNodeImpl.copyTree:()Lsun/security/provider/certpath/PolicyNodeImpl;
            putfield sun.security.provider.certpath.ReverseState.rootNode:Lsun/security/provider/certpath/PolicyNodeImpl;
        15: .line 398
      StackMap locals:
      StackMap stack:
            aload 1 /* clonedState */
        16: areturn
        end local 2 // java.util.ListIterator li
        end local 1 // sun.security.provider.certpath.ReverseState clonedState
        17: .line 399
      StackMap locals: sun.security.provider.certpath.ReverseState
      StackMap stack: java.lang.CloneNotSupportedException
            astore 1 /* e */
        start local 1 // java.lang.CloneNotSupportedException e
        18: .line 400
            new java.lang.InternalError
            dup
            aload 1 /* e */
            invokevirtual java.lang.CloneNotSupportedException.toString:()Ljava/lang/String;
            invokespecial java.lang.InternalError.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.CloneNotSupportedException e
        end local 0 // sun.security.provider.certpath.ReverseState this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   19     0         this  Lsun/security/provider/certpath/ReverseState;
            1   17     1  clonedState  Lsun/security/provider/certpath/ReverseState;
            6   17     2           li  Ljava/util/ListIterator<Ljava/security/cert/PKIXCertPathChecker;>;
            8   10     3      checker  Ljava/security/cert/PKIXCertPathChecker;
           18   19     1            e  Ljava/lang/CloneNotSupportedException;
      Exception table:
        from    to  target  type
           0    16      17  Class java.lang.CloneNotSupportedException
}
SourceFile: "ReverseState.java"