public final class javax.security.auth.PrivateCredentialPermission extends java.security.Permission
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: javax.security.auth.PrivateCredentialPermission
  super_class: java.security.Permission
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 5284372143517237068

  private static final javax.security.auth.PrivateCredentialPermission$CredOwner[] EMPTY_PRINCIPALS;
    descriptor: [Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private java.lang.String credentialClass;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private java.util.Set<java.security.Principal> principals;
    descriptor: Ljava/util/Set;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Set<Ljava/security/Principal;>;

  private transient javax.security.auth.PrivateCredentialPermission$CredOwner[] credOwners;
    descriptor: [Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
    flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 108
            iconst_0
            anewarray javax.security.auth.PrivateCredentialPermission$CredOwner
            putstatic javax.security.auth.PrivateCredentialPermission.EMPTY_PRINCIPALS:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.lang.String, java.util.Set<java.security.Principal>);
    descriptor: (Ljava/lang/String;Ljava/util/Set;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=7, args_size=3
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // java.lang.String credentialClass
        start local 2 // java.util.Set principals
         0: .line 135
            aload 0 /* this */
            aload 1 /* credentialClass */
            invokespecial java.security.Permission.<init>:(Ljava/lang/String;)V
         1: .line 126
            aload 0 /* this */
            iconst_0
            putfield javax.security.auth.PrivateCredentialPermission.testing:Z
         2: .line 136
            aload 0 /* this */
            aload 1 /* credentialClass */
            putfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
         3: .line 138
            aload 2 /* principals */
            dup
            astore 3
            monitorenter
         4: .line 139
            aload 2 /* principals */
            invokeinterface java.util.Set.size:()I
            ifne 7
         5: .line 140
            aload 0 /* this */
            getstatic javax.security.auth.PrivateCredentialPermission.EMPTY_PRINCIPALS:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            putfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
         6: .line 141
            goto 17
         7: .line 142
      StackMap locals: javax.security.auth.PrivateCredentialPermission java.lang.String java.util.Set java.util.Set
      StackMap stack:
            aload 0 /* this */
            aload 2 /* principals */
            invokeinterface java.util.Set.size:()I
            anewarray javax.security.auth.PrivateCredentialPermission$CredOwner
            putfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
         8: .line 143
            iconst_0
            istore 4 /* index */
        start local 4 // int index
         9: .line 144
            aload 2 /* principals */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5 /* i */
        start local 5 // java.util.Iterator i
        10: .line 145
            goto 16
        11: .line 146
      StackMap locals: int java.util.Iterator
      StackMap stack:
            aload 5 /* i */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.Principal
            astore 6 /* p */
        start local 6 // java.security.Principal p
        12: .line 147
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            iload 4 /* index */
            iinc 4 /* index */ 1
            new javax.security.auth.PrivateCredentialPermission$CredOwner
            dup
        13: .line 148
            aload 6 /* p */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
        14: .line 149
            aload 6 /* p */
            invokeinterface java.security.Principal.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.PrivateCredentialPermission$CredOwner.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        15: .line 147
            aastore
        end local 6 // java.security.Principal p
        16: .line 145
      StackMap locals:
      StackMap stack:
            aload 5 /* i */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        end local 5 // java.util.Iterator i
        end local 4 // int index
        17: .line 138
      StackMap locals:
      StackMap stack:
            aload 3
            monitorexit
        18: goto 21
      StackMap locals:
      StackMap stack: java.lang.Throwable
        19: aload 3
            monitorexit
        20: athrow
        21: .line 153
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.Set principals
        end local 1 // java.lang.String credentialClass
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   22     0             this  Ljavax/security/auth/PrivateCredentialPermission;
            0   22     1  credentialClass  Ljava/lang/String;
            0   22     2       principals  Ljava/util/Set<Ljava/security/Principal;>;
            9   17     4            index  I
           10   17     5                i  Ljava/util/Iterator<Ljava/security/Principal;>;
           12   16     6                p  Ljava/security/Principal;
      Exception table:
        from    to  target  type
           4    18      19  any
          19    20      19  any
    Signature: (Ljava/lang/String;Ljava/util/Set<Ljava/security/Principal;>;)V
    MethodParameters:
                 Name  Flags
      credentialClass  
      principals       

  public void <init>(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // java.lang.String name
        start local 2 // java.lang.String actions
         0: .line 171
            aload 0 /* this */
            aload 1 /* name */
            invokespecial java.security.Permission.<init>:(Ljava/lang/String;)V
         1: .line 126
            aload 0 /* this */
            iconst_0
            putfield javax.security.auth.PrivateCredentialPermission.testing:Z
         2: .line 173
            ldc "read"
            aload 2 /* actions */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 6
         3: .line 174
            new java.lang.IllegalArgumentException
            dup
         4: .line 175
            ldc "actions.can.only.be.read."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         5: .line 174
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 176
      StackMap locals: javax.security.auth.PrivateCredentialPermission java.lang.String java.lang.String
      StackMap stack:
            aload 0 /* this */
            aload 1 /* name */
            invokevirtual javax.security.auth.PrivateCredentialPermission.init:(Ljava/lang/String;)V
         7: .line 177
            return
        end local 2 // java.lang.String actions
        end local 1 // java.lang.String name
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0     this  Ljavax/security/auth/PrivateCredentialPermission;
            0    8     1     name  Ljava/lang/String;
            0    8     2  actions  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      name     
      actions  

  public java.lang.String getCredentialClass();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.PrivateCredentialPermission this
         0: .line 189
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
            areturn
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/PrivateCredentialPermission;

  public java.lang.String[][] getPrincipals();
    descriptor: ()[[Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // javax.security.auth.PrivateCredentialPermission this
         0: .line 212
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            ifnull 1
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            arraylength
            ifne 2
         1: .line 213
      StackMap locals:
      StackMap stack:
            iconst_0
            iconst_0
            multianewarray [[Ljava/lang/String; 2
            areturn
         2: .line 216
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            arraylength
            iconst_2
            multianewarray [[Ljava/lang/String; 2
            astore 1 /* pArray */
        start local 1 // java.lang.String[][] pArray
         3: .line 217
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         4: goto 8
         5: .line 218
      StackMap locals: java.lang.String[][] int
      StackMap stack:
            aload 1 /* pArray */
            iload 2 /* i */
            aaload
            iconst_0
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            iload 2 /* i */
            aaload
            getfield javax.security.auth.PrivateCredentialPermission$CredOwner.principalClass:Ljava/lang/String;
            aastore
         6: .line 219
            aload 1 /* pArray */
            iload 2 /* i */
            aaload
            iconst_1
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            iload 2 /* i */
            aaload
            getfield javax.security.auth.PrivateCredentialPermission$CredOwner.principalName:Ljava/lang/String;
            aastore
         7: .line 217
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 2 /* i */
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            arraylength
            if_icmplt 5
        end local 2 // int i
         9: .line 221
            aload 1 /* pArray */
            areturn
        end local 1 // java.lang.String[][] pArray
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Ljavax/security/auth/PrivateCredentialPermission;
            3   10     1  pArray  [[Ljava/lang/String;
            4    9     2       i  I

  public boolean implies(java.security.Permission);
    descriptor: (Ljava/security/Permission;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // java.security.Permission p
         0: .line 251
            aload 1 /* p */
            ifnull 1
            aload 1 /* p */
            instanceof javax.security.auth.PrivateCredentialPermission
            ifne 2
         1: .line 252
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         2: .line 254
      StackMap locals:
      StackMap stack:
            aload 1 /* p */
            checkcast javax.security.auth.PrivateCredentialPermission
            astore 2 /* that */
        start local 2 // javax.security.auth.PrivateCredentialPermission that
         3: .line 256
            aload 0 /* this */
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
            aload 2 /* that */
            getfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
            invokevirtual javax.security.auth.PrivateCredentialPermission.impliesCredentialClass:(Ljava/lang/String;Ljava/lang/String;)Z
            ifne 5
         4: .line 257
            iconst_0
            ireturn
         5: .line 259
      StackMap locals: javax.security.auth.PrivateCredentialPermission
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            aload 2 /* that */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            invokevirtual javax.security.auth.PrivateCredentialPermission.impliesPrincipalSet:([Ljavax/security/auth/PrivateCredentialPermission$CredOwner;[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;)Z
            ireturn
        end local 2 // javax.security.auth.PrivateCredentialPermission that
        end local 1 // java.security.Permission p
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljavax/security/auth/PrivateCredentialPermission;
            0    6     1     p  Ljava/security/Permission;
            3    6     2  that  Ljavax/security/auth/PrivateCredentialPermission;
    MethodParameters:
      Name  Flags
      p     

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // java.lang.Object obj
         0: .line 280
            aload 1 /* obj */
            aload 0 /* this */
            if_acmpne 2
         1: .line 281
            iconst_1
            ireturn
         2: .line 283
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            instanceof javax.security.auth.PrivateCredentialPermission
            ifne 4
         3: .line 284
            iconst_0
            ireturn
         4: .line 286
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            checkcast javax.security.auth.PrivateCredentialPermission
            astore 2 /* that */
        start local 2 // javax.security.auth.PrivateCredentialPermission that
         5: .line 288
            aload 0 /* this */
            aload 2 /* that */
            invokevirtual javax.security.auth.PrivateCredentialPermission.implies:(Ljava/security/Permission;)Z
            ifeq 6
            aload 2 /* that */
            aload 0 /* this */
            invokevirtual javax.security.auth.PrivateCredentialPermission.implies:(Ljava/security/Permission;)Z
            ifeq 6
            iconst_1
            ireturn
      StackMap locals: javax.security.auth.PrivateCredentialPermission
      StackMap stack:
         6: iconst_0
            ireturn
        end local 2 // javax.security.auth.PrivateCredentialPermission that
        end local 1 // java.lang.Object obj
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Ljavax/security/auth/PrivateCredentialPermission;
            0    7     1   obj  Ljava/lang/Object;
            5    7     2  that  Ljavax/security/auth/PrivateCredentialPermission;
    MethodParameters:
      Name  Flags
      obj   

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.PrivateCredentialPermission this
         0: .line 297
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
            invokevirtual java.lang.String.hashCode:()I
            ireturn
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/PrivateCredentialPermission;

  public java.lang.String getActions();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.PrivateCredentialPermission this
         0: .line 309
            ldc "read"
            areturn
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/PrivateCredentialPermission;

  public java.security.PermissionCollection newPermissionCollection();
    descriptor: ()Ljava/security/PermissionCollection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.PrivateCredentialPermission this
         0: .line 323
            aconst_null
            areturn
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/PrivateCredentialPermission;

  private void init(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=8, args_size=2
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // java.lang.String name
         0: .line 328
            aload 1 /* name */
            ifnull 1
            aload 1 /* name */
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            ifne 2
         1: .line 329
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            ldc "invalid empty name"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 332
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* pList */
        start local 2 // java.util.ArrayList pList
         3: .line 333
            new java.util.StringTokenizer
            dup
            aload 1 /* name */
            ldc " "
            iconst_1
            invokespecial java.util.StringTokenizer.<init>:(Ljava/lang/String;Ljava/lang/String;Z)V
            astore 3 /* tokenizer */
        start local 3 // java.util.StringTokenizer tokenizer
         4: .line 334
            aconst_null
            astore 4 /* principalClass */
        start local 4 // java.lang.String principalClass
         5: .line 335
            aconst_null
            astore 5 /* principalName */
        start local 5 // java.lang.String principalName
         6: .line 337
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.testing:Z
            ifeq 8
         7: .line 338
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "whole 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;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 341
      StackMap locals: javax.security.auth.PrivateCredentialPermission java.lang.String java.util.ArrayList java.util.StringTokenizer java.lang.String java.lang.String
      StackMap stack:
            aload 0 /* this */
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            putfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
         9: .line 342
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.testing:Z
            ifeq 11
        10: .line 343
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Credential Class = "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        11: .line 345
      StackMap locals:
      StackMap stack:
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 77
        12: .line 346
            new java.text.MessageFormat
            dup
        13: .line 347
            ldc "permission.name.name.syntax.invalid."
        14: .line 346
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;)V
            astore 6 /* form */
        start local 6 // java.text.MessageFormat form
        15: .line 348
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* name */
            aastore
            astore 7 /* source */
        start local 7 // java.lang.Object[] source
        16: .line 349
            new java.lang.IllegalArgumentException
            dup
        17: .line 350
            new java.lang.StringBuilder
            dup
            aload 6 /* form */
            aload 7 /* source */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        18: .line 351
            ldc "Credential.Class.not.followed.by.a.Principal.Class.and.Name"
        19: .line 350
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 349
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // java.lang.Object[] source
        end local 6 // java.text.MessageFormat form
        21: .line 357
      StackMap locals:
      StackMap stack:
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            pop
        22: .line 360
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            astore 4 /* principalClass */
        23: .line 361
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.testing:Z
            ifeq 25
        24: .line 362
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "    Principal Class = "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* principalClass */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        25: .line 364
      StackMap locals:
      StackMap stack:
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 35
        26: .line 365
            new java.text.MessageFormat
            dup
        27: .line 366
            ldc "permission.name.name.syntax.invalid."
        28: .line 365
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;)V
            astore 6 /* form */
        start local 6 // java.text.MessageFormat form
        29: .line 367
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* name */
            aastore
            astore 7 /* source */
        start local 7 // java.lang.Object[] source
        30: .line 368
            new java.lang.IllegalArgumentException
            dup
        31: .line 369
            new java.lang.StringBuilder
            dup
            aload 6 /* form */
            aload 7 /* source */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        32: .line 370
            ldc "Principal.Class.not.followed.by.a.Principal.Name"
        33: .line 369
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 368
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // java.lang.Object[] source
        end local 6 // java.text.MessageFormat form
        35: .line 374
      StackMap locals:
      StackMap stack:
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            pop
        36: .line 377
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            astore 5 /* principalName */
        37: .line 379
            aload 5 /* principalName */
            ldc "\""
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 47
        38: .line 380
            new java.text.MessageFormat
            dup
        39: .line 381
            ldc "permission.name.name.syntax.invalid."
        40: .line 380
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;)V
            astore 6 /* form */
        start local 6 // java.text.MessageFormat form
        41: .line 382
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* name */
            aastore
            astore 7 /* source */
        start local 7 // java.lang.Object[] source
        42: .line 383
            new java.lang.IllegalArgumentException
            dup
        43: .line 384
            new java.lang.StringBuilder
            dup
            aload 6 /* form */
            aload 7 /* source */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        44: .line 385
            ldc "Principal.Name.must.be.surrounded.by.quotes"
        45: .line 384
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        46: .line 383
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // java.lang.Object[] source
        end local 6 // java.text.MessageFormat form
        47: .line 388
      StackMap locals:
      StackMap stack:
            aload 5 /* principalName */
            ldc "\""
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifne 64
        48: .line 394
            goto 52
        49: .line 395
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 5 /* principalName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 5 /* principalName */
        50: .line 396
            aload 5 /* principalName */
            ldc "\""
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 52
        51: .line 397
            goto 53
        52: .line 394
      StackMap locals:
      StackMap stack:
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 49
        53: .line 400
      StackMap locals:
      StackMap stack:
            aload 5 /* principalName */
            ldc "\""
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifne 64
        54: .line 401
            new java.text.MessageFormat
            dup
        55: .line 403
            ldc "permission.name.name.syntax.invalid."
        56: .line 402
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
        57: .line 401
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;)V
            astore 6 /* form */
        start local 6 // java.text.MessageFormat form
        58: .line 404
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* name */
            aastore
            astore 7 /* source */
        start local 7 // java.lang.Object[] source
        59: .line 405
            new java.lang.IllegalArgumentException
            dup
        60: .line 406
            new java.lang.StringBuilder
            dup
            aload 6 /* form */
            aload 7 /* source */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        61: .line 407
            ldc "Principal.Name.missing.end.quote"
        62: .line 406
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        63: .line 405
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // java.lang.Object[] source
        end local 6 // java.text.MessageFormat form
        64: .line 411
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.testing:Z
            ifeq 66
        65: .line 412
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "\tprincipalName = '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* principalName */
            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 java.io.PrintStream.println:(Ljava/lang/String;)V
        66: .line 414
      StackMap locals:
      StackMap stack:
            aload 5 /* principalName */
        67: .line 415
            iconst_1
            aload 5 /* principalName */
            invokevirtual java.lang.String.length:()I
            iconst_1
            isub
        68: .line 414
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 5 /* principalName */
        69: .line 417
            aload 4 /* principalClass */
            ldc "*"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 74
        70: .line 418
            aload 5 /* principalName */
            ldc "*"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 74
        71: .line 419
            new java.lang.IllegalArgumentException
            dup
        72: .line 420
            ldc "PrivateCredentialPermission.Principal.Class.can.not.be.a.wildcard.value.if.Principal.Name.is.not.a.wildcard.value"
        73: .line 419
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        74: .line 423
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.testing:Z
            ifeq 76
        75: .line 424
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "\tprincipalName = '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* principalName */
            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 java.io.PrintStream.println:(Ljava/lang/String;)V
        76: .line 426
      StackMap locals:
      StackMap stack:
            aload 2 /* pList */
            new javax.security.auth.PrivateCredentialPermission$CredOwner
            dup
            aload 4 /* principalClass */
            aload 5 /* principalName */
            invokespecial javax.security.auth.PrivateCredentialPermission$CredOwner.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        77: .line 354
      StackMap locals:
      StackMap stack:
            aload 3 /* tokenizer */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 21
        78: .line 429
            aload 0 /* this */
            aload 2 /* pList */
            invokevirtual java.util.ArrayList.size:()I
            anewarray javax.security.auth.PrivateCredentialPermission$CredOwner
            putfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
        79: .line 430
            aload 2 /* pList */
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            pop
        80: .line 431
            return
        end local 5 // java.lang.String principalName
        end local 4 // java.lang.String principalClass
        end local 3 // java.util.StringTokenizer tokenizer
        end local 2 // java.util.ArrayList pList
        end local 1 // java.lang.String name
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   81     0            this  Ljavax/security/auth/PrivateCredentialPermission;
            0   81     1            name  Ljava/lang/String;
            3   81     2           pList  Ljava/util/ArrayList<Ljavax/security/auth/PrivateCredentialPermission$CredOwner;>;
            4   81     3       tokenizer  Ljava/util/StringTokenizer;
            5   81     4  principalClass  Ljava/lang/String;
            6   81     5   principalName  Ljava/lang/String;
           15   21     6            form  Ljava/text/MessageFormat;
           16   21     7          source  [Ljava/lang/Object;
           29   35     6            form  Ljava/text/MessageFormat;
           30   35     7          source  [Ljava/lang/Object;
           41   47     6            form  Ljava/text/MessageFormat;
           42   47     7          source  [Ljava/lang/Object;
           58   64     6            form  Ljava/text/MessageFormat;
           59   64     7          source  [Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      name  

  private boolean impliesCredentialClass(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // java.lang.String thisC
        start local 2 // java.lang.String thatC
         0: .line 436
            aload 1 /* thisC */
            ifnull 1
            aload 2 /* thatC */
            ifnonnull 2
         1: .line 437
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         2: .line 439
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.PrivateCredentialPermission.testing:Z
            ifeq 6
         3: .line 440
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "credential class comparison: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         4: .line 441
            aload 1 /* thisC */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "/"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* thatC */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 440
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 443
      StackMap locals:
      StackMap stack:
            aload 1 /* thisC */
            ldc "*"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 8
         7: .line 444
            iconst_1
            ireturn
         8: .line 457
      StackMap locals:
      StackMap stack:
            aload 1 /* thisC */
            aload 2 /* thatC */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ireturn
        end local 2 // java.lang.String thatC
        end local 1 // java.lang.String thisC
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    9     0   this  Ljavax/security/auth/PrivateCredentialPermission;
            0    9     1  thisC  Ljava/lang/String;
            0    9     2  thatC  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      thisC  
      thatC  

  private boolean impliesPrincipalSet(javax.security.auth.PrivateCredentialPermission$CredOwner[], javax.security.auth.PrivateCredentialPermission$CredOwner[]);
    descriptor: ([Ljavax/security/auth/PrivateCredentialPermission$CredOwner;[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // javax.security.auth.PrivateCredentialPermission$CredOwner[] thisP
        start local 2 // javax.security.auth.PrivateCredentialPermission$CredOwner[] thatP
         0: .line 463
            aload 1 /* thisP */
            ifnull 1
            aload 2 /* thatP */
            ifnonnull 2
         1: .line 464
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         2: .line 466
      StackMap locals:
      StackMap stack:
            aload 2 /* thatP */
            arraylength
            ifne 4
         3: .line 467
            iconst_1
            ireturn
         4: .line 469
      StackMap locals:
      StackMap stack:
            aload 1 /* thisP */
            arraylength
            ifne 6
         5: .line 470
            iconst_0
            ireturn
         6: .line 472
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         7: goto 19
         8: .line 473
      StackMap locals: int
      StackMap stack:
            iconst_0
            istore 4 /* foundMatch */
        start local 4 // boolean foundMatch
         9: .line 474
            iconst_0
            istore 5 /* j */
        start local 5 // int j
        10: goto 15
        11: .line 475
      StackMap locals: int int
      StackMap stack:
            aload 1 /* thisP */
            iload 3 /* i */
            aaload
            aload 2 /* thatP */
            iload 5 /* j */
            aaload
            invokevirtual javax.security.auth.PrivateCredentialPermission$CredOwner.implies:(Ljava/lang/Object;)Z
            ifeq 14
        12: .line 476
            iconst_1
            istore 4 /* foundMatch */
        13: .line 477
            goto 16
        14: .line 474
      StackMap locals:
      StackMap stack:
            iinc 5 /* j */ 1
      StackMap locals:
      StackMap stack:
        15: iload 5 /* j */
            aload 2 /* thatP */
            arraylength
            if_icmplt 11
        end local 5 // int j
        16: .line 480
      StackMap locals:
      StackMap stack:
            iload 4 /* foundMatch */
            ifne 18
        17: .line 481
            iconst_0
            ireturn
        end local 4 // boolean foundMatch
        18: .line 472
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        19: iload 3 /* i */
            aload 1 /* thisP */
            arraylength
            if_icmplt 8
        end local 3 // int i
        20: .line 484
            iconst_1
            ireturn
        end local 2 // javax.security.auth.PrivateCredentialPermission$CredOwner[] thatP
        end local 1 // javax.security.auth.PrivateCredentialPermission$CredOwner[] thisP
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   21     0        this  Ljavax/security/auth/PrivateCredentialPermission;
            0   21     1       thisP  [Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            0   21     2       thatP  [Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            7   20     3           i  I
            9   18     4  foundMatch  Z
           10   16     5           j  I
    MethodParameters:
       Name  Flags
      thisP  
      thatP  

  private void readObject(java.io.ObjectInputStream);
    descriptor: (Ljava/io/ObjectInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // javax.security.auth.PrivateCredentialPermission this
        start local 1 // java.io.ObjectInputStream s
         0: .line 494
            aload 1 /* s */
            invokevirtual java.io.ObjectInputStream.defaultReadObject:()V
         1: .line 498
            aload 0 /* this */
            invokevirtual javax.security.auth.PrivateCredentialPermission.getName:()Ljava/lang/String;
            ldc " "
            invokevirtual java.lang.String.indexOf:(Ljava/lang/String;)I
            iconst_m1
            if_icmpne 5
            aload 0 /* this */
            invokevirtual javax.security.auth.PrivateCredentialPermission.getName:()Ljava/lang/String;
            ldc "\""
            invokevirtual java.lang.String.indexOf:(Ljava/lang/String;)I
            iconst_m1
            if_icmpne 5
         2: .line 501
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual javax.security.auth.PrivateCredentialPermission.getName:()Ljava/lang/String;
            putfield javax.security.auth.PrivateCredentialPermission.credentialClass:Ljava/lang/String;
         3: .line 502
            aload 0 /* this */
            getstatic javax.security.auth.PrivateCredentialPermission.EMPTY_PRINCIPALS:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
            putfield javax.security.auth.PrivateCredentialPermission.credOwners:[Ljavax/security/auth/PrivateCredentialPermission$CredOwner;
         4: .line 504
            goto 6
         5: .line 507
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual javax.security.auth.PrivateCredentialPermission.getName:()Ljava/lang/String;
            invokevirtual javax.security.auth.PrivateCredentialPermission.init:(Ljava/lang/String;)V
         6: .line 509
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.ObjectInputStream s
        end local 0 // javax.security.auth.PrivateCredentialPermission this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Ljavax/security/auth/PrivateCredentialPermission;
            0    7     1     s  Ljava/io/ObjectInputStream;
    Exceptions:
      throws java.io.IOException, java.lang.ClassNotFoundException
    MethodParameters:
      Name  Flags
      s     
}
SourceFile: "PrivateCredentialPermission.java"
NestMembers:
  javax.security.auth.PrivateCredentialPermission$CredOwner
InnerClasses:
  CredOwner = javax.security.auth.PrivateCredentialPermission$CredOwner of javax.security.auth.PrivateCredentialPermission