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

  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.ldap.LdapContext ctx;
    descriptor: Ljavax/naming/ldap/LdapContext;
    flags: (0x0002) ACC_PRIVATE

  private boolean communicationError;
    descriptor: Z
    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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 63
            ldc "certpath"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
         1: .line 78
            iconst_0
            anewarray java.lang.String
            putstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.STRING0:[Ljava/lang/String;
         2: .line 80
            iconst_0
            anewarray byte[]
            putstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.BB0:[[B
         3: .line 82
            new javax.naming.directory.BasicAttributes
            dup
            invokespecial javax.naming.directory.BasicAttributes.<init>:()V
            putstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.EMPTY_ATTRIBUTES:Ljavax/naming/directory/Attributes;
         4: .line 103
            invokedynamic run()Ljava/security/PrivilegedAction;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()Ljava/lang/Object;
                  sun/security/provider/certpath/ldap/LDAPCertStoreImpl.lambda$0()Ljava/lang/String; (6)
                  ()Ljava/lang/String;
         5: .line 102
            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 104
            aload 0 /* s */
            ifnull 9
         7: .line 105
            aload 0 /* s */
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            putstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.LIFETIME:I
         8: .line 106
            goto 10
         9: .line 107
      StackMap locals: java.lang.String
      StackMap stack:
            bipush 30
            putstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.LIFETIME:I
        end local 0 // java.lang.String s
        10: .line 109
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            6   10     0     s  Ljava/lang/String;

  void <init>(java.lang.String, int);
    descriptor: (Ljava/lang/String;I)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
        start local 1 // java.lang.String serverName
        start local 2 // int port
         0: .line 140
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 124
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.communicationError:Z
         2: .line 129
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.prefetchCRLs:Z
         3: .line 133
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.cacheHits:I
         4: .line 134
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.cacheMisses:I
         5: .line 135
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.requests:I
         6: .line 142
            aload 0 /* this */
            aload 1 /* serverName */
            iload 2 /* port */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.createInitialDirContext:(Ljava/lang/String;I)V
         7: .line 145
            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.LDAPCertStoreImpl.cf:Ljava/security/cert/CertificateFactory;
         8: .line 146
            goto 13
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl java.lang.String int
      StackMap stack: java.security.cert.CertificateException
         9: pop
        10: .line 147
            new java.security.InvalidAlgorithmParameterException
            dup
        11: .line 148
            ldc "unable to create CertificateFactory for X.509"
        12: .line 147
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 150
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.LIFETIME:I
            ifne 16
        14: .line 151
            aload 0 /* this */
            invokestatic sun.security.util.Cache.newNullCache:()Lsun/security/util/Cache;
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.valueCache:Lsun/security/util/Cache;
        15: .line 152
            goto 20
      StackMap locals:
      StackMap stack:
        16: getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.LIFETIME:I
            ifge 19
        17: .line 153
            aload 0 /* this */
            sipush 750
            invokestatic sun.security.util.Cache.newSoftMemoryCache:(I)Lsun/security/util/Cache;
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.valueCache:Lsun/security/util/Cache;
        18: .line 154
            goto 20
        19: .line 155
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            sipush 750
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.LIFETIME:I
            invokestatic sun.security.util.Cache.newSoftMemoryCache:(II)Lsun/security/util/Cache;
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.valueCache:Lsun/security/util/Cache;
        20: .line 157
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int port
        end local 1 // java.lang.String serverName
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   21     0        this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   21     1  serverName  Ljava/lang/String;
            0   21     2        port  I
      Exception table:
        from    to  target  type
           7     8       9  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
            Name  Flags
      serverName  
      port        

  private void createInitialDirContext(java.lang.String, int);
    descriptor: (Ljava/lang/String;I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
        start local 1 // java.lang.String server
        start local 2 // int port
         0: .line 168
            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 169
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            astore 4 /* env */
        start local 4 // java.util.Hashtable env
         2: .line 170
            aload 4 /* env */
            ldc "java.naming.factory.initial"
         3: .line 171
            ldc "com.sun.jndi.ldap.LdapCtxFactory"
         4: .line 170
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 172
            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 176
            invokedynamic run()Ljava/security/PrivilegedAction;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()Ljava/lang/Object;
                  sun/security/provider/certpath/ldap/LDAPCertStoreImpl.lambda$1()Ljava/lang/Boolean; (6)
                  ()Ljava/lang/Boolean;
         7: .line 175
            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 177
            iload 5 /* disableAppResourceFiles */
            ifeq 12
         9: .line 178
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 11
        10: .line 179
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore disabling app resource files"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 181
      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 185
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new javax.naming.ldap.InitialLdapContext
            dup
            aload 4 /* env */
            aconst_null
            invokespecial javax.naming.ldap.InitialLdapContext.<init>:(Ljava/util/Hashtable;[Ljavax/naming/ldap/Control;)V
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.ctx:Ljavax/naming/ldap/LdapContext;
        13: .line 189
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.ctx:Ljavax/naming/ldap/LdapContext;
            ldc "java.naming.referral"
            ldc "throw"
            invokeinterface javax.naming.ldap.LdapContext.addToEnvironment:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        14: .line 190
            goto 24
      StackMap locals:
      StackMap stack: javax.naming.NamingException
        15: astore 6 /* e */
        start local 6 // javax.naming.NamingException e
        16: .line 191
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 19
        17: .line 192
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineInit about to throw InvalidAlgorithmParameterException"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        18: .line 194
            aload 6 /* e */
            invokevirtual javax.naming.NamingException.printStackTrace:()V
        19: .line 196
      StackMap locals: javax.naming.NamingException
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        20: .line 197
            ldc "unable to create InitialDirContext using supplied parameters"
        21: .line 196
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            astore 7 /* ee */
        start local 7 // java.lang.Exception ee
        22: .line 198
            aload 7 /* ee */
            aload 6 /* e */
            invokevirtual java.lang.Exception.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        23: .line 199
            aload 7 /* ee */
            checkcast java.security.InvalidAlgorithmParameterException
            athrow
        end local 7 // java.lang.Exception ee
        end local 6 // javax.naming.NamingException e
        24: .line 201
      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.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            0   25     0                     this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   25     1                   server  Ljava/lang/String;
            0   25     2                     port  I
            1   25     3                      url  Ljava/lang/String;
            2   25     4                      env  Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;
            8   25     5  disableAppResourceFiles  Z
           16   24     6                        e  Ljavax/naming/NamingException;
           22   24     7                       ee  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          12    14      15  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.LDAPCertStoreImpl$LDAPRequest, java.lang.String, java.security.cert.X509CertSelector);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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.LDAPCertStoreImpl this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        start local 2 // java.lang.String id
        start local 3 // java.security.cert.X509CertSelector sel
         0: .line 421
            aload 1 /* request */
            aload 2 /* id */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.getValues:(Ljava/lang/String;)[[B
            astore 4 /* encodedCert */
        start local 4 // byte[][] encodedCert
         1: .line 422
            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 423
            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 426
      StackMap locals: byte[][]
      StackMap stack:
            aload 4 /* encodedCert */
            arraylength
            istore 5 /* n */
        start local 5 // int n
         5: .line 427
            iload 5 /* n */
            ifne 7
         6: .line 428
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 431
      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 433
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         9: goto 23
        10: .line 434
      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 436
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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 437
            aload 3 /* sel */
            aload 9 /* cert */
            invokevirtual java.security.cert.X509CertSelector.match:(Ljava/security/cert/Certificate;)Z
            ifeq 22
        13: .line 438
            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 440
            goto 22
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl sun.security.provider.certpath.ldap.LDAPCertStoreImpl$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 441
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 22
        17: .line 442
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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 444
            new sun.security.util.HexDumpEncoder
            dup
            invokespecial sun.security.util.HexDumpEncoder.<init>:()V
            astore 9 /* encoder */
        start local 9 // sun.security.util.HexDumpEncoder encoder
        19: .line 445
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
        20: .line 446
            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.security.util.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 445
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 9 // sun.security.util.HexDumpEncoder encoder
        end local 8 // java.io.ByteArrayInputStream bais
        22: .line 433
      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 451
            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.LDAPCertStoreImpl$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   25     0         this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   25     1      request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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/security/util/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/LDAPCertStoreImpl$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.LDAPCertStoreImpl$LDAPRequest, java.lang.String);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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.LDAPCertStoreImpl this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        start local 2 // java.lang.String id
         0: .line 469
            aload 1 /* request */
            aload 2 /* id */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.getValues:(Ljava/lang/String;)[[B
            astore 3 /* encodedCertPair */
        start local 3 // byte[][] encodedCertPair
         1: .line 470
            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 471
            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 474
      StackMap locals: byte[][]
      StackMap stack:
            aload 3 /* encodedCertPair */
            arraylength
            istore 4 /* n */
        start local 4 // int n
         5: .line 475
            iload 4 /* n */
            ifne 7
         6: .line 476
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 479
      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 481
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         9: goto 24
        10: .line 484
      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 483
            astore 7 /* certPair */
        start local 7 // sun.security.provider.certpath.X509CertificatePair certPair
        12: .line 485
            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 486
            goto 23
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
        14: pop
        15: .line 487
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 23
        16: .line 488
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
        17: .line 489
            ldc "LDAPCertStore.getCertPairs() encountered exception while parsing cert, skipping the bad data: "
        18: .line 488
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        19: .line 491
            new sun.security.util.HexDumpEncoder
            dup
            invokespecial sun.security.util.HexDumpEncoder.<init>:()V
            astore 7 /* encoder */
        start local 7 // sun.security.util.HexDumpEncoder encoder
        20: .line 492
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
        21: .line 493
            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.security.util.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 492
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // sun.security.util.HexDumpEncoder encoder
        23: .line 481
      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 498
            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.LDAPCertStoreImpl$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   26     0             this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   26     1          request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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/security/util/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/LDAPCertStoreImpl$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.LDAPCertStoreImpl$LDAPRequest, java.security.cert.X509CertSelector, java.security.cert.X509CertSelector);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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.LDAPCertStoreImpl this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        start local 2 // java.security.cert.X509CertSelector forward
        start local 3 // java.security.cert.X509CertSelector reverse
         0: .line 523
            aload 0 /* this */
            aload 1 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getCertPairs:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/lang/String;)Ljava/util/Collection;
         1: .line 522
            astore 4 /* certPairs */
        start local 4 // java.util.Collection certPairs
         2: .line 526
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 5 /* matchingCerts */
        start local 5 // java.util.ArrayList matchingCerts
         3: .line 527
            aload 4 /* certPairs */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 13
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl sun.security.provider.certpath.ldap.LDAPCertStoreImpl$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 529
            aload 2 /* forward */
            ifnull 9
         6: .line 530
            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 531
            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 532
            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 535
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl sun.security.provider.certpath.ldap.LDAPCertStoreImpl$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 536
            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 537
            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 538
            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 527
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl sun.security.provider.certpath.ldap.LDAPCertStoreImpl$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 542
            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.LDAPCertStoreImpl$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   15     0           this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   15     1        request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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/LDAPCertStoreImpl$LDAPRequest;Ljava/security/cert/X509CertSelector;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
         Name  Flags
      request  
      forward  
      reverse  

  synchronized java.util.Collection<java.security.cert.X509Certificate> getCertificates(java.security.cert.X509CertSelector, java.lang.String);
    descriptor: (Ljava/security/cert/X509CertSelector;Ljava/lang/String;)Ljava/util/Collection;
    flags: (0x0020) ACC_SYNCHRONIZED
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
        start local 1 // java.security.cert.X509CertSelector xsel
        start local 2 // java.lang.String ldapDN
         0: .line 570
            aload 2 /* ldapDN */
            ifnonnull 2
         1: .line 571
            aload 1 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getSubjectAsString:()Ljava/lang/String;
            astore 2 /* ldapDN */
         2: .line 573
      StackMap locals:
      StackMap stack:
            aload 1 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getBasicConstraints:()I
            istore 3 /* basicConstraints */
        start local 3 // int basicConstraints
         3: .line 574
            aload 1 /* xsel */
            invokevirtual java.security.cert.X509CertSelector.getIssuerAsString:()Ljava/lang/String;
            astore 4 /* issuer */
        start local 4 // java.lang.String issuer
         4: .line 575
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 5 /* certs */
        start local 5 // java.util.HashSet certs
         5: .line 576
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 9
         6: .line 577
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.engineGetCertificates() basicConstraints: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         7: .line 578
            iload 3 /* basicConstraints */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 577
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         9: .line 586
      StackMap locals: int java.lang.String java.util.HashSet
      StackMap stack:
            aload 2 /* ldapDN */
            ifnull 39
        10: .line 587
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 12
        11: .line 588
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineGetCertificates()  subject is not null"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 591
      StackMap locals:
      StackMap stack:
            new sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
            dup
            aload 0 /* this */
            aload 2 /* ldapDN */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;Ljava/lang/String;)V
            astore 6 /* request */
        start local 6 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        13: .line 592
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 19
        14: .line 593
            aload 6 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        15: .line 594
            aload 6 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        16: .line 595
            aload 6 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        17: .line 596
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.prefetchCRLs:Z
            ifeq 19
        18: .line 597
            aload 6 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        19: .line 600
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
      StackMap stack:
            iload 3 /* basicConstraints */
            ifge 21
        20: .line 601
            aload 6 /* request */
            ldc "userCertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        21: .line 604
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 32
        22: .line 605
            aload 5 /* certs */
            aload 0 /* this */
            aload 6 /* request */
            aload 1 /* xsel */
            aconst_null
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getMatchingCrossCerts:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/security/cert/X509CertSelector;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        23: .line 606
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 27
        24: .line 607
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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
        25: .line 609
            aload 5 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        26: .line 607
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        27: .line 611
      StackMap locals:
      StackMap stack:
            aload 5 /* certs */
            aload 0 /* this */
            aload 6 /* request */
            ldc "cACertificate;binary"
            aload 1 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getCertificates:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        28: .line 612
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 32
        29: .line 613
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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
        30: .line 615
            aload 5 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        31: .line 613
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        32: .line 618
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            ifge 47
        33: .line 619
            aload 5 /* certs */
            aload 0 /* this */
            aload 6 /* request */
            ldc "userCertificate;binary"
            aload 1 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getCertificates:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        34: .line 620
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 47
        35: .line 621
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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
        36: .line 623
            aload 5 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        37: .line 621
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 6 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        38: .line 626
            goto 47
        39: .line 627
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 43
        40: .line 628
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
        41: .line 629
            ldc "LDAPCertStore.engineGetCertificates() subject is null"
        42: .line 628
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        43: .line 631
      StackMap locals:
      StackMap stack:
            iload 3 /* basicConstraints */
            bipush -2
            if_icmpne 45
        44: .line 632
            new java.security.cert.CertStoreException
            dup
            ldc "need subject to find EE certs"
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
        45: .line 634
      StackMap locals:
      StackMap stack:
            aload 4 /* issuer */
            ifnonnull 47
        46: .line 635
            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
        47: .line 638
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 49
        48: .line 639
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineGetCertificates() about to getMatchingCrossCerts..."
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        49: .line 642
      StackMap locals:
      StackMap stack:
            aload 4 /* issuer */
            ifnull 66
            iload 3 /* basicConstraints */
            bipush -2
            if_icmple 66
        50: .line 643
            new sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
            dup
            aload 0 /* this */
            aload 4 /* issuer */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;Ljava/lang/String;)V
            astore 6 /* request */
        start local 6 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        51: .line 644
            aload 6 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        52: .line 645
            aload 6 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        53: .line 646
            aload 6 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        54: .line 647
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.prefetchCRLs:Z
            ifeq 56
        55: .line 648
            aload 6 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        56: .line 651
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
      StackMap stack:
            aload 5 /* certs */
            aload 0 /* this */
            aload 6 /* request */
            aconst_null
            aload 1 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getMatchingCrossCerts:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/security/cert/X509CertSelector;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        57: .line 652
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 61
        58: .line 653
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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
        59: .line 655
            aload 5 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        60: .line 653
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        61: .line 657
      StackMap locals:
      StackMap stack:
            aload 5 /* certs */
            aload 0 /* this */
            aload 6 /* request */
            ldc "cACertificate;binary"
            aload 1 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getCertificates:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CertSelector;)Ljava/util/Collection;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        62: .line 658
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 66
        63: .line 659
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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
        64: .line 661
            aload 5 /* certs */
            invokevirtual java.util.HashSet.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        65: .line 659
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 6 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        66: .line 664
      StackMap locals:
      StackMap stack:
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 68
        67: .line 665
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ldc "LDAPCertStore.engineGetCertificates() returning certs"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        68: .line 667
      StackMap locals:
      StackMap stack:
            aload 5 /* certs */
            areturn
        end local 5 // java.util.HashSet certs
        end local 4 // java.lang.String issuer
        end local 3 // int basicConstraints
        end local 2 // java.lang.String ldapDN
        end local 1 // java.security.cert.X509CertSelector xsel
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   69     0              this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   69     1              xsel  Ljava/security/cert/X509CertSelector;
            0   69     2            ldapDN  Ljava/lang/String;
            3   69     3  basicConstraints  I
            4   69     4            issuer  Ljava/lang/String;
            5   69     5             certs  Ljava/util/HashSet<Ljava/security/cert/X509Certificate;>;
           13   38     6           request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;
           51   66     6           request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Ljava/security/cert/X509CertSelector;Ljava/lang/String;)Ljava/util/Collection<Ljava/security/cert/X509Certificate;>;
    MethodParameters:
        Name  Flags
      xsel    
      ldapDN  

  private java.util.Collection<java.security.cert.X509CRL> getCRLs(sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest, java.lang.String, java.security.cert.X509CRLSelector);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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.LDAPCertStoreImpl this
        start local 1 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        start local 2 // java.lang.String id
        start local 3 // java.security.cert.X509CRLSelector sel
         0: .line 687
            aload 1 /* request */
            aload 2 /* id */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.getValues:(Ljava/lang/String;)[[B
            astore 4 /* encodedCRL */
        start local 4 // byte[][] encodedCRL
         1: .line 688
            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 689
            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 692
      StackMap locals: byte[][]
      StackMap stack:
            aload 4 /* encodedCRL */
            arraylength
            istore 5 /* n */
        start local 5 // int n
         5: .line 693
            iload 5 /* n */
            ifne 7
         6: .line 694
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         7: .line 697
      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 699
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         9: goto 20
        10: .line 701
      StackMap locals: java.util.List int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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 702
            aload 3 /* sel */
            aload 8 /* crl */
            invokevirtual java.security.cert.X509CRLSelector.match:(Ljava/security/cert/CRL;)Z
            ifeq 19
        12: .line 703
            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 705
            goto 19
      StackMap locals:
      StackMap stack: java.security.cert.CRLException
        14: pop
        15: .line 706
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 19
        16: .line 707
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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 709
            new sun.security.util.HexDumpEncoder
            dup
            invokespecial sun.security.util.HexDumpEncoder.<init>:()V
            astore 8 /* encoder */
        start local 8 // sun.security.util.HexDumpEncoder encoder
        18: .line 710
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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.security.util.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.security.util.HexDumpEncoder encoder
        19: .line 699
      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 715
            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.LDAPCertStoreImpl$LDAPRequest request
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   22     0        this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   22     1     request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$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/security/util/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/LDAPCertStoreImpl$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CRLSelector;)Ljava/util/Collection<Ljava/security/cert/X509CRL;>;
    MethodParameters:
         Name  Flags
      request  
      id       
      sel      

  synchronized java.util.Collection<java.security.cert.X509CRL> getCRLs(java.security.cert.X509CRLSelector, java.lang.String);
    descriptor: (Ljava/security/cert/X509CRLSelector;Ljava/lang/String;)Ljava/util/Collection;
    flags: (0x0020) ACC_SYNCHRONIZED
    Code:
      stack=4, locals=12, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
        start local 1 // java.security.cert.X509CRLSelector xsel
        start local 2 // java.lang.String ldapDN
         0: .line 742
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 3 /* crls */
        start local 3 // java.util.HashSet crls
         1: .line 746
            aload 1 /* xsel */
            invokevirtual java.security.cert.X509CRLSelector.getCertificateChecking:()Ljava/security/cert/X509Certificate;
            astore 5 /* certChecking */
        start local 5 // java.security.cert.X509Certificate certChecking
         2: .line 747
            aload 5 /* certChecking */
            ifnull 7
         3: .line 748
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 4 /* issuerNames */
        start local 4 // java.util.Collection issuerNames
         4: .line 749
            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
         5: .line 750
            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
         6: .line 751
            goto 14
        end local 4 // java.util.Collection issuerNames
         7: .line 754
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl java.security.cert.X509CRLSelector java.lang.String java.util.HashSet top java.security.cert.X509Certificate
      StackMap stack:
            aload 2 /* ldapDN */
            ifnull 11
         8: .line 755
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 4 /* issuerNames */
        start local 4 // java.util.Collection issuerNames
         9: .line 756
            aload 4 /* issuerNames */
            aload 2 /* ldapDN */
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        10: .line 757
            goto 14
        end local 4 // java.util.Collection issuerNames
        11: .line 758
      StackMap locals:
      StackMap stack:
            aload 1 /* xsel */
            invokevirtual java.security.cert.X509CRLSelector.getIssuerNames:()Ljava/util/Collection;
            astore 4 /* issuerNames */
        start local 4 // java.util.Collection issuerNames
        12: .line 759
            aload 4 /* issuerNames */
            ifnonnull 14
        13: .line 760
            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
        14: .line 765
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl java.security.cert.X509CRLSelector java.lang.String 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 48
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl java.security.cert.X509CRLSelector java.lang.String java.util.HashSet java.util.Collection java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
        15: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 6 /* nameObject */
        start local 6 // java.lang.Object nameObject
        16: .line 767
            aload 6 /* nameObject */
            instanceof byte[]
            ifeq 22
        17: .line 769
            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
        18: .line 770
            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
        19: .line 771
            goto 23
        end local 8 // java.lang.String issuerName
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl java.security.cert.X509CRLSelector java.lang.String java.util.HashSet java.util.Collection java.security.cert.X509Certificate java.lang.Object java.util.Iterator
      StackMap stack: java.lang.IllegalArgumentException
        20: pop
        21: .line 772
            goto 48
        22: .line 775
      StackMap locals:
      StackMap stack:
            aload 6 /* nameObject */
            checkcast java.lang.String
            astore 8 /* issuerName */
        start local 8 // java.lang.String issuerName
        23: .line 778
      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
        24: .line 779
            aload 5 /* certChecking */
            ifnull 25
            aload 5 /* certChecking */
            invokevirtual java.security.cert.X509Certificate.getBasicConstraints:()I
            iconst_m1
            if_icmpeq 43
        25: .line 780
      StackMap locals: java.util.Collection
      StackMap stack:
            new sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
            dup
            aload 0 /* this */
            aload 8 /* issuerName */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;Ljava/lang/String;)V
            astore 10 /* request */
        start local 10 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        26: .line 781
            aload 10 /* request */
            ldc "crossCertificatePair;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        27: .line 782
            aload 10 /* request */
            ldc "cACertificate;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        28: .line 783
            aload 10 /* request */
            ldc "authorityRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        29: .line 784
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.prefetchCRLs:Z
            ifeq 31
        30: .line 785
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        31: .line 788
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
      StackMap stack:
            aload 0 /* this */
            aload 10 /* request */
            ldc "authorityRevocationList;binary"
            aload 1 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getCRLs:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CRLSelector;)Ljava/util/Collection;
            astore 9 /* entryCRLs */
        32: .line 789
            aload 9 /* entryCRLs */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 35
        33: .line 792
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.certpath.ldap.LDAPCertStoreImpl.prefetchCRLs:Z
        34: .line 793
            goto 43
        35: .line 794
      StackMap locals:
      StackMap stack:
            aload 3 /* crls */
            aload 9 /* entryCRLs */
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        36: .line 796
            goto 43
      StackMap locals:
      StackMap stack: java.security.cert.CertStoreException
        37: astore 11 /* e */
        start local 11 // java.security.cert.CertStoreException e
        38: .line 797
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.debug:Lsun/security/util/Debug;
            ifnull 43
        39: .line 798
            getstatic sun.security.provider.certpath.ldap.LDAPCertStoreImpl.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
        40: .line 799
            aload 11 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        41: .line 798
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        42: .line 800
            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.LDAPCertStoreImpl$LDAPRequest request
        43: .line 807
      StackMap locals:
      StackMap stack:
            aload 9 /* entryCRLs */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 44
            aload 5 /* certChecking */
            ifnonnull 48
        44: .line 808
      StackMap locals:
      StackMap stack:
            new sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
            dup
            aload 0 /* this */
            aload 8 /* issuerName */
            invokespecial sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.<init>:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;Ljava/lang/String;)V
            astore 10 /* request */
        start local 10 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        45: .line 809
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest.addRequestedAttribute:(Ljava/lang/String;)V
        46: .line 810
            aload 0 /* this */
            aload 10 /* request */
            ldc "certificateRevocationList;binary"
            aload 1 /* xsel */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStoreImpl.getCRLs:(Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;Ljava/lang/String;Ljava/security/cert/X509CRLSelector;)Ljava/util/Collection;
            astore 9 /* entryCRLs */
        47: .line 811
            aload 3 /* crls */
            aload 9 /* entryCRLs */
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
        end local 10 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest request
        end local 9 // java.util.Collection entryCRLs
        end local 8 // java.lang.String issuerName
        end local 6 // java.lang.Object nameObject
        48: .line 765
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStoreImpl java.security.cert.X509CRLSelector java.lang.String 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 15
        49: .line 814
            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.lang.String ldapDN
        end local 1 // java.security.cert.X509CRLSelector xsel
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStoreImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   50     0          this  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl;
            0   50     1          xsel  Ljava/security/cert/X509CRLSelector;
            0   50     2        ldapDN  Ljava/lang/String;
            1   50     3          crls  Ljava/util/HashSet<Ljava/security/cert/X509CRL;>;
            4    7     4   issuerNames  Ljava/util/Collection<Ljava/lang/Object;>;
            9   11     4   issuerNames  Ljava/util/Collection<Ljava/lang/Object;>;
           12   50     4   issuerNames  Ljava/util/Collection<Ljava/lang/Object;>;
            2   50     5  certChecking  Ljava/security/cert/X509Certificate;
            5    6     6        issuer  Ljavax/security/auth/x500/X500Principal;
           16   48     6    nameObject  Ljava/lang/Object;
           19   20     8    issuerName  Ljava/lang/String;
           23   48     8    issuerName  Ljava/lang/String;
           18   19     9        issuer  Ljavax/security/auth/x500/X500Principal;
           24   48     9     entryCRLs  Ljava/util/Collection<Ljava/security/cert/X509CRL;>;
           26   43    10       request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;
           38   43    11             e  Ljava/security/cert/CertStoreException;
           45   48    10       request  Lsun/security/provider/certpath/ldap/LDAPCertStoreImpl$LDAPRequest;
      Exception table:
        from    to  target  type
          17    19      20  Class java.lang.IllegalArgumentException
          31    36      37  Class java.security.cert.CertStoreException
    Exceptions:
      throws java.security.cert.CertStoreException
    Signature: (Ljava/security/cert/X509CRLSelector;Ljava/lang/String;)Ljava/util/Collection<Ljava/security/cert/X509CRL;>;
    MethodParameters:
        Name  Flags
      xsel    
      ldapDN  

  private static java.lang.String lambda$0();
    descriptor: ()Ljava/lang/String;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 103
            ldc "sun.security.certpath.ldap.cache.lifetime"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static java.lang.Boolean lambda$1();
    descriptor: ()Ljava/lang/Boolean;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 176
            ldc "sun.security.certpath.ldap.disable.app.resource.files"
            invokestatic java.lang.Boolean.getBoolean:(Ljava/lang/String;)Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "LDAPCertStoreImpl.java"
NestMembers:
  sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  private LDAPRequest = sun.security.provider.certpath.ldap.LDAPCertStoreImpl$LDAPRequest of sun.security.provider.certpath.ldap.LDAPCertStoreImpl