public class java.security.ProtectionDomain
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: java.security.ProtectionDomain
  super_class: java.lang.Object
{
  private static final boolean filePermCompatInPD;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private java.security.CodeSource codesource;
    descriptor: Ljava/security/CodeSource;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.ClassLoader classloader;
    descriptor: Ljava/lang/ClassLoader;
    flags: (0x0002) ACC_PRIVATE

  private java.security.Principal[] principals;
    descriptor: [Ljava/security/Principal;
    flags: (0x0002) ACC_PRIVATE

  private java.security.PermissionCollection permissions;
    descriptor: Ljava/security/PermissionCollection;
    flags: (0x0002) ACC_PRIVATE

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

  private final boolean staticPermissions;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  final java.security.ProtectionDomain$Key key;
    descriptor: Ljava/security/ProtectionDomain$Key;
    flags: (0x0010) ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 68
            ldc "true"
         1: .line 69
            ldc "jdk.security.filePermCompat"
         2: .line 68
            invokestatic sun.security.action.GetPropertyAction.privilegedGetProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
         3: .line 67
            putstatic java.security.ProtectionDomain.filePermCompatInPD:Z
         4: .line 130
            new java.security.ProtectionDomain$JavaSecurityAccessImpl
            dup
            invokespecial java.security.ProtectionDomain$JavaSecurityAccessImpl.<init>:()V
            invokestatic jdk.internal.access.SharedSecrets.setJavaSecurityAccess:(Ljdk/internal/access/JavaSecurityAccess;)V
         5: .line 131
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(java.security.CodeSource, java.security.PermissionCollection);
    descriptor: (Ljava/security/CodeSource;Ljava/security/PermissionCollection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // java.security.ProtectionDomain this
        start local 1 // java.security.CodeSource codesource
        start local 2 // java.security.PermissionCollection permissions
         0: .line 171
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 146
            aload 0 /* this */
            iconst_0
            putfield java.security.ProtectionDomain.hasAllPerm:Z
         2: .line 155
            aload 0 /* this */
            new java.security.ProtectionDomain$Key
            dup
            aload 0 /* this */
            invokespecial java.security.ProtectionDomain$Key.<init>:(Ljava/security/ProtectionDomain;)V
            putfield java.security.ProtectionDomain.key:Ljava/security/ProtectionDomain$Key;
         3: .line 173
            aload 0 /* this */
            aload 1 /* codesource */
            putfield java.security.ProtectionDomain.codesource:Ljava/security/CodeSource;
         4: .line 174
            aload 2 /* permissions */
            ifnull 10
         5: .line 175
            aload 0 /* this */
            aload 2 /* permissions */
            putfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
         6: .line 176
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            invokevirtual java.security.PermissionCollection.setReadOnly:()V
         7: .line 177
            aload 2 /* permissions */
            instanceof java.security.Permissions
            ifeq 10
         8: .line 178
            aload 2 /* permissions */
            checkcast java.security.Permissions
            getfield java.security.Permissions.allPermission:Ljava/security/PermissionCollection;
            ifnull 10
         9: .line 179
            aload 0 /* this */
            iconst_1
            putfield java.security.ProtectionDomain.hasAllPerm:Z
        10: .line 182
      StackMap locals: java.security.ProtectionDomain java.security.CodeSource java.security.PermissionCollection
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield java.security.ProtectionDomain.classloader:Ljava/lang/ClassLoader;
        11: .line 183
            aload 0 /* this */
            iconst_0
            anewarray java.security.Principal
            putfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
        12: .line 184
            aload 0 /* this */
            iconst_1
            putfield java.security.ProtectionDomain.staticPermissions:Z
        13: .line 185
            return
        end local 2 // java.security.PermissionCollection permissions
        end local 1 // java.security.CodeSource codesource
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   14     0         this  Ljava/security/ProtectionDomain;
            0   14     1   codesource  Ljava/security/CodeSource;
            0   14     2  permissions  Ljava/security/PermissionCollection;
    MethodParameters:
             Name  Flags
      codesource   
      permissions  

  public void <init>(java.security.CodeSource, java.security.PermissionCollection, java.lang.ClassLoader, java.security.Principal[]);
    descriptor: (Ljava/security/CodeSource;Ljava/security/PermissionCollection;Ljava/lang/ClassLoader;[Ljava/security/Principal;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // java.security.ProtectionDomain this
        start local 1 // java.security.CodeSource codesource
        start local 2 // java.security.PermissionCollection permissions
        start local 3 // java.lang.ClassLoader classloader
        start local 4 // java.security.Principal[] principals
         0: .line 217
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 146
            aload 0 /* this */
            iconst_0
            putfield java.security.ProtectionDomain.hasAllPerm:Z
         2: .line 155
            aload 0 /* this */
            new java.security.ProtectionDomain$Key
            dup
            aload 0 /* this */
            invokespecial java.security.ProtectionDomain$Key.<init>:(Ljava/security/ProtectionDomain;)V
            putfield java.security.ProtectionDomain.key:Ljava/security/ProtectionDomain$Key;
         3: .line 221
            aload 0 /* this */
            aload 1 /* codesource */
            putfield java.security.ProtectionDomain.codesource:Ljava/security/CodeSource;
         4: .line 222
            aload 2 /* permissions */
            ifnull 10
         5: .line 223
            aload 0 /* this */
            aload 2 /* permissions */
            putfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
         6: .line 224
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            invokevirtual java.security.PermissionCollection.setReadOnly:()V
         7: .line 225
            aload 2 /* permissions */
            instanceof java.security.Permissions
            ifeq 10
         8: .line 226
            aload 2 /* permissions */
            checkcast java.security.Permissions
            getfield java.security.Permissions.allPermission:Ljava/security/PermissionCollection;
            ifnull 10
         9: .line 227
            aload 0 /* this */
            iconst_1
            putfield java.security.ProtectionDomain.hasAllPerm:Z
        10: .line 230
      StackMap locals: java.security.ProtectionDomain java.security.CodeSource java.security.PermissionCollection java.lang.ClassLoader java.security.Principal[]
      StackMap stack:
            aload 0 /* this */
            aload 3 /* classloader */
            putfield java.security.ProtectionDomain.classloader:Ljava/lang/ClassLoader;
        11: .line 231
            aload 0 /* this */
            aload 4 /* principals */
            ifnull 12
            aload 4 /* principals */
            invokevirtual java.security.Principal[].clone:()Ljava/lang/Object;
            checkcast java.security.Principal[]
            goto 13
        12: .line 232
      StackMap locals:
      StackMap stack: java.security.ProtectionDomain
            iconst_0
            anewarray java.security.Principal
        13: .line 231
      StackMap locals: java.security.ProtectionDomain java.security.CodeSource java.security.PermissionCollection java.lang.ClassLoader java.security.Principal[]
      StackMap stack: java.security.ProtectionDomain java.security.Principal[]
            putfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
        14: .line 233
            aload 0 /* this */
            iconst_0
            putfield java.security.ProtectionDomain.staticPermissions:Z
        15: .line 234
            return
        end local 4 // java.security.Principal[] principals
        end local 3 // java.lang.ClassLoader classloader
        end local 2 // java.security.PermissionCollection permissions
        end local 1 // java.security.CodeSource codesource
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   16     0         this  Ljava/security/ProtectionDomain;
            0   16     1   codesource  Ljava/security/CodeSource;
            0   16     2  permissions  Ljava/security/PermissionCollection;
            0   16     3  classloader  Ljava/lang/ClassLoader;
            0   16     4   principals  [Ljava/security/Principal;
    MethodParameters:
             Name  Flags
      codesource   
      permissions  
      classloader  
      principals   

  public final java.security.CodeSource getCodeSource();
    descriptor: ()Ljava/security/CodeSource;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.ProtectionDomain this
         0: .line 242
            aload 0 /* this */
            getfield java.security.ProtectionDomain.codesource:Ljava/security/CodeSource;
            areturn
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/ProtectionDomain;

  public final java.lang.ClassLoader getClassLoader();
    descriptor: ()Ljava/lang/ClassLoader;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.ProtectionDomain this
         0: .line 253
            aload 0 /* this */
            getfield java.security.ProtectionDomain.classloader:Ljava/lang/ClassLoader;
            areturn
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/ProtectionDomain;

  public final java.security.Principal[] getPrincipals();
    descriptor: ()[Ljava/security/Principal;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.ProtectionDomain this
         0: .line 265
            aload 0 /* this */
            getfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
            invokevirtual java.security.Principal[].clone:()Ljava/lang/Object;
            checkcast java.security.Principal[]
            areturn
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/ProtectionDomain;

  public final java.security.PermissionCollection getPermissions();
    descriptor: ()Ljava/security/PermissionCollection;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.ProtectionDomain this
         0: .line 276
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            areturn
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/ProtectionDomain;

  public final boolean staticPermissionsOnly();
    descriptor: ()Z
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.ProtectionDomain this
         0: .line 289
            aload 0 /* this */
            getfield java.security.ProtectionDomain.staticPermissions:Z
            ireturn
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/ProtectionDomain;

  public boolean implies(java.security.Permission);
    descriptor: (Ljava/security/Permission;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.security.ProtectionDomain this
        start local 1 // java.security.Permission perm
         0: .line 314
            aload 0 /* this */
            getfield java.security.ProtectionDomain.hasAllPerm:Z
            ifeq 2
         1: .line 317
            iconst_1
            ireturn
         2: .line 320
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.ProtectionDomain.staticPermissions:Z
            ifne 5
         3: .line 321
            invokestatic java.security.Policy.getPolicyNoCheck:()Ljava/security/Policy;
            aload 0 /* this */
            aload 1 /* perm */
            invokevirtual java.security.Policy.implies:(Ljava/security/ProtectionDomain;Ljava/security/Permission;)Z
            ifeq 5
         4: .line 322
            iconst_1
            ireturn
         5: .line 324
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            ifnull 7
         6: .line 325
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            aload 1 /* perm */
            invokevirtual java.security.PermissionCollection.implies:(Ljava/security/Permission;)Z
            ireturn
         7: .line 328
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // java.security.Permission perm
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljava/security/ProtectionDomain;
            0    8     1  perm  Ljava/security/Permission;
    MethodParameters:
      Name  Flags
      perm  

  boolean impliesWithAltFilePerm(java.security.Permission);
    descriptor: (Ljava/security/Permission;)Z
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // java.security.ProtectionDomain this
        start local 1 // java.security.Permission perm
         0: .line 351
            getstatic java.security.ProtectionDomain.filePermCompatInPD:Z
            ifeq 2
            getstatic sun.security.util.FilePermCompat.compat:Z
            ifeq 2
         1: .line 352
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            ldc Ljava/security/ProtectionDomain;
            if_acmpeq 3
         2: .line 353
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* perm */
            invokevirtual java.security.ProtectionDomain.implies:(Ljava/security/Permission;)Z
            ireturn
         3: .line 356
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.ProtectionDomain.hasAllPerm:Z
            ifeq 5
         4: .line 359
            iconst_1
            ireturn
         5: .line 362
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* p2 */
        start local 2 // java.security.Permission p2
         6: .line 363
            iconst_0
            istore 3 /* p2Calculated */
        start local 3 // boolean p2Calculated
         7: .line 365
            aload 0 /* this */
            getfield java.security.ProtectionDomain.staticPermissions:Z
            ifne 17
         8: .line 366
            invokestatic java.security.Policy.getPolicyNoCheck:()Ljava/security/Policy;
            astore 4 /* policy */
        start local 4 // java.security.Policy policy
         9: .line 367
            aload 4 /* policy */
            instanceof sun.security.provider.PolicyFile
            ifeq 11
        10: .line 370
            aload 4 /* policy */
            aload 0 /* this */
            aload 1 /* perm */
            invokevirtual java.security.Policy.implies:(Ljava/security/ProtectionDomain;Ljava/security/Permission;)Z
            ireturn
        11: .line 372
      StackMap locals: java.security.Permission int java.security.Policy
      StackMap stack:
            aload 4 /* policy */
            aload 0 /* this */
            aload 1 /* perm */
            invokevirtual java.security.Policy.implies:(Ljava/security/ProtectionDomain;Ljava/security/Permission;)Z
            ifeq 13
        12: .line 373
            iconst_1
            ireturn
        13: .line 375
      StackMap locals:
      StackMap stack:
            aload 1 /* perm */
            invokestatic sun.security.util.FilePermCompat.newPermUsingAltPath:(Ljava/security/Permission;)Ljava/security/Permission;
            astore 2 /* p2 */
        14: .line 376
            iconst_1
            istore 3 /* p2Calculated */
        15: .line 377
            aload 2 /* p2 */
            ifnull 17
            aload 4 /* policy */
            aload 0 /* this */
            aload 2 /* p2 */
            invokevirtual java.security.Policy.implies:(Ljava/security/ProtectionDomain;Ljava/security/Permission;)Z
            ifeq 17
        16: .line 378
            iconst_1
            ireturn
        end local 4 // java.security.Policy policy
        17: .line 382
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            ifnull 24
        18: .line 383
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            aload 1 /* perm */
            invokevirtual java.security.PermissionCollection.implies:(Ljava/security/Permission;)Z
            ifeq 20
        19: .line 384
            iconst_1
            ireturn
        20: .line 386
      StackMap locals:
      StackMap stack:
            iload 3 /* p2Calculated */
            ifne 22
        21: .line 387
            aload 1 /* perm */
            invokestatic sun.security.util.FilePermCompat.newPermUsingAltPath:(Ljava/security/Permission;)Ljava/security/Permission;
            astore 2 /* p2 */
        22: .line 389
      StackMap locals:
      StackMap stack:
            aload 2 /* p2 */
            ifnull 24
        23: .line 390
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            aload 2 /* p2 */
            invokevirtual java.security.PermissionCollection.implies:(Ljava/security/Permission;)Z
            ireturn
        24: .line 394
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 3 // boolean p2Calculated
        end local 2 // java.security.Permission p2
        end local 1 // java.security.Permission perm
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   25     0          this  Ljava/security/ProtectionDomain;
            0   25     1          perm  Ljava/security/Permission;
            6   25     2            p2  Ljava/security/Permission;
            7   25     3  p2Calculated  Z
            9   17     4        policy  Ljava/security/Policy;
    MethodParameters:
      Name  Flags
      perm  

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // java.security.ProtectionDomain this
         0: .line 401
            ldc "<no principals>"
            astore 1 /* pals */
        start local 1 // java.lang.String pals
         1: .line 402
            aload 0 /* this */
            getfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
            ifnull 15
            aload 0 /* this */
            getfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
            arraylength
            ifle 15
         2: .line 403
            new java.lang.StringBuilder
            dup
            ldc "(principals "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 2 /* palBuf */
        start local 2 // java.lang.StringBuilder palBuf
         3: .line 405
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         4: goto 13
         5: .line 406
      StackMap locals: java.lang.String java.lang.StringBuilder int
      StackMap stack:
            aload 2 /* palBuf */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
            iload 3 /* i */
            aaload
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 407
            ldc " \""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
            iload 3 /* i */
            aaload
            invokeinterface java.security.Principal.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         7: .line 408
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 406
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         9: .line 409
            iload 3 /* i */
            aload 0 /* this */
            getfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
            arraylength
            iconst_1
            isub
            if_icmpge 11
        10: .line 410
            aload 2 /* palBuf */
            ldc ",\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
            goto 12
        11: .line 412
      StackMap locals:
      StackMap stack:
            aload 2 /* palBuf */
            ldc ")\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        12: .line 405
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 3 /* i */
            aload 0 /* this */
            getfield java.security.ProtectionDomain.principals:[Ljava/security/Principal;
            arraylength
            if_icmplt 5
        end local 3 // int i
        14: .line 414
            aload 2 /* palBuf */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 1 /* pals */
        end local 2 // java.lang.StringBuilder palBuf
        15: .line 419
      StackMap locals:
      StackMap stack:
            invokestatic java.security.Policy.isSet:()Z
            ifeq 17
            invokestatic java.security.ProtectionDomain.seeAllp:()Z
            ifeq 17
        16: .line 420
            aload 0 /* this */
            invokevirtual java.security.ProtectionDomain.mergePermissions:()Ljava/security/PermissionCollection;
            goto 18
        17: .line 421
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.security.ProtectionDomain.getPermissions:()Ljava/security/PermissionCollection;
        18: .line 419
      StackMap locals:
      StackMap stack: java.security.PermissionCollection
            astore 2 /* pc */
        start local 2 // java.security.PermissionCollection pc
        19: .line 423
            new java.lang.StringBuilder
            dup
            ldc "ProtectionDomain  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        20: .line 424
            aload 0 /* this */
            getfield java.security.ProtectionDomain.codesource:Ljava/security/CodeSource;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        21: .line 425
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield java.security.ProtectionDomain.classloader:Ljava/lang/ClassLoader;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        22: .line 426
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* pals */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        23: .line 427
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* pc */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        24: .line 423
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 2 // java.security.PermissionCollection pc
        end local 1 // java.lang.String pals
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   25     0    this  Ljava/security/ProtectionDomain;
            1   25     1    pals  Ljava/lang/String;
            3   15     2  palBuf  Ljava/lang/StringBuilder;
            4   14     3       i  I
           19   25     2      pc  Ljava/security/PermissionCollection;

  private static boolean seeAllp();
    descriptor: ()Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 453
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 0 /* sm */
        start local 0 // java.lang.SecurityManager sm
         1: .line 455
            aload 0 /* sm */
            ifnonnull 3
         2: .line 456
            iconst_1
            ireturn
         3: .line 458
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            getstatic java.security.ProtectionDomain$DebugHolder.debug:Lsun/security/util/Debug;
            ifnull 7
         4: .line 459
            aload 0 /* sm */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getClassLoader:()Ljava/lang/ClassLoader;
            ifnonnull 10
         5: .line 460
            invokestatic java.security.Policy.getPolicyNoCheck:()Ljava/security/Policy;
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getClassLoader:()Ljava/lang/ClassLoader;
            ifnonnull 10
         6: .line 462
            iconst_1
            ireturn
         7: .line 466
      StackMap locals:
      StackMap stack:
            aload 0 /* sm */
            getstatic sun.security.util.SecurityConstants.GET_POLICY_PERMISSION:Ljava/security/SecurityPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         8: .line 467
            iconst_1
            ireturn
         9: .line 468
      StackMap locals:
      StackMap stack: java.lang.SecurityException
            pop
        10: .line 474
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 0 // java.lang.SecurityManager sm
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            1   11     0    sm  Ljava/lang/SecurityManager;
      Exception table:
        from    to  target  type
           7     8       9  Class java.lang.SecurityException

  private java.security.PermissionCollection mergePermissions();
    descriptor: ()Ljava/security/PermissionCollection;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=15, args_size=1
        start local 0 // java.security.ProtectionDomain this
         0: .line 478
            aload 0 /* this */
            getfield java.security.ProtectionDomain.staticPermissions:Z
            ifeq 2
         1: .line 479
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            areturn
         2: .line 483
      StackMap locals:
      StackMap stack:
            new java.security.ProtectionDomain$1
            dup
            aload 0 /* this */
            invokespecial java.security.ProtectionDomain$1.<init>:(Ljava/security/ProtectionDomain;)V
         3: .line 482
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.security.PermissionCollection
         4: .line 481
            astore 1 /* perms */
        start local 1 // java.security.PermissionCollection perms
         5: .line 490
            new java.security.Permissions
            dup
            invokespecial java.security.Permissions.<init>:()V
            astore 2 /* mergedPerms */
        start local 2 // java.security.Permissions mergedPerms
         6: .line 491
            bipush 32
            istore 3 /* swag */
        start local 3 // int swag
         7: .line 492
            bipush 8
            istore 4 /* vcap */
        start local 4 // int vcap
         8: .line 494
            new java.util.ArrayList
            dup
            iload 4 /* vcap */
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 6 /* pdVector */
        start local 6 // java.util.List pdVector
         9: .line 495
            new java.util.ArrayList
            dup
            iload 3 /* swag */
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 7 /* plVector */
        start local 7 // java.util.List plVector
        10: .line 499
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            ifnull 20
        11: .line 500
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            dup
            astore 8
            monitorenter
        12: .line 501
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            invokevirtual java.security.PermissionCollection.elements:()Ljava/util/Enumeration;
            astore 5 /* e */
        start local 5 // java.util.Enumeration e
        13: .line 502
            goto 15
        14: .line 503
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int java.util.Enumeration java.util.List java.util.List java.security.PermissionCollection
      StackMap stack:
            aload 6 /* pdVector */
            aload 5 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.security.Permission
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        15: .line 502
      StackMap locals:
      StackMap stack:
            aload 5 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 14
        16: .line 500
            aload 8
            monitorexit
        17: goto 20
        end local 5 // java.util.Enumeration e
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int top java.util.List java.util.List java.security.PermissionCollection
      StackMap stack: java.lang.Throwable
        18: aload 8
            monitorexit
        19: athrow
        20: .line 510
      StackMap locals:
      StackMap stack:
            aload 1 /* perms */
            ifnull 31
        21: .line 511
            aload 1 /* perms */
            dup
            astore 8
            monitorenter
        22: .line 512
            aload 1 /* perms */
            invokevirtual java.security.PermissionCollection.elements:()Ljava/util/Enumeration;
            astore 5 /* e */
        start local 5 // java.util.Enumeration e
        23: .line 513
            goto 26
        24: .line 514
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int java.util.Enumeration java.util.List java.util.List java.security.PermissionCollection
      StackMap stack:
            aload 7 /* plVector */
            aload 5 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.security.Permission
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        25: .line 515
            iinc 4 /* vcap */ 1
        26: .line 513
      StackMap locals:
      StackMap stack:
            aload 5 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 24
        27: .line 511
            aload 8
            monitorexit
        28: goto 31
        end local 5 // java.util.Enumeration e
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int top java.util.List java.util.List java.security.PermissionCollection
      StackMap stack: java.lang.Throwable
        29: aload 8
            monitorexit
        30: athrow
        31: .line 520
      StackMap locals:
      StackMap stack:
            aload 1 /* perms */
            ifnull 54
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            ifnull 54
        32: .line 525
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            dup
            astore 8
            monitorenter
        33: .line 526
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            invokevirtual java.security.PermissionCollection.elements:()Ljava/util/Enumeration;
            astore 5 /* e */
        start local 5 // java.util.Enumeration e
        34: .line 527
            goto 49
        35: .line 528
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int java.util.Enumeration java.util.List java.util.List java.security.PermissionCollection
      StackMap stack:
            aload 5 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.security.Permission
            astore 9 /* pdp */
        start local 9 // java.security.Permission pdp
        36: .line 529
            aload 9 /* pdp */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            astore 10 /* pdpClass */
        start local 10 // java.lang.Class pdpClass
        37: .line 530
            aload 9 /* pdp */
            invokevirtual java.security.Permission.getActions:()Ljava/lang/String;
            astore 11 /* pdpActions */
        start local 11 // java.lang.String pdpActions
        38: .line 531
            aload 9 /* pdp */
            invokevirtual java.security.Permission.getName:()Ljava/lang/String;
            astore 12 /* pdpName */
        start local 12 // java.lang.String pdpName
        39: .line 532
            iconst_0
            istore 13 /* i */
        start local 13 // int i
        40: goto 48
        41: .line 533
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int java.util.Enumeration java.util.List java.util.List java.security.PermissionCollection java.security.Permission java.lang.Class java.lang.String java.lang.String int
      StackMap stack:
            aload 7 /* plVector */
            iload 13 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.Permission
            astore 14 /* pp */
        start local 14 // java.security.Permission pp
        42: .line 534
            aload 10 /* pdpClass */
            aload 14 /* pp */
            invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
            ifeq 47
        43: .line 538
            aload 12 /* pdpName */
            aload 14 /* pp */
            invokevirtual java.security.Permission.getName:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 47
        44: .line 539
            aload 11 /* pdpActions */
            aload 14 /* pp */
            invokevirtual java.security.Permission.getActions:()Ljava/lang/String;
            invokestatic java.util.Objects.equals:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 47
        45: .line 540
            aload 7 /* plVector */
            iload 13 /* i */
            invokeinterface java.util.List.remove:(I)Ljava/lang/Object;
            pop
        46: .line 541
            goto 49
        end local 14 // java.security.Permission pp
        47: .line 532
      StackMap locals:
      StackMap stack:
            iinc 13 /* i */ 1
      StackMap locals:
      StackMap stack:
        48: iload 13 /* i */
            aload 7 /* plVector */
            invokeinterface java.util.List.size:()I
            if_icmplt 41
        end local 13 // int i
        end local 12 // java.lang.String pdpName
        end local 11 // java.lang.String pdpActions
        end local 10 // java.lang.Class pdpClass
        end local 9 // java.security.Permission pdp
        49: .line 527
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int java.util.Enumeration java.util.List java.util.List java.security.PermissionCollection
      StackMap stack:
            aload 5 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 35
        50: .line 525
            aload 8
            monitorexit
        51: goto 54
        end local 5 // java.util.Enumeration e
      StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions int int top java.util.List java.util.List java.security.PermissionCollection
      StackMap stack: java.lang.Throwable
        52: aload 8
            monitorexit
        53: athrow
        54: .line 549
      StackMap locals:
      StackMap stack:
            aload 1 /* perms */
            ifnull 60
        55: .line 553
            aload 7 /* plVector */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            istore 8 /* i */
        start local 8 // int i
        56: goto 59
        57: .line 554
      StackMap locals: int
      StackMap stack:
            aload 2 /* mergedPerms */
            aload 7 /* plVector */
            iload 8 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.Permission
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
        58: .line 553
            iinc 8 /* i */ -1
      StackMap locals:
      StackMap stack:
        59: iload 8 /* i */
            ifge 57
        end local 8 // int i
        60: .line 557
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.ProtectionDomain.permissions:Ljava/security/PermissionCollection;
            ifnull 66
        61: .line 558
            aload 6 /* pdVector */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
            istore 8 /* i */
        start local 8 // int i
        62: goto 65
        63: .line 559
      StackMap locals: int
      StackMap stack:
            aload 2 /* mergedPerms */
            aload 6 /* pdVector */
            iload 8 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.Permission
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
        64: .line 558
            iinc 8 /* i */ -1
      StackMap locals:
      StackMap stack:
        65: iload 8 /* i */
            ifge 63
        end local 8 // int i
        66: .line 563
      StackMap locals:
      StackMap stack:
            aload 2 /* mergedPerms */
            areturn
        end local 7 // java.util.List plVector
        end local 6 // java.util.List pdVector
        end local 4 // int vcap
        end local 3 // int swag
        end local 2 // java.security.Permissions mergedPerms
        end local 1 // java.security.PermissionCollection perms
        end local 0 // java.security.ProtectionDomain this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   67     0         this  Ljava/security/ProtectionDomain;
            5   67     1        perms  Ljava/security/PermissionCollection;
            6   67     2  mergedPerms  Ljava/security/Permissions;
            7   67     3         swag  I
            8   67     4         vcap  I
           13   18     5            e  Ljava/util/Enumeration<Ljava/security/Permission;>;
           23   29     5            e  Ljava/util/Enumeration<Ljava/security/Permission;>;
           34   52     5            e  Ljava/util/Enumeration<Ljava/security/Permission;>;
            9   67     6     pdVector  Ljava/util/List<Ljava/security/Permission;>;
           10   67     7     plVector  Ljava/util/List<Ljava/security/Permission;>;
           36   49     9          pdp  Ljava/security/Permission;
           37   49    10     pdpClass  Ljava/lang/Class<*>;
           38   49    11   pdpActions  Ljava/lang/String;
           39   49    12      pdpName  Ljava/lang/String;
           40   49    13            i  I
           42   47    14           pp  Ljava/security/Permission;
           56   60     8            i  I
           62   66     8            i  I
      Exception table:
        from    to  target  type
          12    17      18  any
          18    19      18  any
          22    28      29  any
          29    30      29  any
          33    51      52  any
          52    53      52  any
}
SourceFile: "ProtectionDomain.java"
NestMembers:
  java.security.ProtectionDomain$1  java.security.ProtectionDomain$DebugHolder  java.security.ProtectionDomain$JavaSecurityAccessImpl  java.security.ProtectionDomain$JavaSecurityAccessImpl$1  java.security.ProtectionDomain$Key
InnerClasses:
  java.security.ProtectionDomain$1
  private DebugHolder = java.security.ProtectionDomain$DebugHolder of java.security.ProtectionDomain
  private JavaSecurityAccessImpl = java.security.ProtectionDomain$JavaSecurityAccessImpl of java.security.ProtectionDomain
  final Key = java.security.ProtectionDomain$Key of java.security.ProtectionDomain