class sun.security.provider.PolicyPermissions extends java.security.PermissionCollection
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.provider.PolicyPermissions
  super_class: java.security.PermissionCollection
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -1954188373270545523

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

  private java.security.Permissions perms;
    descriptor: Ljava/security/Permissions;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.provider.AuthPolicyFile policy;
    descriptor: Lsun/security/provider/AuthPolicyFile;
    flags: (0x0002) ACC_PRIVATE

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

  private java.util.Vector<java.security.Permission> additionalPerms;
    descriptor: Ljava/util/Vector;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Vector<Ljava/security/Permission;>;

  void <init>(sun.security.provider.AuthPolicyFile, java.security.CodeSource);
    descriptor: (Lsun/security/provider/AuthPolicyFile;Ljava/security/CodeSource;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.provider.PolicyPermissions this
        start local 1 // sun.security.provider.AuthPolicyFile policy
        start local 2 // java.security.CodeSource codesource
         0: .line 1129
            aload 0 /* this */
            invokespecial java.security.PermissionCollection.<init>:()V
         1: .line 1132
            aload 0 /* this */
            aload 2 /* codesource */
            putfield sun.security.provider.PolicyPermissions.codesource:Ljava/security/CodeSource;
         2: .line 1133
            aload 0 /* this */
            aload 1 /* policy */
            putfield sun.security.provider.PolicyPermissions.policy:Lsun/security/provider/AuthPolicyFile;
         3: .line 1134
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
         4: .line 1135
            aload 0 /* this */
            iconst_1
            putfield sun.security.provider.PolicyPermissions.notInit:Z
         5: .line 1136
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.PolicyPermissions.additionalPerms:Ljava/util/Vector;
         6: .line 1137
            return
        end local 2 // java.security.CodeSource codesource
        end local 1 // sun.security.provider.AuthPolicyFile policy
        end local 0 // sun.security.provider.PolicyPermissions this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    7     0        this  Lsun/security/provider/PolicyPermissions;
            0    7     1      policy  Lsun/security/provider/AuthPolicyFile;
            0    7     2  codesource  Ljava/security/CodeSource;
    MethodParameters:
            Name  Flags
      policy      
      codesource  

  public void add(java.security.Permission);
    descriptor: (Ljava/security/Permission;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.provider.PolicyPermissions this
        start local 1 // java.security.Permission permission
         0: .line 1141
            aload 0 /* this */
            invokevirtual sun.security.provider.PolicyPermissions.isReadOnly:()Z
            ifeq 6
         1: .line 1142
            new java.lang.SecurityException
            dup
         2: .line 1143
            getstatic sun.security.provider.AuthPolicyFile.rb:Ljava/util/ResourceBundle;
         3: .line 1144
            ldc "attempt.to.add.a.Permission.to.a.readonly.PermissionCollection"
         4: .line 1143
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
         5: .line 1142
            invokespecial java.lang.SecurityException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 1146
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            ifnonnull 11
         7: .line 1147
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.additionalPerms:Ljava/util/Vector;
            ifnonnull 9
         8: .line 1148
            aload 0 /* this */
            new java.util.Vector
            dup
            invokespecial java.util.Vector.<init>:()V
            putfield sun.security.provider.PolicyPermissions.additionalPerms:Ljava/util/Vector;
         9: .line 1150
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.additionalPerms:Ljava/util/Vector;
            aload 1 /* permission */
            invokevirtual java.util.Vector.add:(Ljava/lang/Object;)Z
            pop
        10: .line 1151
            goto 12
        11: .line 1152
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            aload 1 /* permission */
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
        12: .line 1154
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.security.Permission permission
        end local 0 // sun.security.provider.PolicyPermissions this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   13     0        this  Lsun/security/provider/PolicyPermissions;
            0   13     1  permission  Ljava/security/Permission;
    MethodParameters:
            Name  Flags
      permission  

  private synchronized void init();
    descriptor: ()V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.provider.PolicyPermissions this
         0: .line 1157
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.notInit:Z
            ifeq 11
         1: .line 1158
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            ifnonnull 3
         2: .line 1159
            aload 0 /* this */
            new java.security.Permissions
            dup
            invokespecial java.security.Permissions.<init>:()V
            putfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
         3: .line 1161
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.additionalPerms:Ljava/util/Vector;
            ifnull 9
         4: .line 1162
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.additionalPerms:Ljava/util/Vector;
            invokevirtual java.util.Vector.elements:()Ljava/util/Enumeration;
            astore 1 /* e */
        start local 1 // java.util.Enumeration e
         5: .line 1163
            goto 7
         6: .line 1164
      StackMap locals: java.util.Enumeration
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            aload 1 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.security.Permission
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
         7: .line 1163
      StackMap locals:
      StackMap stack:
            aload 1 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 6
         8: .line 1166
            aload 0 /* this */
            aconst_null
            putfield sun.security.provider.PolicyPermissions.additionalPerms:Ljava/util/Vector;
        end local 1 // java.util.Enumeration e
         9: .line 1168
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.policy:Lsun/security/provider/AuthPolicyFile;
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.codesource:Ljava/security/CodeSource;
            invokevirtual sun.security.provider.AuthPolicyFile.getPermissions:(Ljava/security/Permissions;Ljava/security/CodeSource;)Ljava/security/Permissions;
            pop
        10: .line 1169
            aload 0 /* this */
            iconst_0
            putfield sun.security.provider.PolicyPermissions.notInit:Z
        11: .line 1171
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.provider.PolicyPermissions this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lsun/security/provider/PolicyPermissions;
            5    9     1     e  Ljava/util/Enumeration<Ljava/security/Permission;>;

  public boolean implies(java.security.Permission);
    descriptor: (Ljava/security/Permission;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.provider.PolicyPermissions this
        start local 1 // java.security.Permission permission
         0: .line 1175
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.notInit:Z
            ifeq 2
         1: .line 1176
            aload 0 /* this */
            invokevirtual sun.security.provider.PolicyPermissions.init:()V
         2: .line 1178
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            aload 1 /* permission */
            invokevirtual java.security.Permissions.implies:(Ljava/security/Permission;)Z
            ireturn
        end local 1 // java.security.Permission permission
        end local 0 // sun.security.provider.PolicyPermissions this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lsun/security/provider/PolicyPermissions;
            0    3     1  permission  Ljava/security/Permission;
    MethodParameters:
            Name  Flags
      permission  

  public java.util.Enumeration<java.security.Permission> elements();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.PolicyPermissions this
         0: .line 1183
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.notInit:Z
            ifeq 2
         1: .line 1184
            aload 0 /* this */
            invokevirtual sun.security.provider.PolicyPermissions.init:()V
         2: .line 1186
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            invokevirtual java.security.Permissions.elements:()Ljava/util/Enumeration;
            areturn
        end local 0 // sun.security.provider.PolicyPermissions this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/provider/PolicyPermissions;
    Signature: ()Ljava/util/Enumeration<Ljava/security/Permission;>;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.PolicyPermissions this
         0: .line 1191
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.notInit:Z
            ifeq 2
         1: .line 1192
            aload 0 /* this */
            invokevirtual sun.security.provider.PolicyPermissions.init:()V
         2: .line 1194
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.PolicyPermissions.perms:Ljava/security/Permissions;
            invokevirtual java.security.Permissions.toString:()Ljava/lang/String;
            areturn
        end local 0 // sun.security.provider.PolicyPermissions this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/provider/PolicyPermissions;
}
SourceFile: "AuthPolicyFile.java"