class sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest
  super_class: java.lang.Object
{
  private final java.lang.String name;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private java.util.Map<java.lang.String, byte[][]> valueMap;
    descriptor: Ljava/util/Map;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Map<Ljava/lang/String;[[B>;

  private final java.util.List<java.lang.String> requestedAttributes;
    descriptor: Ljava/util/List;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/List<Ljava/lang/String;>;

  final sun.security.provider.certpath.ldap.LDAPCertStore this$0;
    descriptor: Lsun/security/provider/certpath/ldap/LDAPCertStore;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(sun.security.provider.certpath.ldap.LDAPCertStore, java.lang.String);
    descriptor: (Lsun/security/provider/certpath/ldap/LDAPCertStore;Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
        start local 2 // java.lang.String name
         0: .line 314
            aload 0 /* this */
            aload 1
            putfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.this$0:Lsun/security/provider/certpath/ldap/LDAPCertStore;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 315
            aload 0 /* this */
            aload 0 /* this */
            aload 2 /* name */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.checkName:(Ljava/lang/String;)Ljava/lang/String;
            putfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.name:Ljava/lang/String;
         2: .line 316
            aload 0 /* this */
            new java.util.ArrayList
            dup
            iconst_5
            invokespecial java.util.ArrayList.<init>:(I)V
            putfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.requestedAttributes:Ljava/util/List;
         3: .line 317
            return
        end local 2 // java.lang.String name
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0    4     2  name  Ljava/lang/String;
    Exceptions:
      throws java.security.cert.CertStoreException
    MethodParameters:
        Name  Flags
      this$0  final
      name    

  private java.lang.String checkName(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
        start local 1 // java.lang.String name
         0: .line 320
            aload 1 /* name */
            ifnonnull 2
         1: .line 321
            new java.security.cert.CertStoreException
            dup
            ldc "Name absent"
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 324
      StackMap locals:
      StackMap stack:
            new javax.naming.CompositeName
            dup
            aload 1 /* name */
            invokespecial javax.naming.CompositeName.<init>:(Ljava/lang/String;)V
            invokevirtual javax.naming.CompositeName.size:()I
            iconst_1
            if_icmple 6
         3: .line 325
            new java.security.cert.CertStoreException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 327
      StackMap locals:
      StackMap stack: javax.naming.InvalidNameException
            astore 2 /* ine */
        start local 2 // javax.naming.InvalidNameException ine
         5: .line 328
            new java.security.cert.CertStoreException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* ine */
            invokespecial java.security.cert.CertStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // javax.naming.InvalidNameException ine
         6: .line 330
      StackMap locals:
      StackMap stack:
            aload 1 /* name */
            areturn
        end local 1 // java.lang.String name
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0    7     1  name  Ljava/lang/String;
            5    6     2   ine  Ljavax/naming/InvalidNameException;
      Exception table:
        from    to  target  type
           2     4       4  Class javax.naming.InvalidNameException
    Exceptions:
      throws java.security.cert.CertStoreException
    MethodParameters:
      Name  Flags
      name  

  java.lang.String getName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
         0: .line 334
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.name:Ljava/lang/String;
            areturn
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;

  void addRequestedAttribute(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
        start local 1 // java.lang.String attrId
         0: .line 338
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.valueMap:Ljava/util/Map;
            ifnull 2
         1: .line 339
            new java.lang.IllegalStateException
            dup
            ldc "Request already sent"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 341
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.requestedAttributes:Ljava/util/List;
            aload 1 /* attrId */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         3: .line 342
            return
        end local 1 // java.lang.String attrId
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0    4     1  attrId  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      attrId  

  byte[][] getValues(java.lang.String);
    descriptor: (Ljava/lang/String;)[[B
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
        start local 1 // java.lang.String attrId
         0: .line 356
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.name:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "|"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* attrId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 2 /* cacheKey */
        start local 2 // java.lang.String cacheKey
         1: .line 357
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.this$0:Lsun/security/provider/certpath/ldap/LDAPCertStore;
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.valueCache:Lsun/security/util/Cache;
            aload 2 /* cacheKey */
            invokevirtual sun.security.util.Cache.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast byte[][]
            astore 3 /* values */
        start local 3 // byte[][] values
         2: .line 358
            aload 3 /* values */
            ifnull 5
         3: .line 359
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.this$0:Lsun/security/provider/certpath/ldap/LDAPCertStore;
            dup
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheHits:I
            iconst_1
            iadd
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheHits:I
         4: .line 360
            aload 3 /* values */
            areturn
         5: .line 362
      StackMap locals: java.lang.String byte[][]
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.this$0:Lsun/security/provider/certpath/ldap/LDAPCertStore;
            dup
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheMisses:I
            iconst_1
            iadd
            putfield sun.security.provider.certpath.ldap.LDAPCertStore.cacheMisses:I
         6: .line 363
            aload 0 /* this */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.getValueMap:()Ljava/util/Map;
            astore 4 /* attrs */
        start local 4 // java.util.Map attrs
         7: .line 364
            aload 4 /* attrs */
            aload 1 /* attrId */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast byte[][]
            astore 3 /* values */
         8: .line 365
            aload 3 /* values */
            areturn
        end local 4 // java.util.Map attrs
        end local 3 // byte[][] values
        end local 2 // java.lang.String cacheKey
        end local 1 // java.lang.String attrId
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0    9     1    attrId  Ljava/lang/String;
            1    9     2  cacheKey  Ljava/lang/String;
            2    9     3    values  [[B
            7    9     4     attrs  Ljava/util/Map<Ljava/lang/String;[[B>;
    Exceptions:
      throws javax.naming.NamingException
    MethodParameters:
        Name  Flags
      attrId  

  private java.util.Map<java.lang.String, byte[][]> getValueMap();
    descriptor: ()Ljava/util/Map;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=7, args_size=1
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
         0: .line 383
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.valueMap:Ljava/util/Map;
            ifnull 2
         1: .line 384
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.valueMap:Ljava/util/Map;
            areturn
         2: .line 393
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.util.HashMap
            dup
            bipush 8
            invokespecial java.util.HashMap.<init>:(I)V
            putfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.valueMap:Ljava/util/Map;
         3: .line 394
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.requestedAttributes:Ljava/util/List;
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.STRING0:[Ljava/lang/String;
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.lang.String[]
            astore 1 /* attrIds */
        start local 1 // java.lang.String[] attrIds
         4: .line 397
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.this$0:Lsun/security/provider/certpath/ldap/LDAPCertStore;
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.ctx:Ljavax/naming/directory/DirContext;
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.name:Ljava/lang/String;
            aload 1 /* attrIds */
            invokeinterface javax.naming.directory.DirContext.getAttributes:(Ljava/lang/String;[Ljava/lang/String;)Ljavax/naming/directory/Attributes;
            astore 2 /* attrs */
        start local 2 // javax.naming.directory.Attributes attrs
         5: .line 398
            goto 34
        end local 2 // javax.naming.directory.Attributes attrs
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.lang.String[]
      StackMap stack: com.sun.jndi.ldap.LdapReferralException
         6: astore 3 /* lre */
        start local 3 // com.sun.jndi.ldap.LdapReferralException lre
         7: .line 402
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.lang.String[] top com.sun.jndi.ldap.LdapReferralException
      StackMap stack:
            aload 3 /* lre */
            invokevirtual com.sun.jndi.ldap.LdapReferralException.getReferralInfo:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* newName */
        start local 4 // java.lang.String newName
         8: .line 403
            new java.net.URI
            dup
            aload 4 /* newName */
            invokespecial java.net.URI.<init>:(Ljava/lang/String;)V
            astore 5 /* newUri */
        start local 5 // java.net.URI newUri
         9: .line 404
            aload 5 /* newUri */
            invokevirtual java.net.URI.getScheme:()Ljava/lang/String;
            ldc "ldap"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 11
        10: .line 405
            new java.lang.IllegalArgumentException
            dup
            ldc "Not LDAP"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 407
      StackMap locals: java.lang.String java.net.URI
      StackMap stack:
            aload 5 /* newUri */
            invokevirtual java.net.URI.getPath:()Ljava/lang/String;
            astore 6 /* newDn */
        start local 6 // java.lang.String newDn
        12: .line 408
            aload 6 /* newDn */
            ifnull 14
            aload 6 /* newDn */
            iconst_0
            invokevirtual java.lang.String.charAt:(I)C
            bipush 47
            if_icmpne 14
        13: .line 409
            aload 6 /* newDn */
            iconst_1
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 6 /* newDn */
        14: .line 411
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            aload 6 /* newDn */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.checkName:(Ljava/lang/String;)Ljava/lang/String;
            pop
        end local 6 // java.lang.String newDn
        end local 5 // java.net.URI newUri
        end local 4 // java.lang.String newName
        15: .line 412
            goto 20
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.lang.String[] top com.sun.jndi.ldap.LdapReferralException
      StackMap stack: java.lang.Exception
        16: pop
        17: .line 413
            new javax.naming.NamingException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Cannot follow referral to "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        18: .line 414
            aload 3 /* lre */
            invokevirtual com.sun.jndi.ldap.LdapReferralException.getReferralInfo:()Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 413
            invokespecial javax.naming.NamingException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 417
      StackMap locals:
      StackMap stack:
            aload 3 /* lre */
            invokevirtual com.sun.jndi.ldap.LdapReferralException.getReferralContext:()Ljavax/naming/Context;
            checkcast javax.naming.ldap.LdapContext
        21: .line 416
            astore 4 /* refCtx */
        start local 4 // javax.naming.ldap.LdapContext refCtx
        22: .line 421
            aload 4 /* refCtx */
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.name:Ljava/lang/String;
            aload 1 /* attrIds */
            invokeinterface javax.naming.ldap.LdapContext.getAttributes:(Ljava/lang/String;[Ljava/lang/String;)Ljavax/naming/directory/Attributes;
            astore 2 /* attrs */
        start local 2 // javax.naming.directory.Attributes attrs
        23: .line 428
            aload 4 /* refCtx */
            invokeinterface javax.naming.ldap.LdapContext.close:()V
        24: .line 422
            goto 34
        end local 2 // javax.naming.directory.Attributes attrs
        25: .line 423
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.lang.String[] top com.sun.jndi.ldap.LdapReferralException javax.naming.ldap.LdapContext
      StackMap stack: com.sun.jndi.ldap.LdapReferralException
            astore 5 /* re */
        start local 5 // com.sun.jndi.ldap.LdapReferralException re
        26: .line 424
            aload 5 /* re */
            astore 3 /* lre */
        27: .line 428
            aload 4 /* refCtx */
            invokeinterface javax.naming.ldap.LdapContext.close:()V
        28: .line 425
            goto 7
        end local 5 // com.sun.jndi.ldap.LdapReferralException re
        29: .line 426
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 6
        30: .line 428
            aload 4 /* refCtx */
            invokeinterface javax.naming.ldap.LdapContext.close:()V
        31: .line 429
            aload 6
            athrow
        end local 4 // javax.naming.ldap.LdapContext refCtx
        end local 3 // com.sun.jndi.ldap.LdapReferralException lre
        32: .line 431
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.lang.String[]
      StackMap stack: javax.naming.NameNotFoundException
            pop
        33: .line 434
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.EMPTY_ATTRIBUTES:Ljavax/naming/directory/Attributes;
            astore 2 /* attrs */
        start local 2 // javax.naming.directory.Attributes attrs
        34: .line 436
      StackMap locals: javax.naming.directory.Attributes
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.requestedAttributes:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 40
      StackMap locals: sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest java.lang.String[] javax.naming.directory.Attributes top java.util.Iterator
      StackMap stack:
        35: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 3 /* attrId */
        start local 3 // java.lang.String attrId
        36: .line 437
            aload 2 /* attrs */
            aload 3 /* attrId */
            invokeinterface javax.naming.directory.Attributes.get:(Ljava/lang/String;)Ljavax/naming/directory/Attribute;
            astore 5 /* attr */
        start local 5 // javax.naming.directory.Attribute attr
        37: .line 438
            aload 0 /* this */
            aload 5 /* attr */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.getAttributeValues:(Ljavax/naming/directory/Attribute;)[[B
            astore 6 /* values */
        start local 6 // byte[][] values
        38: .line 439
            aload 0 /* this */
            aload 3 /* attrId */
            aload 6 /* values */
            invokevirtual sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.cacheAttribute:(Ljava/lang/String;[[B)V
        39: .line 440
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.valueMap:Ljava/util/Map;
            aload 3 /* attrId */
            aload 6 /* values */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 6 // byte[][] values
        end local 5 // javax.naming.directory.Attribute attr
        end local 3 // java.lang.String attrId
        40: .line 436
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 35
        41: .line 442
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.valueMap:Ljava/util/Map;
            areturn
        end local 2 // javax.naming.directory.Attributes attrs
        end local 1 // java.lang.String[] attrIds
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   42     0     this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            4   42     1  attrIds  [Ljava/lang/String;
            5    6     2    attrs  Ljavax/naming/directory/Attributes;
           23   25     2    attrs  Ljavax/naming/directory/Attributes;
           34   42     2    attrs  Ljavax/naming/directory/Attributes;
            7   32     3      lre  Lcom/sun/jndi/ldap/LdapReferralException;
            8   15     4  newName  Ljava/lang/String;
            9   15     5   newUri  Ljava/net/URI;
           12   15     6    newDn  Ljava/lang/String;
           22   32     4   refCtx  Ljavax/naming/ldap/LdapContext;
           26   29     5       re  Lcom/sun/jndi/ldap/LdapReferralException;
           36   40     3   attrId  Ljava/lang/String;
           37   40     5     attr  Ljavax/naming/directory/Attribute;
           38   40     6   values  [[B
      Exception table:
        from    to  target  type
           4     5       6  Class com.sun.jndi.ldap.LdapReferralException
           7    15      16  Class java.lang.Exception
          22    23      25  Class com.sun.jndi.ldap.LdapReferralException
          22    23      29  any
          25    27      29  any
           4     5      32  Class javax.naming.NameNotFoundException
    Exceptions:
      throws javax.naming.NamingException
    Signature: ()Ljava/util/Map<Ljava/lang/String;[[B>;

  private void cacheAttribute(java.lang.String, byte[][]);
    descriptor: (Ljava/lang/String;[[B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
        start local 1 // java.lang.String attrId
        start local 2 // byte[][] values
         0: .line 449
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.name:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "|"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* attrId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* cacheKey */
        start local 3 // java.lang.String cacheKey
         1: .line 450
            aload 0 /* this */
            getfield sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest.this$0:Lsun/security/provider/certpath/ldap/LDAPCertStore;
            getfield sun.security.provider.certpath.ldap.LDAPCertStore.valueCache:Lsun/security/util/Cache;
            aload 3 /* cacheKey */
            aload 2 /* values */
            invokevirtual sun.security.util.Cache.put:(Ljava/lang/Object;Ljava/lang/Object;)V
         2: .line 451
            return
        end local 3 // java.lang.String cacheKey
        end local 2 // byte[][] values
        end local 1 // java.lang.String attrId
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0    3     1    attrId  Ljava/lang/String;
            0    3     2    values  [[B
            1    3     3  cacheKey  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      attrId  
      values  

  private byte[][] getAttributeValues(javax.naming.directory.Attribute);
    descriptor: (Ljavax/naming/directory/Attribute;)[[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
        start local 1 // javax.naming.directory.Attribute attr
         0: .line 461
            aload 1 /* attr */
            ifnonnull 3
         1: .line 462
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.BB0:[[B
            astore 2 /* values */
        start local 2 // byte[][] values
         2: .line 463
            goto 16
        end local 2 // byte[][] values
         3: .line 464
      StackMap locals:
      StackMap stack:
            aload 1 /* attr */
            invokeinterface javax.naming.directory.Attribute.size:()I
            anewarray byte[]
            astore 2 /* values */
        start local 2 // byte[][] values
         4: .line 465
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         5: .line 466
            aload 1 /* attr */
            invokeinterface javax.naming.directory.Attribute.getAll:()Ljavax/naming/NamingEnumeration;
            astore 4 /* enum_ */
        start local 4 // javax.naming.NamingEnumeration enum_
         6: .line 467
            goto 15
         7: .line 468
      StackMap locals: byte[][] int javax.naming.NamingEnumeration
      StackMap stack:
            aload 4 /* enum_ */
            invokeinterface javax.naming.NamingEnumeration.next:()Ljava/lang/Object;
            astore 5 /* obj */
        start local 5 // java.lang.Object obj
         8: .line 469
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            ifnull 13
         9: .line 470
            aload 5 /* obj */
            instanceof java.lang.String
            ifeq 13
        10: .line 471
            getstatic sun.security.provider.certpath.ldap.LDAPCertStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "LDAPCertStore.getAttrValues() enum.next is a string!: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 472
            aload 5 /* obj */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 471
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 475
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 5 /* obj */
            checkcast byte[]
            astore 6 /* value */
        start local 6 // byte[] value
        14: .line 476
            aload 2 /* values */
            iload 3 /* i */
            iinc 3 /* i */ 1
            aload 6 /* value */
            aastore
        end local 6 // byte[] value
        end local 5 // java.lang.Object obj
        15: .line 467
      StackMap locals:
      StackMap stack:
            aload 4 /* enum_ */
            invokeinterface javax.naming.NamingEnumeration.hasMore:()Z
            ifne 7
        end local 4 // javax.naming.NamingEnumeration enum_
        end local 3 // int i
        16: .line 479
      StackMap locals:
      StackMap stack:
            aload 2 /* values */
            areturn
        end local 2 // byte[][] values
        end local 1 // javax.naming.directory.Attribute attr
        end local 0 // sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   17     0    this  Lsun/security/provider/certpath/ldap/LDAPCertStore$LDAPRequest;
            0   17     1    attr  Ljavax/naming/directory/Attribute;
            2    3     2  values  [[B
            4   17     2  values  [[B
            5   16     3       i  I
            6   16     4   enum_  Ljavax/naming/NamingEnumeration<*>;
            8   15     5     obj  Ljava/lang/Object;
           14   15     6   value  [B
    Exceptions:
      throws javax.naming.NamingException
    MethodParameters:
      Name  Flags
      attr  
}
SourceFile: "LDAPCertStore.java"
NestHost: sun.security.provider.certpath.ldap.LDAPCertStore
InnerClasses:
  private LDAPRequest = sun.security.provider.certpath.ldap.LDAPCertStore$LDAPRequest of sun.security.provider.certpath.ldap.LDAPCertStore