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 static final java.lang.String PROP_DISABLE_APP_RESOURCE_FILES;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "sun.security.certpath.ldap.disable.app.resource.files"

  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<java.lang.String, byte[][]> valueCache;
    descriptor: Lsun/security/util/Cache;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Lsun/security/util/Cache<Ljava/lang/String;[[B>;

  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<java.security.cert.LDAPCertStoreParameters, java.security.cert.CertStore> certStoreCache;
    descriptor: Lsun/security/util/Cache;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Lsun/security/util/Cache<Ljava/security/cert/LDAPCertStoreParameters;Ljava/security/cert/CertStore;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 113
            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 128
            iconst_0
            anewarray java.lang.String
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.STRING0:[Ljava/lang/String;
         2: .line 130
            iconst_0
            anewarray byte[]
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.BB0:[[B
         3: .line 132
            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 153
            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 152
            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 154
            aload 0 /* s */
            ifnull 9
         7: .line 155
            aload 0 /* s */
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            putstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
         8: .line 156
            goto 10
         9: .line 157
      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 224
      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 193
            aload 0 /* this */
            aload 1 /* params */
            invokespecial java.security.cert.CertStoreSpi.<init>:(Ljava/security/cert/CertStoreParameters;)V
         1: .line 174
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
         2: .line 178
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheHits:I
         3: .line 179
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheMisses:I
         4: .line 180
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.requests:I
         5: .line 194
            aload 1 /* params */
            instanceof java.security.cert.LDAPCertStoreParameters
            ifne 9
         6: .line 195
            new java.security.InvalidAlgorithmParameterException
            dup
         7: .line 196
            ldc "parameters must be LDAPCertStoreParameters"
         8: .line 195
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 198
      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 201
            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 205
            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 206
            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 207
            new java.security.InvalidAlgorithmParameterException
            dup
        15: .line 208
            ldc "unable to create CertificateFactory for X.509"
        16: .line 207
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 210
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
            ifne 20
        18: .line 211
            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 212
            goto 24
      StackMap locals:
      StackMap stack:
        20: getstatic sun.security.provider.certpath.ldap.LDAPCertStore.LIFETIME:I
            ifge 23
        21: .line 213
            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 214
            goto 24
        23: .line 215
      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 217
      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 228
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 1 /* security */
        start local 1 // java.lang.SecurityManager security
         1: .line 229
            aload 1 /* security */
            ifnull 3
         2: .line 230
            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 233
      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 234
            aload 2 /* lcs */
            ifnonnull 8
         5: .line 235
            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 236
            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 237
            goto 10
         8: .line 238
      StackMap locals: java.security.cert.CertStore
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 10
         9: .line 239
            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 242
      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=8, 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 254
            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 255
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            astore 4 /* env */
        start local 4 // java.util.Hashtable env
         2: .line 256
            aload 4 /* env */
            ldc "java.naming.factory.initial"
         3: .line 257
            ldc "com.sun.jndi.ldap.LdapCtxFactory"
         4: .line 256
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 258
            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 262
            new sun.security.action.GetBooleanAction
            dup
            ldc "sun.security.certpath.ldap.disable.app.resource.files"
            invokespecial sun.security.action.GetBooleanAction.<init>:(Ljava/lang/String;)V
         7: .line 261
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            istore 5 /* disableAppResourceFiles */
        start local 5 // boolean disableAppResourceFiles
         8: .line 263
            iload 5 /* disableAppResourceFiles */
            ifeq 12
         9: .line 264
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 11
        10: .line 265
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore disabling app resource files"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 267
      StackMap locals: java.lang.String java.util.Hashtable int
      StackMap stack:
            aload 4 /* env */
            ldc "com.sun.naming.disable.app.resource.files"
            ldc "true"
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        12: .line 271
      StackMap locals:
      StackMap stack:
            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;
        13: .line 276
            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 6 /* currentEnv */
        start local 6 // java.util.Hashtable currentEnv
        14: .line 277
            aload 6 /* currentEnv */
            ldc "java.naming.referral"
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnonnull 26
        15: .line 278
            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 6 // java.util.Hashtable currentEnv
        16: .line 280
            goto 26
      StackMap locals:
      StackMap stack: javax.naming.NamingException
        17: astore 6 /* e */
        start local 6 // javax.naming.NamingException e
        18: .line 281
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 21
        19: .line 282
            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
        20: .line 284
            aload 6 /* e */
            invokevirtual javax.naming.NamingException.printStackTrace:()V
        21: .line 286
      StackMap locals: javax.naming.NamingException
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        22: .line 287
            ldc "unable to create InitialDirContext using supplied parameters"
        23: .line 286
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            astore 7 /* ee */
        start local 7 // java.lang.Exception ee
        24: .line 288
            aload 7 /* ee */
            aload 6 /* e */
            invokevirtual java.lang.Exception.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        25: .line 289
            aload 7 /* ee */
            checkcast java.security.InvalidAlgorithmParameterException
            athrow
        end local 7 // java.lang.Exception ee
        end local 6 // javax.naming.NamingException e
        26: .line 291
      StackMap locals:
      StackMap stack:
            return
        end local 5 // boolean disableAppResourceFiles
        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   27     0                     this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   27     1                   server  Ljava/lang/String;
            0   27     2                     port  I
            1   27     3                      url  Ljava/lang/String;
            2   27     4                      env  Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;
            8   27     5  disableAppResourceFiles  Z
           14   16     6               currentEnv  Ljava/util/Hashtable<**>;
           18   26     6                        e  Ljavax/naming/NamingException;
           24   26     7                       ee  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          12    16      17  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 502
            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 503
            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 504
            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 507
      StackMap locals: byte[][]
      StackMap stack:
            aload 4 /* encodedCert */
            arraylength
            istore 5 /* n */
        start local 5 // int n
         5: .line 508
            iload 5 /* n */
            ifne 7
         6: .line 509
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 512
      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 514
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         9: goto 23
        10: .line 515
      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 517
            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 518
            aload 3 /* sel */
            aload 9 /* cert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 22
        13: .line 519
            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 521
            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 522
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 22
        17: .line 523
            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 525
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 9 /* encoder */
        start local 9 // sun.misc.HexDumpEncoder encoder
        19: .line 526
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        20: .line 527
            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 526
            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 514
      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 532
            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 550
            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 551
            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 552
            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 555
      StackMap locals: byte[][]
      StackMap stack:
            aload 3 /* encodedCertPair */
            arraylength
            istore 4 /* n */
        start local 4 // int n
         5: .line 556
            iload 4 /* n */
            ifne 7
         6: .line 557
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 560
      StackMap locals: int
      StackMap stack:
            new java.util.ArrayList
            dup
            iload 4 /* n */
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 5 /* certPairs */
        start local 5 // java.util.List certPairs
         8: .line 562
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         9: goto 24
        10: .line 565
      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;
        11: .line 564
            astore 7 /* certPair */
        start local 7 // sun.security.provider.certpath.X509CertificatePair certPair
        12: .line 566
            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
        13: .line 567
            goto 23
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
        14: pop
        15: .line 568
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 23
        16: .line 569
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        17: .line 570
            ldc "LDAPCertStore.getCertPairs() encountered exception while parsing cert, skipping the bad data: "
        18: .line 569
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        19: .line 572
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 7 /* encoder */
        start local 7 // sun.misc.HexDumpEncoder encoder
        20: .line 573
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        21: .line 574
            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;
        22: .line 573
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // sun.misc.HexDumpEncoder encoder
        23: .line 562
      StackMap locals:
      StackMap stack:
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        24: iload 6 /* i */
            iload 4 /* n */
            if_icmplt 10
        end local 6 // int i
        25: .line 579
            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   26     0             this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   26     1          request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0   26     2               id  Ljava/lang/String;
            1    2     3  encodedCertPair  [[B
            4   26     3  encodedCertPair  [[B
            3    4     4         namingEx  Ljavax/naming/NamingException;
            5   26     4                n  I
            8   26     5        certPairs  Ljava/util/List<Lsun/security/provider/certpath/X509CertificatePair;>;
            9   25     6                i  I
           12   13     7         certPair  Lsun/security/provider/certpath/X509CertificatePair;
           20   23     7          encoder  Lsun/misc/HexDumpEncoder;
      Exception table:
        from    to  target  type
           0     1       2  Class javax.naming.NamingException
          10    13      14  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 604
            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 603
            astore 4 /* certPairs */
        start local 4 // java.util.Collection certPairs
         2: .line 607
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 5 /* matchingCerts */
        start local 5 // java.util.ArrayList matchingCerts
         3: .line 608
            aload 4 /* certPairs */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 13
      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:
         4: 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
         5: .line 610
            aload 2 /* forward */
            ifnull 9
         6: .line 611
            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
         7: .line 612
            aload 8 /* cert */
            ifnull 9
            aload 2 /* forward */
            aload 8 /* cert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 9
         8: .line 613
            aload 5 /* matchingCerts */
            aload 8 /* cert */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // java.security.cert.X509Certificate cert
         9: .line 616
      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 13
        10: .line 617
            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
        11: .line 618
            aload 8 /* cert */
            ifnull 13
            aload 3 /* reverse */
            aload 8 /* cert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 13
        12: .line 619
            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
        13: .line 608
      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 4
        14: .line 623
            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   15     0           this  Lsun/security/provider/certpath/ldap/LDAPCertStore;
            0   15     1        request  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0   15     2        forward  Ljava/security/cert/X509CertSelector;
            0   15     3        reverse  Ljava/security/cert/X509CertSelector;
            2   15     4      certPairs  Ljava/util/Collection<Lsun/security/provider/certpath/X509CertificatePair;>;
            3   15     5  matchingCerts  Ljava/util/ArrayList<Ljava/security/cert/X509Certificate;>;
            5   13     6       certPair  Lsun/security/provider/certpath/X509CertificatePair;
            7    9     8           cert  Ljava/security/cert/X509Certificate;
           11   13     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 649
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 650
            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 651
            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 650
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 654
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            ifnonnull 6
         5: .line 655
            new java.security.cert.X509CertSelector
            dup
            invokespecial java.security.cert.X509CertSelector.<init>:()V
            astore 1 /* selector */
         6: .line 657
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            instanceof java.security.cert.X509CertSelector
            ifne 8
         7: .line 658
            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 661
      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 662
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getBasicConstraints:()I
            istore 3 /* basicConstraints */
        start local 3 // int basicConstraints
        10: .line 663
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getSubjectAsString:()Ljava/lang/String;
            astore 4 /* subject */
        start local 4 // java.lang.String subject
        11: .line 664
            aload 2 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getIssuerAsString:()Ljava/lang/String;
            astore 5 /* issuer */
        start local 5 // java.lang.String issuer
        12: .line 665
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 6 /* certs */
        start local 6 // java.util.HashSet certs
        13: .line 666
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 17
        14: .line 667
            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 668
            iload 3 /* basicConstraints */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 667
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        17: .line 676
      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 677
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 20
        19: .line 678
            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 681
      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 682
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 27
        22: .line 683
            aload 7 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        23: .line 684
            aload 7 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        24: .line 685
            aload 7 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        25: .line 686
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
            ifeq 27
        26: .line 687
            aload 7 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        27: .line 690
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
      StackMap stack:
            iload 3 /* basicConstraints */
            ifge 29
        28: .line 691
            aload 7 /* request */
            ldc "userCertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        29: .line 694
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 40
        30: .line 695
            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 696
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 35
        32: .line 697
            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 699
            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 697
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        35: .line 701
      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 702
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 40
        37: .line 703
            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 705
            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 703
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        40: .line 708
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            ifge 55
        41: .line 709
            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 710
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 55
        43: .line 711
            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 713
            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 711
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        46: .line 716
            goto 55
        47: .line 717
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 51
        48: .line 718
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
        49: .line 719
            ldc "LDAPCertStore.engineGetCertificates() subject is null"
        50: .line 718
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        51: .line 721
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            bipush -2
            if_icmpne 53
        52: .line 722
            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 724
      StackMap locals:
      StackMap stack:
            aload 5 /* issuer */
            ifnonnull 55
        54: .line 725
            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 728
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 57
        56: .line 729
            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 732
      StackMap locals:
      StackMap stack:
            aload 5 /* issuer */
            ifnull 74
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 74
        58: .line 733
            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 734
            aload 7 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        60: .line 735
            aload 7 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        61: .line 736
            aload 7 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        62: .line 737
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
            ifeq 64
        63: .line 738
            aload 7 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        64: .line 741
      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 742
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 69
        66: .line 743
            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 745
            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 743
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        69: .line 747
      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 748
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 74
        71: .line 749
            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 751
            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 749
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest request
        74: .line 754
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 76
        75: .line 755
            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 757
      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 777
            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 778
            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 779
            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 782
      StackMap locals: byte[][]
      StackMap stack:
            aload 4 /* encodedCRL */
            arraylength
            istore 5 /* n */
        start local 5 // int n
         5: .line 783
            iload 5 /* n */
            ifne 7
         6: .line 784
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 787
      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 789
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         9: goto 20
        10: .line 791
      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 792
            aload 3 /* sel */
            aload 8 /* crl */
            invokevirtual java.security.cert.X509CRLSelector.match:(Ljava/security/cert/CRL;)Z
            ifeq 19
        12: .line 793
            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 795
            goto 19
      StackMap locals:
      StackMap stack: java.security.cert.CRLException
        14: pop
        15: .line 796
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 19
        16: .line 797
            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 799
            new sun.misc.HexDumpEncoder
            dup
            invokespecial sun.misc.HexDumpEncoder.<init>:()V
            astore 8 /* encoder */
        start local 8 // sun.misc.HexDumpEncoder encoder
        18: .line 800
            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 789
      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 805
            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 831
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 4
         1: .line 832
            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 833
            aload 1 /* selector */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 832
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 836
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            ifnonnull 6
         5: .line 837
            new java.security.cert.X509CRLSelector
            dup
            invokespecial java.security.cert.X509CRLSelector.<init>:()V
            astore 1 /* selector */
         6: .line 839
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            instanceof java.security.cert.X509CRLSelector
            ifne 8
         7: .line 840
            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 842
      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 843
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 3 /* crls */
        start local 3 // java.util.HashSet crls
        10: .line 847
            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 848
            aload 5 /* certChecking */
            ifnull 16
        12: .line 849
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 4 /* issuerNames */
        start local 4 // java.util.Collection issuerNames
        13: .line 850
            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 851
            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 852
            goto 19
        end local 4 // java.util.Collection issuerNames
        16: .line 855
      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 856
            aload 4 /* issuerNames */
            ifnonnull 19
        18: .line 857
            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 861
      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 863
            aload 6 /* nameObject */
            instanceof byte[]
            ifeq 27
        22: .line 865
            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 866
            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 867
            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 868
            goto 53
        27: .line 871
      StackMap locals:
      StackMap stack:
            aload 6 /* nameObject */
            checkcast java.lang.String
            astore 8 /* issuerName */
        start local 8 // java.lang.String issuerName
        28: .line 874
      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 875
            aload 5 /* certChecking */
            ifnull 30
            aload 5 /* certChecking */
            invokevirtual java.security.cert.X509Certificate.getBasicConstraints:()I
            iconst_m1
            if_icmpeq 48
        30: .line 876
      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 877
            aload 10 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        32: .line 878
            aload 10 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        33: .line 879
            aload 10 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        34: .line 880
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
            ifeq 36
        35: .line 881
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        36: .line 884
      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 885
            aload 9 /* entryCRLs */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 40
        38: .line 888
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.prefetchCRLs:Z
        39: .line 889
            goto 48
        40: .line 890
      StackMap locals:
      StackMap stack:
            aload 3 /* crls */
            aload 9 /* entryCRLs */
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        41: .line 892
            goto 48
      StackMap locals:
      StackMap stack: java.security.cert.CertStoreException
        42: astore 11 /* e */
        start local 11 // java.security.cert.CertStoreException e
        43: .line 893
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 48
        44: .line 894
            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 895
            aload 11 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        46: .line 894
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        47: .line 896
            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 903
      StackMap locals:
      StackMap stack:
            aload 9 /* entryCRLs */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 49
            aload 5 /* certChecking */
            ifnonnull 53
        49: .line 904
      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 905
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        51: .line 906
            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 907
            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 861
      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 910
            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 915
            aload 0 /* uri */
            invokevirtual java.net.URI.getHost:()Ljava/lang/String;
            astore 1 /* host */
        start local 1 // java.lang.String host
         1: .line 916
            aload 1 /* host */
            ifnonnull 3
         2: .line 917
            new sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters
            dup
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStore$SunLDAPCertStoreParameters.<init>:()V
            areturn
         3: .line 919
      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 920
            iload 2 /* port */
            iconst_m1
            if_icmpne 6
         5: .line 921
            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 922
      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 920
      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