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

  private static final boolean DEBUG;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  private static final java.lang.String USER_CERT;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "userCertificate;binary"

  private static final java.lang.String CA_CERT;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "cACertificate;binary"

  private static final java.lang.String CROSS_CERT;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "crossCertificatePair;binary"

  private static final java.lang.String CRL;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "certificateRevocationList;binary"

  private static final java.lang.String ARL;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "authorityRevocationList;binary"

  private static final java.lang.String DELTA_CRL;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "deltaRevocationList;binary"

  private static final java.lang.String[] STRING0;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final byte[][] BB0;
    descriptor: [[B
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final javax.naming.directory.Attributes EMPTY_ATTRIBUTES;
    descriptor: Ljavax/naming/directory/Attributes;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int DEFAULT_CACHE_SIZE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 750

  private static final int DEFAULT_CACHE_LIFETIME;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 30

  private static final int LIFETIME;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String PROP_LIFETIME;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "sun.security.certpath.ldap.cache.lifetime"

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

  private javax.naming.directory.DirContext ctx;
    descriptor: Ljavax/naming/directory/DirContext;
    flags: (0x0002) ACC_PRIVATE

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

  private final sun.security.util.Cache valueCache;
    descriptor: Lsun/security/util/Cache;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private int cacheHits;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int cacheMisses;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int requests;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private static final sun.security.util.Cache certStoreCache;
    descriptor: Lsun/security/util/Cache;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 112
            ldc "certpath"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
         1: .line 127
            iconst_0
            anewarray java.lang.String
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.STRING0:[Ljava/lang/String;
         2: .line 129
            iconst_0
            anewarray byte[]
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.BB0:[[B
         3: .line 131
            new javax.naming.directory.BasicAttributes
            dup
            invokespecial javax.naming.directory.BasicAttributes.<init>:()V
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.EMPTY_ATTRIBUTES:Ljavax/naming/directory/Attributes;
         4: .line 144
            new sun.security.action.GetPropertyAction
            dup
            ldc "sun.security.certpath.ldap.cache.lifetime"
            invokespecial sun.security.action.GetPropertyAction.<init>:(Ljava/lang/String;)V
         5: .line 143
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 0 /* s */
        start local 0 // java.lang.String s
         6: .line 145
            aload 0 /* s */
            ifnull 9
         7: .line 146
            aload 0 /* s */
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
         8: .line 147
            goto 10
         9: .line 148
      StackMap locals: java.lang.String
      StackMap stack:
            bipush 30
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
        end local 0 // java.lang.String s
        10: .line 214
      StackMap locals:
      StackMap stack:
            sipush 185
            invokestatic sun.security.util.Cache.newSoftMemoryCache:(I)Lsun/security/util/Cache;
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.certStoreCache:Lsun/security/util/Cache;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            6   10     0     s  Ljava/lang/String;

  public void <init>(java.security.cert.CertStoreParameters);
    descriptor: (Ljava/security/cert/CertStoreParameters;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // java.security.cert.CertStoreParameters params
         0: .line 184
            aload 0 /* this */
            aload 1 /* params */
            invokespecial java.security.cert.CertStoreSpi.<init>:(Ljava/security/cert/CertStoreParameters;)V
         1: .line 165
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
         2: .line 169
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheHits:I
         3: .line 170
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheMisses:I
         4: .line 171
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.requests:I
         5: .line 185
            aload 1 /* params */
            instanceof java.security.cert.LDAPCertStoreParameters
            ifne 9
         6: .line 186
            new java.security.InvalidAlgorithmParameterException
            dup
         7: .line 187
            ldc "parameters must be LDAPCertStoreParameters"
         8: .line 186
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 189
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CertStoreParameters
      StackMap stack:
            aload 1 /* params */
            checkcast java.security.cert.LDAPCertStoreParameters
            astore 2 /* lparams */
        start local 2 // java.security.cert.LDAPCertStoreParameters lparams
        10: .line 192
            aload 0 /* this */
            aload 2 /* lparams */
            invokevirtual java.security.cert.LDAPCertStoreParameters.getServerName:()Ljava/lang/String;
            aload 2 /* lparams */
            invokevirtual java.security.cert.LDAPCertStoreParameters.getPort:()I
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.createInitialDirContext:(Ljava/lang/String;I)V
        11: .line 196
            aload 0 /* this */
            ldc "X.509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.cf:Ljava/security/cert/CertificateFactory;
        12: .line 197
            goto 17
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CertStoreParameters java.security.cert.LDAPCertStoreParameters
      StackMap stack: java.security.cert.CertificateException
        13: pop
        14: .line 198
            new java.security.InvalidAlgorithmParameterException
            dup
        15: .line 199
            ldc "unable to create CertificateFactory for X.509"
        16: .line 198
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 201
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
            ifne 20
        18: .line 202
            aload 0 /* this */
            invokestatic sun.security.util.Cache.newNullCache:()Lsun/security/util/Cache;
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.valueCache:Lsun/security/util/Cache;
        19: .line 203
            goto 24
      StackMap locals:
      StackMap stack:
        20: getstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
            ifge 23
        21: .line 204
            aload 0 /* this */
            sipush 750
            invokestatic sun.security.util.Cache.newSoftMemoryCache:(I)Lsun/security/util/Cache;
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.valueCache:Lsun/security/util/Cache;
        22: .line 205
            goto 24
        23: .line 206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            sipush 750
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
            invokestatic sun.security.util.Cache.newSoftMemoryCache:(II)Lsun/security/util/Cache;
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.valueCache:Lsun/security/util/Cache;
        24: .line 208
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.security.cert.LDAPCertStoreParameters lparams
        end local 1 // java.security.cert.CertStoreParameters params
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   25     0     this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   25     1   params  Ljava/security/cert/CertStoreParameters;
           10   25     2  lparams  Ljava/security/cert/LDAPCertStoreParameters;
      Exception table:
        from    to  target  type
          11    12      13  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      params  

  static synchronized java.security.cert.CertStore getInstance(java.security.cert.LDAPCertStoreParameters);
    descriptor: (Ljava/security/cert/LDAPCertStoreParameters;)Ljava/security/cert/CertStore;
    flags: (0x0028) ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // java.security.cert.LDAPCertStoreParameters params
         0: .line 218
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 1 /* security */
        start local 1 // java.lang.SecurityManager security
         1: .line 219
            aload 1 /* security */
            ifnull 3
         2: .line 220
            aload 1 /* security */
            aload 0 /* params */
            invokevirtual java.security.cert.LDAPCertStoreParameters.getServerName:()Ljava/lang/String;
            aload 0 /* params */
            invokevirtual java.security.cert.LDAPCertStoreParameters.getPort:()I
            invokevirtual java.lang.SecurityManager.checkConnect:(Ljava/lang/String;I)V
         3: .line 223
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.certStoreCache:Lsun/security/util/Cache;
            aload 0 /* params */
            invokevirtual sun.security.util.Cache.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.cert.CertStore
            astore 2 /* lcs */
        start local 2 // java.security.cert.CertStore lcs
         4: .line 224
            aload 2 /* lcs */
            ifnonnull 8
         5: .line 225
            ldc "LDAP"
            aload 0 /* params */
            invokestatic java.security.cert.CertStore.getInstance:(Ljava/lang/String;Ljava/security/cert/CertStoreParameters;)Ljava/security/cert/CertStore;
            astore 2 /* lcs */
         6: .line 226
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.certStoreCache:Lsun/security/util/Cache;
            aload 0 /* params */
            aload 2 /* lcs */
            invokevirtual sun.security.util.Cache.put:(Ljava/lang/Object;Ljava/lang/Object;)V
         7: .line 227
            goto 10
         8: .line 228
      StackMap locals: java.security.cert.CertStore
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 10
         9: .line 229
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.getInstance: cache hit"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        10: .line 232
      StackMap locals:
      StackMap stack:
            aload 2 /* lcs */
            areturn
        end local 2 // java.security.cert.CertStore lcs
        end local 1 // java.lang.SecurityManager security
        end local 0 // java.security.cert.LDAPCertStoreParameters params
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0    params  Ljava/security/cert/LDAPCertStoreParameters;
            1   11     1  security  Ljava/lang/SecurityManager;
            4   11     2       lcs  Ljava/security/cert/CertStore;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      params  

  private void createInitialDirContext(java.lang.String, int);
    descriptor: (Ljava/lang/String;I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // java.lang.String server
        start local 2 // int port
         0: .line 244
            new java.lang.StringBuilder
            dup
            ldc "ldap://"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* server */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ":"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 2 /* port */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* url */
        start local 3 // java.lang.String url
         1: .line 245
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            astore 4 /* env */
        start local 4 // java.util.Hashtable env
         2: .line 246
            aload 4 /* env */
            ldc "java.naming.factory.initial"
         3: .line 247
            ldc "com.sun.jndi.ldap.LdapCtxFactory"
         4: .line 246
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 248
            aload 4 /* env */
            ldc "java.naming.provider.url"
            aload 3 /* url */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 250
            aload 0 /* this */
            new javax.naming.directory.InitialDirContext
            dup
            aload 4 /* env */
            invokespecial javax.naming.directory.InitialDirContext.<init>:(Ljava/util/Hashtable;)V
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.ctx:Ljavax/naming/directory/DirContext;
         7: .line 255
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.ctx:Ljavax/naming/directory/DirContext;
            invokeinterface javax.naming.directory.DirContext.getEnvironment:()Ljava/util/Hashtable;
            astore 5 /* currentEnv */
        start local 5 // java.util.Hashtable currentEnv
         8: .line 256
            aload 5 /* currentEnv */
            ldc "java.naming.referral"
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnonnull 20
         9: .line 257
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.ctx:Ljavax/naming/directory/DirContext;
            ldc "java.naming.referral"
            ldc "throw"
            invokeinterface javax.naming.directory.DirContext.addToEnvironment:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // java.util.Hashtable currentEnv
        10: .line 259
            goto 20
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.lang.String int java.lang.String java.util.Hashtable
      StackMap stack: javax.naming.NamingException
        11: astore 5 /* e */
        start local 5 // javax.naming.NamingException e
        12: .line 260
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 15
        13: .line 261
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineInit about to throw InvalidAlgorithmParameterException"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 263
            aload 5 /* e */
            invokevirtual javax.naming.NamingException.printStackTrace:()V
        15: .line 265
      StackMap locals: javax.naming.NamingException
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        16: .line 266
            ldc "unable to create InitialDirContext using supplied parameters"
        17: .line 265
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            astore 6 /* ee */
        start local 6 // java.lang.Exception ee
        18: .line 267
            aload 6 /* ee */
            aload 5 /* e */
            invokevirtual java.lang.Exception.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        19: .line 268
            aload 6 /* ee */
            checkcast java.security.InvalidAlgorithmParameterException
            athrow
        end local 6 // java.lang.Exception ee
        end local 5 // javax.naming.NamingException e
        20: .line 270
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.util.Hashtable env
        end local 3 // java.lang.String url
        end local 2 // int port
        end local 1 // java.lang.String server
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   21     0        this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   21     1      server  Ljava/lang/String;
            0   21     2        port  I
            1   21     3         url  Ljava/lang/String;
            2   21     4         env  Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;
            8   10     5  currentEnv  Ljava/util/Hashtable<**>;
           12   20     5           e  Ljavax/naming/NamingException;
           18   20     6          ee  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           6    10      11  Class javax.naming.NamingException
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      server  
      port    

  private java.util.Collection<java.security.cert.X509Certificate> getCertificates(sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest, java.lang.String, java.security.cert.X509CertSelector);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=10, args_size=4
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        start local 2 // java.lang.String id
        start local 3 // java.security.cert.X509CertSelector sel
         0: .line 481
            aload 1 /* request */
            aload 2 /* id */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.getValues:(Ljava/lang/String;)[[B
            astore 4 /* encodedCert */
        start local 4 // byte[][] encodedCert
         1: .line 482
            goto 4
        end local 4 // byte[][] encodedCert
      StackMap locals:
      StackMap stack: javax.naming.NamingException
         2: astore 5 /* namingEx */
        start local 5 // javax.naming.NamingException namingEx
         3: .line 483
            new java.security.cert.CertStoreException
            dup
            aload 5 /* namingEx */
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 5 // javax.naming.NamingException namingEx
        start local 4 // byte[][] encodedCert
         4: .line 486
      StackMap locals: byte[][]
      StackMap stack:
            aload 4 /* encodedCert */
            arraylength
            istore 5 /* n */
        start local 5 // int n
         5: .line 487
            iload 5 /* n */
            ifne 7
         6: .line 488
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 491
      StackMap locals: int
      StackMap stack:
            new java.util.ArrayList
            dup
            iload 5 /* n */
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 6 /* certs */
        start local 6 // java.util.List certs
         8: .line 493
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         9: goto 23
        10: .line 494
      StackMap locals: java.util.List int
      StackMap stack:
            new java.io.ByteArrayInputStream
            dup
            aload 4 /* encodedCert */
            iload 7 /* i */
            aaload
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 8 /* bais */
        start local 8 // java.io.ByteArrayInputStream bais
        11: .line 496
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.cf:Ljava/security/cert/CertificateFactory;
            aload 8 /* bais */
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            astore 9 /* cert */
        start local 9 // java.security.cert.Certificate cert
        12: .line 497
            aload 3 /* sel */
            aload 9 /* cert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 22
        13: .line 498
            aload 6 /* certs */
            aload 9 /* cert */
            checkcast java.security.cert.X509Certificate
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 9 // java.security.cert.Certificate cert
        14: .line 500
            goto 22
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.lang.String java.security.cert.X509CertSelector byte[][] int java.util.List int java.io.ByteArrayInputStream
      StackMap stack: java.security.cert.CertificateException
        15: pop
        16: .line 501
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 22
        17: .line 502
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.getCertificates() encountered exception while parsing cert, skipping the bad data: "
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        18: .line 504
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 9 /* encoder */
        start local 9 // sun.misc.HexDumpEncoder encoder
        19: .line 505
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        20: .line 506
            new java.lang.StringBuilder
            dup
            ldc "[ "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* encoder */
            aload 4 /* encodedCert */
            iload 7 /* i */
            aaload
            invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:([B)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;
        21: .line 505
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 9 // sun.misc.HexDumpEncoder encoder
        end local 8 // java.io.ByteArrayInputStream bais
        22: .line 493
      StackMap locals:
      StackMap stack:
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        23: iload 7 /* i */
            iload 5 /* n */
            if_icmplt 10
        end local 7 // int i
        24: .line 511
            aload 6 /* certs */
            areturn
        end local 6 // java.util.List certs
        end local 5 // int n
        end local 4 // byte[][] encodedCert
        end local 3 // java.security.cert.X509CertSelector sel
        end local 2 // java.lang.String id
        end local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   25     0         this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   25     1      request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0   25     2           id  Ljava/lang/String;
            0   25     3          sel  Ljava/security/cert/X509CertSelector;
            1    2     4  encodedCert  [[B
            4   25     4  encodedCert  [[B
            3    4     5     namingEx  Ljavax/naming/NamingException;
            5   25     5            n  I
            8   25     6        certs  Ljava/util/List<Ljava/security/cert/X509Certificate;>;
            9   24     7            i  I
           11   22     8         bais  Ljava/io/ByteArrayInputStream;
           12   14     9         cert  Ljava/security/cert/Certificate;
           19   22     9      encoder  Lsun/misc/HexDumpEncoder;
      Exception table:
        from    to  target  type
           0     1       2  Class javax.naming.NamingException
          11    14      15  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
         Name  Flags
      request  
      id       
      sel      

  private java.util.Collection<sun.security.provider.certpath.X509CertificatePair> getCertPairs(sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest, java.lang.String);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;)Ljava/util/Collection;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        start local 2 // java.lang.String id
         0: .line 529
            aload 1 /* request */
            aload 2 /* id */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.getValues:(Ljava/lang/String;)[[B
            astore 3 /* encodedCertPair */
        start local 3 // byte[][] encodedCertPair
         1: .line 530
            goto 4
        end local 3 // byte[][] encodedCertPair
      StackMap locals:
      StackMap stack: javax.naming.NamingException
         2: astore 4 /* namingEx */
        start local 4 // javax.naming.NamingException namingEx
         3: .line 531
            new java.security.cert.CertStoreException
            dup
            aload 4 /* namingEx */
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 4 // javax.naming.NamingException namingEx
        start local 3 // byte[][] encodedCertPair
         4: .line 534
      StackMap locals: byte[][]
      StackMap stack:
            aload 3 /* encodedCertPair */
            arraylength
            istore 4 /* n */
        start local 4 // int n
         5: .line 535
            iload 4 /* n */
            ifne 7
         6: .line 536
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 540
      StackMap locals: int
      StackMap stack:
            new java.util.ArrayList
            dup
            iload 4 /* n */
            invokespecial java.util.ArrayList.<init>:(I)V
         8: .line 539
            astore 5 /* certPairs */
        start local 5 // java.util.List certPairs
         9: .line 542
            iconst_0
            istore 6 /* i */
        start local 6 // int i
        10: goto 25
        11: .line 545
      StackMap locals: java.util.List int
      StackMap stack:
            aload 3 /* encodedCertPair */
            iload 6 /* i */
            aaload
            invokestatic sun.security.provider.certpath.X509CertificatePair.generateCertificatePair:([B)Lsun/security/provider/certpath/X509CertificatePair;
        12: .line 544
            astore 7 /* certPair */
        start local 7 // sun.security.provider.certpath.X509CertificatePair certPair
        13: .line 546
            aload 5 /* certPairs */
            aload 7 /* certPair */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // sun.security.provider.certpath.X509CertificatePair certPair
        14: .line 547
            goto 24
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
        15: pop
        16: .line 548
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 24
        17: .line 549
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        18: .line 550
            ldc "LDAPCertStore.getCertPairs() encountered exception while parsing cert, skipping the bad data: "
        19: .line 549
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        20: .line 552
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 7 /* encoder */
        start local 7 // sun.misc.HexDumpEncoder encoder
        21: .line 553
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        22: .line 554
            new java.lang.StringBuilder
            dup
            ldc "[ "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* encoder */
            aload 3 /* encodedCertPair */
            iload 6 /* i */
            aaload
            invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:([B)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;
        23: .line 553
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // sun.misc.HexDumpEncoder encoder
        24: .line 542
      StackMap locals:
      StackMap stack:
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        25: iload 6 /* i */
            iload 4 /* n */
            if_icmplt 11
        end local 6 // int i
        26: .line 559
            aload 5 /* certPairs */
            areturn
        end local 5 // java.util.List certPairs
        end local 4 // int n
        end local 3 // byte[][] encodedCertPair
        end local 2 // java.lang.String id
        end local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   27     0             this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   27     1          request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0   27     2               id  Ljava/lang/String;
            1    2     3  encodedCertPair  [[B
            4   27     3  encodedCertPair  [[B
            3    4     4         namingEx  Ljavax/naming/NamingException;
            5   27     4                n  I
            9   27     5        certPairs  Ljava/util/List<Lsun/security/provider/certpath/X509CertificatePair;>;
           10   26     6                i  I
           13   14     7         certPair  Lsun/security/provider/certpath/X509CertificatePair;
           21   24     7          encoder  Lsun/misc/HexDumpEncoder;
      Exception table:
        from    to  target  type
           0     1       2  Class javax.naming.NamingException
          11    14      15  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;)Ljava/util/Collection<Lsun/security/provider/certpath/X509CertificatePair;>;
    MethodParameters:
         Name  Flags
      request  
      id       

  private java.util.Collection<java.security.cert.X509Certificate> getMatchingCrossCerts(sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest, java.security.cert.X509CertSelector, java.security.cert.X509CertSelector);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/security/cert/X509CertSelector;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=9, args_size=4
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        start local 2 // java.security.cert.X509CertSelector forward
        start local 3 // java.security.cert.X509CertSelector reverse
         0: .line 584
            aload 0 /* this */
            aload 1 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getCertPairs:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;)Ljava/util/Collection;
         1: .line 583
            astore 4 /* certPairs */
        start local 4 // java.util.Collection certPairs
         2: .line 588
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
         3: .line 587
            astore 5 /* matchingCerts */
        start local 5 // java.util.ArrayList matchingCerts
         4: .line 589
            aload 4 /* certPairs */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 14
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.security.cert.X509CertSelector java.security.cert.X509CertSelector java.util.Collection java.util.ArrayList top java.util.Iterator
      StackMap stack:
         5: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.provider.certpath.X509CertificatePair
            astore 6 /* certPair */
        start local 6 // sun.security.provider.certpath.X509CertificatePair certPair
         6: .line 591
            aload 2 /* forward */
            ifnull 10
         7: .line 592
            aload 6 /* certPair */
            invokevirtual sun.security.provider.certpath.X509CertificatePair.getForward:()Ljava/security/cert/X509Certificate;
            astore 8 /* cert */
        start local 8 // java.security.cert.X509Certificate cert
         8: .line 593
            aload 8 /* cert */
            ifnull 10
            aload 2 /* forward */
            aload 8 /* cert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 10
         9: .line 594
            aload 5 /* matchingCerts */
            aload 8 /* cert */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // java.security.cert.X509Certificate cert
        10: .line 597
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.security.cert.X509CertSelector java.security.cert.X509CertSelector java.util.Collection java.util.ArrayList sun.security.provider.certpath.X509CertificatePair java.util.Iterator
      StackMap stack:
            aload 3 /* reverse */
            ifnull 14
        11: .line 598
            aload 6 /* certPair */
            invokevirtual sun.security.provider.certpath.X509CertificatePair.getReverse:()Ljava/security/cert/X509Certificate;
            astore 8 /* cert */
        start local 8 // java.security.cert.X509Certificate cert
        12: .line 599
            aload 8 /* cert */
            ifnull 14
            aload 3 /* reverse */
            aload 8 /* cert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 14
        13: .line 600
            aload 5 /* matchingCerts */
            aload 8 /* cert */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // java.security.cert.X509Certificate cert
        end local 6 // sun.security.provider.certpath.X509CertificatePair certPair
        14: .line 589
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.security.cert.X509CertSelector java.security.cert.X509CertSelector java.util.Collection java.util.ArrayList top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        15: .line 604
            aload 5 /* matchingCerts */
            areturn
        end local 5 // java.util.ArrayList matchingCerts
        end local 4 // java.util.Collection certPairs
        end local 3 // java.security.cert.X509CertSelector reverse
        end local 2 // java.security.cert.X509CertSelector forward
        end local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   16     0           this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   16     1        request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0   16     2        forward  Ljava/security/cert/X509CertSelector;
            0   16     3        reverse  Ljava/security/cert/X509CertSelector;
            2   16     4      certPairs  Ljava/util/Collection<Lsun/security/provider/certpath/X509CertificatePair;>;
            4   16     5  matchingCerts  Ljava/util/ArrayList<Ljava/security/cert/X509Certificate;>;
            6   14     6       certPair  Lsun/security/provider/certpath/X509CertificatePair;
            8   10     8           cert  Ljava/security/cert/X509Certificate;
           12   14     8           cert  Ljava/security/cert/X509Certificate;
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/security/cert/X509CertSelector;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
         Name  Flags
      request  
      forward  
      reverse  

  public synchronized java.util.Collection<java.security.cert.X509Certificate> engineGetCertificates(java.security.cert.CertSelector);
    descriptor: (Ljava/security/cert/CertSelector;)Ljava/util/Collection;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=8, args_size=2
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // java.security.cert.CertSelector selector
         0: .line 630
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 631
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() selector: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 632
            aload 1 /* selector */
            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;
         3: .line 631
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 635
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            ifnonnull 6
         5: .line 636
            new java.security.cert.X509CertSelector
            dup
            invokespecial java.security.cert.X509CertSelector.<init>:()V
            astore 1 /* selector */
         6: .line 638
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            instanceof java.security.cert.X509CertSelector
            ifne 8
         7: .line 639
            new java.security.cert.CertStoreException
            dup
            ldc "LDAPCertStore needs an X509CertSelector to find certs"
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 642
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            checkcast java.security.cert.X509CertSelector
            astore 2 /* xsel */
        start local 2 // java.security.cert.X509CertSelector xsel
         9: .line 643
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getBasicConstraints:()I
            istore 3 /* basicConstraints */
        start local 3 // int basicConstraints
        10: .line 644
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getSubjectAsString:()Ljava/lang/String;
            astore 4 /* subject */
        start local 4 // java.lang.String subject
        11: .line 645
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getIssuerAsString:()Ljava/lang/String;
            astore 5 /* issuer */
        start local 5 // java.lang.String issuer
        12: .line 646
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 6 /* certs */
        start local 6 // java.util.HashSet certs
        13: .line 647
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 17
        14: .line 648
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() basicConstraints: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        15: .line 649
            iload 3 /* basicConstraints */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 648
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        17: .line 657
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CertSelector java.security.cert.X509CertSelector int java.lang.String java.lang.String java.util.HashSet
      StackMap stack:
            aload 4 /* subject */
            ifnull 47
        18: .line 658
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 20
        19: .line 659
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineGetCertificates() subject is not null"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        20: .line 662
      StackMap locals:
      StackMap stack:
            new sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
            dup
            aload 0 /* this */
            aload 4 /* subject */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStore;Ljava/lang/String;)V
            astore 7 /* request */
        start local 7 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        21: .line 663
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 27
        22: .line 664
            aload 7 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        23: .line 665
            aload 7 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        24: .line 666
            aload 7 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        25: .line 667
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
            ifeq 27
        26: .line 668
            aload 7 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        27: .line 671
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
      StackMap stack:
            iload 3 /* basicConstraints */
            ifge 29
        28: .line 672
            aload 7 /* request */
            ldc "userCertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        29: .line 675
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 40
        30: .line 676
            aload 6 /* certs */
            aload 0 /* this */
            aload 7 /* request */
            aload 2 /* xsel */
            aconst_null
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getMatchingCrossCerts:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/security/cert/X509CertSelector;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        31: .line 677
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 35
        32: .line 678
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() after getMatchingCrossCerts(subject,xsel,null),certs.size(): "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        33: .line 680
            aload 6 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 678
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        35: .line 682
      StackMap locals:
      StackMap stack:
            aload 6 /* certs */
            aload 0 /* this */
            aload 7 /* request */
            ldc "cACertificate;binary"
            aload 2 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getCertificates:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        36: .line 683
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 40
        37: .line 684
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() after getCertificates(subject,CA_CERT,xsel),certs.size(): "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        38: .line 686
            aload 6 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        39: .line 684
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        40: .line 689
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            ifge 55
        41: .line 690
            aload 6 /* certs */
            aload 0 /* this */
            aload 7 /* request */
            ldc "userCertificate;binary"
            aload 2 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getCertificates:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        42: .line 691
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 55
        43: .line 692
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() after getCertificates(subject,USER_CERT, xsel),certs.size(): "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        44: .line 694
            aload 6 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        45: .line 692
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        46: .line 697
            goto 55
        47: .line 698
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 51
        48: .line 699
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        49: .line 700
            ldc "LDAPCertStore.engineGetCertificates() subject is null"
        50: .line 699
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        51: .line 702
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            bipush -2
            if_icmpne 53
        52: .line 703
            new java.security.cert.CertStoreException
            dup
            ldc "need subject to find EE certs"
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
        53: .line 705
      StackMap locals:
      StackMap stack:
            aload 5 /* issuer */
            ifnonnull 55
        54: .line 706
            new java.security.cert.CertStoreException
            dup
            ldc "need subject or issuer to find certs"
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
        55: .line 709
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 57
        56: .line 710
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineGetCertificates() about to getMatchingCrossCerts..."
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        57: .line 713
      StackMap locals:
      StackMap stack:
            aload 5 /* issuer */
            ifnull 74
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 74
        58: .line 714
            new sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
            dup
            aload 0 /* this */
            aload 5 /* issuer */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStore;Ljava/lang/String;)V
            astore 7 /* request */
        start local 7 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        59: .line 715
            aload 7 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        60: .line 716
            aload 7 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        61: .line 717
            aload 7 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        62: .line 718
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
            ifeq 64
        63: .line 719
            aload 7 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        64: .line 722
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
      StackMap stack:
            aload 6 /* certs */
            aload 0 /* this */
            aload 7 /* request */
            aconst_null
            aload 2 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getMatchingCrossCerts:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/security/cert/X509CertSelector;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        65: .line 723
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 69
        66: .line 724
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() after getMatchingCrossCerts(issuer,null,xsel),certs.size(): "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        67: .line 726
            aload 6 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        68: .line 724
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        69: .line 728
      StackMap locals:
      StackMap stack:
            aload 6 /* certs */
            aload 0 /* this */
            aload 7 /* request */
            ldc "cACertificate;binary"
            aload 2 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getCertificates:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        70: .line 729
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 74
        71: .line 730
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() after getCertificates(issuer,CA_CERT,xsel),certs.size(): "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        72: .line 732
            aload 6 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        73: .line 730
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        74: .line 735
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 76
        75: .line 736
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineGetCertificates() returning certs"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        76: .line 738
      StackMap locals:
      StackMap stack:
            aload 6 /* certs */
            areturn
        end local 6 // java.util.HashSet certs
        end local 5 // java.lang.String issuer
        end local 4 // java.lang.String subject
        end local 3 // int basicConstraints
        end local 2 // java.security.cert.X509CertSelector xsel
        end local 1 // java.security.cert.CertSelector selector
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   77     0              this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   77     1          selector  Ljava/security/cert/CertSelector;
            9   77     2              xsel  Ljava/security/cert/X509CertSelector;
           10   77     3  basicConstraints  I
           11   77     4           subject  Ljava/lang/String;
           12   77     5            issuer  Ljava/lang/String;
           13   77     6             certs  Ljava/util/HashSet<Ljava/security/cert/X509Certificate;>;
           21   46     7           request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
           59   74     7           request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Ljava/security/cert/CertSelector;)Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
          Name  Flags
      selector  

  private java.util.Collection<java.security.cert.X509CRL> getCRLs(sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest, java.lang.String, java.security.cert.X509CRLSelector);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CRLSelector;)Ljava/util/Collection;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=9, args_size=4
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        start local 2 // java.lang.String id
        start local 3 // java.security.cert.X509CRLSelector sel
         0: .line 758
            aload 1 /* request */
            aload 2 /* id */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.getValues:(Ljava/lang/String;)[[B
            astore 4 /* encodedCRL */
        start local 4 // byte[][] encodedCRL
         1: .line 759
            goto 4
        end local 4 // byte[][] encodedCRL
      StackMap locals:
      StackMap stack: javax.naming.NamingException
         2: astore 5 /* namingEx */
        start local 5 // javax.naming.NamingException namingEx
         3: .line 760
            new java.security.cert.CertStoreException
            dup
            aload 5 /* namingEx */
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 5 // javax.naming.NamingException namingEx
        start local 4 // byte[][] encodedCRL
         4: .line 763
      StackMap locals: byte[][]
      StackMap stack:
            aload 4 /* encodedCRL */
            arraylength
            istore 5 /* n */
        start local 5 // int n
         5: .line 764
            iload 5 /* n */
            ifne 7
         6: .line 765
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 768
      StackMap locals: int
      StackMap stack:
            new java.util.ArrayList
            dup
            iload 5 /* n */
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 6 /* crls */
        start local 6 // java.util.List crls
         8: .line 770
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         9: goto 20
        10: .line 772
      StackMap locals: java.util.List int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.cf:Ljava/security/cert/CertificateFactory;
            new java.io.ByteArrayInputStream
            dup
            aload 4 /* encodedCRL */
            iload 7 /* i */
            aaload
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            invokevirtual java.security.cert.CertificateFactory.generateCRL:(Ljava/io/InputStream;)Ljava/security/cert/CRL;
            astore 8 /* crl */
        start local 8 // java.security.cert.CRL crl
        11: .line 773
            aload 3 /* sel */
            aload 8 /* crl */
            invokevirtual java.security.cert.X509CRLSelector.match:(Ljava/security/cert/CRL;)Z
            ifeq 19
        12: .line 774
            aload 6 /* crls */
            aload 8 /* crl */
            checkcast java.security.cert.X509CRL
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // java.security.cert.CRL crl
        13: .line 776
            goto 19
      StackMap locals:
      StackMap stack: java.security.cert.CRLException
        14: pop
        15: .line 777
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 19
        16: .line 778
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.getCRLs() encountered exception while parsing CRL, skipping the bad data: "
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        17: .line 780
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 8 /* encoder */
        start local 8 // sun.misc.HexDumpEncoder encoder
        18: .line 781
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "[ "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* encoder */
            aload 4 /* encodedCRL */
            iload 7 /* i */
            aaload
            invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:([B)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
        end local 8 // sun.misc.HexDumpEncoder encoder
        19: .line 770
      StackMap locals:
      StackMap stack:
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        20: iload 7 /* i */
            iload 5 /* n */
            if_icmplt 10
        end local 7 // int i
        21: .line 786
            aload 6 /* crls */
            areturn
        end local 6 // java.util.List crls
        end local 5 // int n
        end local 4 // byte[][] encodedCRL
        end local 3 // java.security.cert.X509CRLSelector sel
        end local 2 // java.lang.String id
        end local 1 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   22     0        this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   22     1     request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0   22     2          id  Ljava/lang/String;
            0   22     3         sel  Ljava/security/cert/X509CRLSelector;
            1    2     4  encodedCRL  [[B
            4   22     4  encodedCRL  [[B
            3    4     5    namingEx  Ljavax/naming/NamingException;
            5   22     5           n  I
            8   22     6        crls  Ljava/util/List<Ljava/security/cert/X509CRL;>;
            9   21     7           i  I
           11   13     8         crl  Ljava/security/cert/CRL;
           18   19     8     encoder  Lsun/misc/HexDumpEncoder;
      Exception table:
        from    to  target  type
           0     1       2  Class javax.naming.NamingException
          10    13      14  Class java.security.cert.CRLException
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CRLSelector;)Ljava/util/Collection<Ljava/security/cert/X509CRL;>;
    MethodParameters:
         Name  Flags
      request  
      id       
      sel      

  public synchronized java.util.Collection<java.security.cert.X509CRL> engineGetCRLs(java.security.cert.CRLSelector);
    descriptor: (Ljava/security/cert/CRLSelector;)Ljava/util/Collection;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=12, args_size=2
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
        start local 1 // java.security.cert.CRLSelector selector
         0: .line 812
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 813
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCRLs() selector: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 814
            aload 1 /* selector */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 813
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 817
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            ifnonnull 6
         5: .line 818
            new java.security.cert.X509CRLSelector
            dup
            invokespecial java.security.cert.X509CRLSelector.<init>:()V
            astore 1 /* selector */
         6: .line 820
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            instanceof java.security.cert.X509CRLSelector
            ifne 8
         7: .line 821
            new java.security.cert.CertStoreException
            dup
            ldc "need X509CRLSelector to find CRLs"
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 823
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            checkcast java.security.cert.X509CRLSelector
            astore 2 /* xsel */
        start local 2 // java.security.cert.X509CRLSelector xsel
         9: .line 824
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 3 /* crls */
        start local 3 // java.util.HashSet crls
        10: .line 828
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CRLSelector.getCertificateChecking:()Ljava/security/cert/X509Certificate;
            astore 5 /* certChecking */
        start local 5 // java.security.cert.X509Certificate certChecking
        11: .line 829
            aload 5 /* certChecking */
            ifnull 16
        12: .line 830
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 4 /* issuerNames */
        start local 4 // java.util.Collection issuerNames
        13: .line 831
            aload 5 /* certChecking */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 6 /* issuer */
        start local 6 // javax.security.auth.x500.X500Principal issuer
        14: .line 832
            aload 4 /* issuerNames */
            aload 6 /* issuer */
            ldc "RFC2253"
            invokevirtual javax.security.auth.x500.X500Principal.getName:(Ljava/lang/String;)Ljava/lang/String;
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        end local 6 // javax.security.auth.x500.X500Principal issuer
        15: .line 833
            goto 19
        end local 4 // java.util.Collection issuerNames
        16: .line 836
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CRLSelector java.security.cert.X509CRLSelector java.util.HashSet top java.security.cert.X509Certificate
      StackMap stack:
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CRLSelector.getIssuerNames:()Ljava/util/Collection;
            astore 4 /* issuerNames */
        start local 4 // java.util.Collection issuerNames
        17: .line 837
            aload 4 /* issuerNames */
            ifnonnull 19
        18: .line 838
            new java.security.cert.CertStoreException
            dup
            ldc "need issuerNames or certChecking to find CRLs"
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 842
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CRLSelector java.security.cert.X509CRLSelector java.util.HashSet java.util.Collection java.security.cert.X509Certificate
      StackMap stack:
            aload 4 /* issuerNames */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 53
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CRLSelector java.security.cert.X509CRLSelector java.util.HashSet java.util.Collection java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
        20: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 6 /* nameObject */
        start local 6 // java.lang.Object nameObject
        21: .line 844
            aload 6 /* nameObject */
            instanceof byte[]
            ifeq 27
        22: .line 846
            new javax.security.auth.x500.X500Principal
            dup
            aload 6 /* nameObject */
            checkcast byte[]
            invokespecial javax.security.auth.x500.X500Principal.<init>:([B)V
            astore 9 /* issuer */
        start local 9 // javax.security.auth.x500.X500Principal issuer
        23: .line 847
            aload 9 /* issuer */
            ldc "RFC2253"
            invokevirtual javax.security.auth.x500.X500Principal.getName:(Ljava/lang/String;)Ljava/lang/String;
            astore 8 /* issuerName */
        end local 9 // javax.security.auth.x500.X500Principal issuer
        start local 8 // java.lang.String issuerName
        24: .line 848
            goto 28
        end local 8 // java.lang.String issuerName
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CRLSelector java.security.cert.X509CRLSelector java.util.HashSet java.util.Collection java.security.cert.X509Certificate java.lang.Object java.util.Iterator
      StackMap stack: java.lang.IllegalArgumentException
        25: pop
        26: .line 849
            goto 53
        27: .line 852
      StackMap locals:
      StackMap stack:
            aload 6 /* nameObject */
            checkcast java.lang.String
            astore 8 /* issuerName */
        start local 8 // java.lang.String issuerName
        28: .line 855
      StackMap locals: java.lang.String
      StackMap stack:
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            astore 9 /* entryCRLs */
        start local 9 // java.util.Collection entryCRLs
        29: .line 856
            aload 5 /* certChecking */
            ifnull 30
            aload 5 /* certChecking */
            invokevirtual java.security.cert.X509Certificate.getBasicConstraints:()I
            iconst_m1
            if_icmpeq 48
        30: .line 857
      StackMap locals: java.util.Collection
      StackMap stack:
            new sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
            dup
            aload 0 /* this */
            aload 8 /* issuerName */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStore;Ljava/lang/String;)V
            astore 10 /* request */
        start local 10 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        31: .line 858
            aload 10 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        32: .line 859
            aload 10 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        33: .line 860
            aload 10 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        34: .line 861
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
            ifeq 36
        35: .line 862
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        36: .line 865
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
      StackMap stack:
            aload 0 /* this */
            aload 10 /* request */
            ldc "authorityRevocationList;binary"
            aload 2 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getCRLs:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CRLSelector;)Ljava/util/Collection;
            astore 9 /* entryCRLs */
        37: .line 866
            aload 9 /* entryCRLs */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 40
        38: .line 869
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
        39: .line 870
            goto 48
        40: .line 871
      StackMap locals:
      StackMap stack:
            aload 3 /* crls */
            aload 9 /* entryCRLs */
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        41: .line 873
            goto 48
      StackMap locals:
      StackMap stack: java.security.cert.CertStoreException
        42: astore 11 /* e */
        start local 11 // java.security.cert.CertStoreException e
        43: .line 874
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 48
        44: .line 875
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCRLs non-fatal error retrieving ARLs:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        45: .line 876
            aload 11 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        46: .line 875
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        47: .line 877
            aload 11 /* e */
            invokevirtual java.security.cert.CertStoreException.printStackTrace:()V
        end local 11 // java.security.cert.CertStoreException e
        end local 10 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        48: .line 884
      StackMap locals:
      StackMap stack:
            aload 9 /* entryCRLs */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 49
            aload 5 /* certChecking */
            ifnonnull 53
        49: .line 885
      StackMap locals:
      StackMap stack:
            new sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
            dup
            aload 0 /* this */
            aload 8 /* issuerName */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStore;Ljava/lang/String;)V
            astore 10 /* request */
        start local 10 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        50: .line 886
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        51: .line 887
            aload 0 /* this */
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            aload 2 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore.getCRLs:(Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CRLSelector;)Ljava/util/Collection;
            astore 9 /* entryCRLs */
        52: .line 888
            aload 3 /* crls */
            aload 9 /* entryCRLs */
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        end local 10 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        end local 9 // java.util.Collection entryCRLs
        end local 8 // java.lang.String issuerName
        end local 6 // java.lang.Object nameObject
        53: .line 842
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore java.security.cert.CRLSelector java.security.cert.X509CRLSelector java.util.HashSet java.util.Collection java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 20
        54: .line 891
            aload 3 /* crls */
            areturn
        end local 5 // java.security.cert.X509Certificate certChecking
        end local 4 // java.util.Collection issuerNames
        end local 3 // java.util.HashSet crls
        end local 2 // java.security.cert.X509CRLSelector xsel
        end local 1 // java.security.cert.CRLSelector selector
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   55     0          this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   55     1      selector  Ljava/security/cert/CRLSelector;
            9   55     2          xsel  Ljava/security/cert/X509CRLSelector;
           10   55     3          crls  Ljava/util/HashSet<Ljava/security/cert/X509CRL;>;
           13   16     4   issuerNames  Ljava/util/Collection<Ljava/lang/Object;>;
           17   55     4   issuerNames  Ljava/util/Collection<Ljava/lang/Object;>;
           11   55     5  certChecking  Ljava/security/cert/X509Certificate;
           14   15     6        issuer  Ljavax/security/auth/x500/X500Principal;
           21   53     6    nameObject  Ljava/lang/Object;
           24   25     8    issuerName  Ljava/lang/String;
           28   53     8    issuerName  Ljava/lang/String;
           23   24     9        issuer  Ljavax/security/auth/x500/X500Principal;
           29   53     9     entryCRLs  Ljava/util/Collection<Ljava/security/cert/X509CRL;>;
           31   48    10       request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
           43   48    11             e  Ljava/security/cert/CertStoreException;
           50   53    10       request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
      Exception table:
        from    to  target  type
          22    24      25  Class java.lang.IllegalArgumentException
          36    41      42  Class java.security.cert.CertStoreException
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Ljava/security/cert/CRLSelector;)Ljava/util/Collection<Ljava/security/cert/X509CRL;>;
    MethodParameters:
          Name  Flags
      selector  

  static java.security.cert.LDAPCertStoreParameters getParameters(java.net.URI);
    descriptor: (Ljava/net/URI;)Ljava/security/cert/LDAPCertStoreParameters;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // java.net.URI uri
         0: .line 896
            aload 0 /* uri */
            invokevirtual java.net.URI.getHost:()Ljava/lang/String;
            astore 1 /* host */
        start local 1 // java.lang.String host
         1: .line 897
            aload 1 /* host */
            ifnonnull 3
         2: .line 898
            new sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters
            dup
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters.<init>:()V
            areturn
         3: .line 900
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* uri */
            invokevirtual java.net.URI.getPort:()I
            istore 2 /* port */
        start local 2 // int port
         4: .line 901
            iload 2 /* port */
            iconst_m1
            if_icmpne 6
         5: .line 902
            new sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters
            dup
            aload 1 /* host */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters.<init>:(Ljava/lang/String;)V
            goto 7
         6: .line 903
      StackMap locals: int
      StackMap stack:
            new sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters
            dup
            aload 1 /* host */
            iload 2 /* port */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters.<init>:(Ljava/lang/String;I)V
         7: .line 901
      StackMap locals:
      StackMap stack: sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters
            areturn
        end local 2 // int port
        end local 1 // java.lang.String host
        end local 0 // java.net.URI uri
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0   uri  Ljava/net/URI;
            1    8     1  host  Ljava/lang/String;
            4    8     2  port  I
    MethodParameters:
      Name  Flags
      uri   
}
SourceFile: "LDAPCertStore.java"
NestMembers:
  sun.security.provider.certpath.ldap.LDAPCertStore$LDAPCRLSelector  sun.security.provider.certpath.ldap.LDAPCertStore$LDAPCertSelector  sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest  sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters
InnerClasses:
  LDAPCRLSelector = sun.security.provider.certpath.ldap.LDAPCertStore$LDAPCRLSelector of sun.security.provider.certpath.ldap.LDAPCertStore
  LDAPCertSelector = sun.security.provider.certpath.ldap.LDAPCertStore$LDAPCertSelector of sun.security.provider.certpath.ldap.LDAPCertStore
  private LDAPRequest = sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest of sun.security.provider.certpath.ldap.LDAPCertStore
  private SunLDAPCertStoreParameters = sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters of sun.security.provider.certpath.ldap.LDAPCertStore