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

  private final java.security.PublicKey trustedPubKey;
    descriptor: Ljava/security/PublicKey;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final javax.security.auth.x500.X500Principal caName;
    descriptor: Ljavax/security/auth/x500/X500Principal;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.Date testDate;
    descriptor: Ljava/util/Date;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String sigProvider;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean sigOnly;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private javax.security.auth.x500.X500Principal prevSubject;
    descriptor: Ljavax/security/auth/x500/X500Principal;
    flags: (0x0002) ACC_PRIVATE

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

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

  void <init>(java.security.cert.TrustAnchor, java.util.Date, java.lang.String, boolean);
    descriptor: (Ljava/security/cert/TrustAnchor;Ljava/util/Date;Ljava/lang/String;Z)V
    flags: (0x0000) 
    Code:
      stack=2, locals=5, args_size=5
        start local 0 // sun.security.provider.certpath.BasicChecker this
        start local 1 // java.security.cert.TrustAnchor anchor
        start local 2 // java.util.Date testDate
        start local 3 // java.lang.String sigProvider
        start local 4 // boolean sigOnly
         0: .line 75
            aload 0 /* this */
            invokespecial java.security.cert.PKIXCertPathChecker.<init>:()V
         1: .line 78
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            ifnull 5
         2: .line 79
            aload 0 /* this */
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.BasicChecker.trustedPubKey:Ljava/security/PublicKey;
         3: .line 80
            aload 0 /* this */
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getTrustedCert:()Ljava/security/cert/X509Certificate;
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.BasicChecker.caName:Ljavax/security/auth/x500/X500Principal;
         4: .line 81
            goto 7
         5: .line 82
      StackMap locals: sun.security.provider.certpath.BasicChecker java.security.cert.TrustAnchor java.util.Date java.lang.String int
      StackMap stack:
            aload 0 /* this */
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCAPublicKey:()Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.BasicChecker.trustedPubKey:Ljava/security/PublicKey;
         6: .line 83
            aload 0 /* this */
            aload 1 /* anchor */
            invokevirtual java.security.cert.TrustAnchor.getCA:()Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.BasicChecker.caName:Ljavax/security/auth/x500/X500Principal;
         7: .line 85
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* testDate */
            putfield sun.security.provider.certpath.BasicChecker.testDate:Ljava/util/Date;
         8: .line 86
            aload 0 /* this */
            aload 3 /* sigProvider */
            putfield sun.security.provider.certpath.BasicChecker.sigProvider:Ljava/lang/String;
         9: .line 87
            aload 0 /* this */
            iload 4 /* sigOnly */
            putfield sun.security.provider.certpath.BasicChecker.sigOnly:Z
        10: .line 88
            aload 0 /* this */
            iconst_0
            invokevirtual sun.security.provider.certpath.BasicChecker.init:(Z)V
        11: .line 89
            return
        end local 4 // boolean sigOnly
        end local 3 // java.lang.String sigProvider
        end local 2 // java.util.Date testDate
        end local 1 // java.security.cert.TrustAnchor anchor
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   12     0         this  Lsun/security/provider/certpath/BasicChecker;
            0   12     1       anchor  Ljava/security/cert/TrustAnchor;
            0   12     2     testDate  Ljava/util/Date;
            0   12     3  sigProvider  Ljava/lang/String;
            0   12     4      sigOnly  Z
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    MethodParameters:
             Name  Flags
      anchor       
      testDate     
      sigProvider  
      sigOnly      

  public void init(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.provider.certpath.BasicChecker this
        start local 1 // boolean forward
         0: .line 96
            iload 1 /* forward */
            ifne 4
         1: .line 97
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.trustedPubKey:Ljava/security/PublicKey;
            putfield sun.security.provider.certpath.BasicChecker.prevPubKey:Ljava/security/PublicKey;
         2: .line 98
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.caName:Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.BasicChecker.prevSubject:Ljavax/security/auth/x500/X500Principal;
         3: .line 99
            goto 6
         4: .line 101
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertPathValidatorException
            dup
            ldc "forward checking not supported"
         5: .line 100
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 103
      StackMap locals:
      StackMap stack:
            return
        end local 1 // boolean forward
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lsun/security/provider/certpath/BasicChecker;
            0    7     1  forward  Z
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    MethodParameters:
         Name  Flags
      forward  

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

  public java.util.Set<java.lang.String> getSupportedExtensions();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.BasicChecker this
         0: .line 110
            aconst_null
            areturn
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/BasicChecker;
    Signature: ()Ljava/util/Set<Ljava/lang/String;>;

  public void check(java.security.cert.Certificate, java.util.Collection<java.lang.String>);
    descriptor: (Ljava/security/cert/Certificate;Ljava/util/Collection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // sun.security.provider.certpath.BasicChecker this
        start local 1 // java.security.cert.Certificate cert
        start local 2 // java.util.Collection unresolvedCritExts
         0: .line 127
            aload 1 /* cert */
            checkcast java.security.cert.X509Certificate
            astore 3 /* currCert */
        start local 3 // java.security.cert.X509Certificate currCert
         1: .line 129
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.sigOnly:Z
            ifne 4
         2: .line 130
            aload 0 /* this */
            aload 3 /* currCert */
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.testDate:Ljava/util/Date;
            invokevirtual sun.security.provider.certpath.BasicChecker.verifyTimestamp:(Ljava/security/cert/X509Certificate;Ljava/util/Date;)V
         3: .line 131
            aload 0 /* this */
            aload 3 /* currCert */
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.prevSubject:Ljavax/security/auth/x500/X500Principal;
            invokevirtual sun.security.provider.certpath.BasicChecker.verifyNameChaining:(Ljava/security/cert/X509Certificate;Ljavax/security/auth/x500/X500Principal;)V
         4: .line 133
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 0 /* this */
            aload 3 /* currCert */
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.prevPubKey:Ljava/security/PublicKey;
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.sigProvider:Ljava/lang/String;
            invokevirtual sun.security.provider.certpath.BasicChecker.verifySignature:(Ljava/security/cert/X509Certificate;Ljava/security/PublicKey;Ljava/lang/String;)V
         5: .line 135
            aload 0 /* this */
            aload 3 /* currCert */
            invokevirtual sun.security.provider.certpath.BasicChecker.updateState:(Ljava/security/cert/X509Certificate;)V
         6: .line 136
            return
        end local 3 // java.security.cert.X509Certificate currCert
        end local 2 // java.util.Collection unresolvedCritExts
        end local 1 // java.security.cert.Certificate cert
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    7     0                this  Lsun/security/provider/certpath/BasicChecker;
            0    7     1                cert  Ljava/security/cert/Certificate;
            0    7     2  unresolvedCritExts  Ljava/util/Collection<Ljava/lang/String;>;
            1    7     3            currCert  Ljava/security/cert/X509Certificate;
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    Signature: (Ljava/security/cert/Certificate;Ljava/util/Collection<Ljava/lang/String;>;)V
    MethodParameters:
                    Name  Flags
      cert                
      unresolvedCritExts  

  private void verifySignature(java.security.cert.X509Certificate, java.security.PublicKey, java.lang.String);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/security/PublicKey;Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // sun.security.provider.certpath.BasicChecker this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.security.PublicKey prevPubKey
        start local 3 // java.lang.String sigProvider
         0: .line 149
            ldc "signature"
            astore 4 /* msg */
        start local 4 // java.lang.String msg
         1: .line 150
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 3
         2: .line 151
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "---checking "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* msg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "..."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         3: .line 154
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* cert */
            aload 2 /* prevPubKey */
            aload 3 /* sigProvider */
            invokevirtual java.security.cert.X509Certificate.verify:(Ljava/security/PublicKey;Ljava/lang/String;)V
         4: .line 155
            goto 10
      StackMap locals:
      StackMap stack: java.lang.Exception
         5: astore 5 /* e */
        start local 5 // java.lang.Exception e
         6: .line 156
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 9
         7: .line 157
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            aload 5 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         8: .line 158
            aload 5 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
         9: .line 160
      StackMap locals: java.lang.Exception
      StackMap stack:
            new java.security.cert.CertPathValidatorException
            dup
            new java.lang.StringBuilder
            dup
            aload 4 /* msg */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " check failed"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 5 /* e */
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.lang.Exception e
        10: .line 163
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 12
        11: .line 164
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            aload 4 /* msg */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " verified."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 165
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.lang.String msg
        end local 3 // java.lang.String sigProvider
        end local 2 // java.security.PublicKey prevPubKey
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   13     0         this  Lsun/security/provider/certpath/BasicChecker;
            0   13     1         cert  Ljava/security/cert/X509Certificate;
            0   13     2   prevPubKey  Ljava/security/PublicKey;
            0   13     3  sigProvider  Ljava/lang/String;
            1   13     4          msg  Ljava/lang/String;
            6   10     5            e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           3     4       5  Class java.lang.Exception
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    MethodParameters:
             Name  Flags
      cert         
      prevPubKey   
      sigProvider  

  private void verifyTimestamp(java.security.cert.X509Certificate, java.util.Date);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/util/Date;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // sun.security.provider.certpath.BasicChecker this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.util.Date date
         0: .line 173
            ldc "timestamp"
            astore 3 /* msg */
        start local 3 // java.lang.String msg
         1: .line 174
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 3
         2: .line 175
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "---checking "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* msg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ":"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* date */
            invokevirtual java.util.Date.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "..."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         3: .line 178
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* cert */
            aload 2 /* date */
            invokevirtual java.security.cert.X509Certificate.checkValidity:(Ljava/util/Date;)V
         4: .line 179
            goto 10
      StackMap locals:
      StackMap stack: java.lang.Exception
         5: astore 4 /* e */
        start local 4 // java.lang.Exception e
         6: .line 180
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 9
         7: .line 181
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            aload 4 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         8: .line 182
            aload 4 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
         9: .line 184
      StackMap locals: java.lang.Exception
      StackMap stack:
            new java.security.cert.CertPathValidatorException
            dup
            new java.lang.StringBuilder
            dup
            aload 3 /* msg */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " check failed"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* e */
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Exception e
        10: .line 187
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 12
        11: .line 188
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            aload 3 /* msg */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " verified."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 189
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.String msg
        end local 2 // java.util.Date date
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lsun/security/provider/certpath/BasicChecker;
            0   13     1  cert  Ljava/security/cert/X509Certificate;
            0   13     2  date  Ljava/util/Date;
            1   13     3   msg  Ljava/lang/String;
            6   10     4     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           3     4       5  Class java.lang.Exception
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    MethodParameters:
      Name  Flags
      cert  
      date  

  private void verifyNameChaining(java.security.cert.X509Certificate, javax.security.auth.x500.X500Principal);
    descriptor: (Ljava/security/cert/X509Certificate;Ljavax/security/auth/x500/X500Principal;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // sun.security.provider.certpath.BasicChecker this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // javax.security.auth.x500.X500Principal prevSubject
         0: .line 197
            aload 2 /* prevSubject */
            ifnull 13
         1: .line 199
            ldc "subject/issuer name chaining"
            astore 3 /* msg */
        start local 3 // java.lang.String msg
         2: .line 200
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 4
         3: .line 201
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "---checking "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* msg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "..."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 203
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 4 /* currIssuer */
        start local 4 // javax.security.auth.x500.X500Principal currIssuer
         5: .line 206
            aload 4 /* currIssuer */
            invokestatic sun.security.x509.X500Name.asX500Name:(Ljavax/security/auth/x500/X500Principal;)Lsun/security/x509/X500Name;
            invokevirtual sun.security.x509.X500Name.isEmpty:()Z
            ifeq 9
         6: .line 207
            new java.security.cert.CertPathValidatorException
            dup
            new java.lang.StringBuilder
            dup
            aload 3 /* msg */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " check failed: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         7: .line 208
            ldc "empty/null issuer DN in certificate is invalid"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 207
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 211
      StackMap locals: javax.security.auth.x500.X500Principal
      StackMap stack:
            aload 4 /* currIssuer */
            aload 2 /* prevSubject */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 11
        10: .line 212
            new java.security.cert.CertPathValidatorException
            dup
            new java.lang.StringBuilder
            dup
            aload 3 /* msg */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " check failed"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 215
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 13
        12: .line 216
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            aload 3 /* msg */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " verified."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 4 // javax.security.auth.x500.X500Principal currIssuer
        end local 3 // java.lang.String msg
        13: .line 218
      StackMap locals:
      StackMap stack:
            return
        end local 2 // javax.security.auth.x500.X500Principal prevSubject
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   14     0         this  Lsun/security/provider/certpath/BasicChecker;
            0   14     1         cert  Ljava/security/cert/X509Certificate;
            0   14     2  prevSubject  Ljavax/security/auth/x500/X500Principal;
            2   13     3          msg  Ljava/lang/String;
            5   13     4   currIssuer  Ljavax/security/auth/x500/X500Principal;
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    MethodParameters:
             Name  Flags
      cert         
      prevSubject  

  private void updateState(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // sun.security.provider.certpath.BasicChecker this
        start local 1 // java.security.cert.X509Certificate currCert
         0: .line 226
            aload 1 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 2 /* cKey */
        start local 2 // java.security.PublicKey cKey
         1: .line 227
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 7
         2: .line 228
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "BasicChecker.updateState issuer: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         3: .line 229
            aload 1 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "; subject: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 230
            aload 1 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "; serial#: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         5: .line 231
            aload 1 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getSerialNumber:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         6: .line 228
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         7: .line 233
      StackMap locals: java.security.PublicKey
      StackMap stack:
            aload 2 /* cKey */
            instanceof java.security.interfaces.DSAPublicKey
            ifeq 11
         8: .line 234
            aload 2 /* cKey */
            checkcast java.security.interfaces.DSAPublicKey
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            ifnonnull 11
         9: .line 236
            aload 2 /* cKey */
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.prevPubKey:Ljava/security/PublicKey;
            invokestatic sun.security.provider.certpath.BasicChecker.makeInheritedParamsKey:(Ljava/security/PublicKey;Ljava/security/PublicKey;)Ljava/security/PublicKey;
            astore 2 /* cKey */
        10: .line 237
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ifnull 11
            getstatic sun.security.provider.certpath.BasicChecker.debug:Lsun/security/util/Debug;
            ldc "BasicChecker.updateState Made key with inherited params"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 240
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* cKey */
            putfield sun.security.provider.certpath.BasicChecker.prevPubKey:Ljava/security/PublicKey;
        12: .line 241
            aload 0 /* this */
            aload 1 /* currCert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            putfield sun.security.provider.certpath.BasicChecker.prevSubject:Ljavax/security/auth/x500/X500Principal;
        13: .line 242
            return
        end local 2 // java.security.PublicKey cKey
        end local 1 // java.security.cert.X509Certificate currCert
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   14     0      this  Lsun/security/provider/certpath/BasicChecker;
            0   14     1  currCert  Ljava/security/cert/X509Certificate;
            1   14     2      cKey  Ljava/security/PublicKey;
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    MethodParameters:
          Name  Flags
      currCert  

  static java.security.PublicKey makeInheritedParamsKey(java.security.PublicKey, java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;Ljava/security/PublicKey;)Ljava/security/PublicKey;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=7, args_size=2
        start local 0 // java.security.PublicKey keyValueKey
        start local 1 // java.security.PublicKey keyParamsKey
         0: .line 257
            aload 0 /* keyValueKey */
            instanceof java.security.interfaces.DSAPublicKey
            ifeq 2
         1: .line 258
            aload 1 /* keyParamsKey */
            instanceof java.security.interfaces.DSAPublicKey
            ifne 3
         2: .line 259
      StackMap locals:
      StackMap stack:
            new java.security.cert.CertPathValidatorException
            dup
            ldc "Input key is not appropriate type for inheriting parameters"
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 262
      StackMap locals:
      StackMap stack:
            aload 1 /* keyParamsKey */
            checkcast java.security.interfaces.DSAPublicKey
            invokeinterface java.security.interfaces.DSAPublicKey.getParams:()Ljava/security/interfaces/DSAParams;
            astore 3 /* params */
        start local 3 // java.security.interfaces.DSAParams params
         4: .line 263
            aload 3 /* params */
            ifnonnull 6
         5: .line 264
            new java.security.cert.CertPathValidatorException
            dup
            ldc "Key parameters missing"
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 266
      StackMap locals: java.security.PublicKey java.security.PublicKey top java.security.interfaces.DSAParams
      StackMap stack:
            aload 0 /* keyValueKey */
            checkcast java.security.interfaces.DSAPublicKey
            invokeinterface java.security.interfaces.DSAPublicKey.getY:()Ljava/math/BigInteger;
            astore 4 /* y */
        start local 4 // java.math.BigInteger y
         7: .line 267
            ldc "DSA"
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 5 /* kf */
        start local 5 // java.security.KeyFactory kf
         8: .line 268
            new java.security.spec.DSAPublicKeySpec
            dup
            aload 4 /* y */
         9: .line 269
            aload 3 /* params */
            invokeinterface java.security.interfaces.DSAParams.getP:()Ljava/math/BigInteger;
        10: .line 270
            aload 3 /* params */
            invokeinterface java.security.interfaces.DSAParams.getQ:()Ljava/math/BigInteger;
        11: .line 271
            aload 3 /* params */
            invokeinterface java.security.interfaces.DSAParams.getG:()Ljava/math/BigInteger;
        12: .line 268
            invokespecial java.security.spec.DSAPublicKeySpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            astore 6 /* ks */
        start local 6 // java.security.spec.DSAPublicKeySpec ks
        13: .line 272
            aload 5 /* kf */
            aload 6 /* ks */
            invokevirtual java.security.KeyFactory.generatePublic:(Ljava/security/spec/KeySpec;)Ljava/security/PublicKey;
            astore 2 /* usableKey */
        end local 6 // java.security.spec.DSAPublicKeySpec ks
        end local 5 // java.security.KeyFactory kf
        end local 4 // java.math.BigInteger y
        start local 2 // java.security.PublicKey usableKey
        14: .line 273
            goto 19
        end local 2 // java.security.PublicKey usableKey
      StackMap locals:
      StackMap stack: java.lang.Exception
        15: astore 4 /* e */
        start local 4 // java.lang.Exception e
        16: .line 274
            new java.security.cert.CertPathValidatorException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unable to generate key with inherited parameters: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        17: .line 276
            aload 4 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* e */
        18: .line 274
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Exception e
        start local 2 // java.security.PublicKey usableKey
        19: .line 278
      StackMap locals: java.security.PublicKey java.security.PublicKey java.security.PublicKey java.security.interfaces.DSAParams
      StackMap stack:
            aload 2 /* usableKey */
            areturn
        end local 3 // java.security.interfaces.DSAParams params
        end local 2 // java.security.PublicKey usableKey
        end local 1 // java.security.PublicKey keyParamsKey
        end local 0 // java.security.PublicKey keyValueKey
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   20     0   keyValueKey  Ljava/security/PublicKey;
            0   20     1  keyParamsKey  Ljava/security/PublicKey;
           14   15     2     usableKey  Ljava/security/PublicKey;
           19   20     2     usableKey  Ljava/security/PublicKey;
            4   20     3        params  Ljava/security/interfaces/DSAParams;
            7   14     4             y  Ljava/math/BigInteger;
            8   14     5            kf  Ljava/security/KeyFactory;
           13   14     6            ks  Ljava/security/spec/DSAPublicKeySpec;
           16   19     4             e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           6    14      15  Class java.lang.Exception
    Exceptions:
      throws java.security.cert.CertPathValidatorException
    MethodParameters:
              Name  Flags
      keyValueKey   
      keyParamsKey  

  java.security.PublicKey getPublicKey();
    descriptor: ()Ljava/security/PublicKey;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.BasicChecker this
         0: .line 287
            aload 0 /* this */
            getfield sun.security.provider.certpath.BasicChecker.prevPubKey:Ljava/security/PublicKey;
            areturn
        end local 0 // sun.security.provider.certpath.BasicChecker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/BasicChecker;
}
SourceFile: "BasicChecker.java"