public abstract class javax.security.auth.Policy
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: javax.security.auth.Policy
  super_class: java.lang.Object
{
  private static javax.security.auth.Policy policy;
    descriptor: Ljavax/security/auth/Policy;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private final java.security.AccessControlContext acc;
    descriptor: Ljava/security/AccessControlContext;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private static boolean isCustomPolicy;
    descriptor: Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  protected void <init>();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // javax.security.auth.Policy this
         0: .line 178
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 167
            aload 0 /* this */
         2: .line 168
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            putfield javax.security.auth.Policy.acc:Ljava/security/AccessControlContext;
         3: .line 178
            return
        end local 0 // javax.security.auth.Policy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljavax/security/auth/Policy;

  public static javax.security.auth.Policy getPolicy();
    descriptor: ()Ljavax/security/auth/Policy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=1, args_size=0
         0: .line 198
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 0 /* sm */
        start local 0 // java.lang.SecurityManager sm
         1: .line 199
            aload 0 /* sm */
            ifnull 2
            aload 0 /* sm */
            new javax.security.auth.AuthPermission
            dup
            ldc "getPolicy"
            invokespecial javax.security.auth.AuthPermission.<init>:(Ljava/lang/String;)V
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         2: .line 200
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            invokestatic javax.security.auth.Policy.getPolicyNoCheck:()Ljavax/security/auth/Policy;
            areturn
        end local 0 // java.lang.SecurityManager sm
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            1    3     0    sm  Ljava/lang/SecurityManager;

  static javax.security.auth.Policy getPolicyNoCheck();
    descriptor: ()Ljavax/security/auth/Policy;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=4, args_size=0
         0: .line 210
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            ifnonnull 26
         1: .line 212
            ldc Ljavax/security/auth/Policy;
            dup
            astore 0
            monitorenter
         2: .line 214
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            ifnonnull 22
         3: .line 215
            aconst_null
            astore 1 /* policy_class */
        start local 1 // java.lang.String policy_class
         4: .line 217
            new javax.security.auth.Policy$1
            dup
            invokespecial javax.security.auth.Policy$1.<init>:()V
         5: .line 216
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 1 /* policy_class */
         6: .line 223
            aload 1 /* policy_class */
            ifnonnull 8
         7: .line 224
            ldc "com.sun.security.auth.PolicyFile"
            astore 1 /* policy_class */
         8: .line 228
      StackMap locals: java.lang.Class java.lang.String
      StackMap stack:
            aload 1 /* policy_class */
            astore 2 /* finalClass */
        start local 2 // java.lang.String finalClass
         9: .line 230
            new javax.security.auth.Policy$2
            dup
            aload 2 /* finalClass */
            invokespecial javax.security.auth.Policy$2.<init>:(Ljava/lang/String;)V
        10: .line 229
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            checkcast javax.security.auth.Policy
            astore 3 /* untrustedImpl */
        start local 3 // javax.security.auth.Policy untrustedImpl
        11: .line 241
            aload 3 /* untrustedImpl */
            getfield javax.security.auth.Policy.acc:Ljava/security/AccessControlContext;
            ifnonnull 13
        12: .line 242
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
        13: .line 245
      StackMap locals: java.lang.String javax.security.auth.Policy
      StackMap stack:
            new javax.security.auth.Policy$3
            dup
            aload 3 /* untrustedImpl */
            aload 2 /* finalClass */
            invokespecial javax.security.auth.Policy$3.<init>:(Ljavax/security/auth/Policy;Ljava/lang/String;)V
        14: .line 252
            aload 3 /* untrustedImpl */
            getfield javax.security.auth.Policy.acc:Ljava/security/AccessControlContext;
        15: .line 244
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            pop
        end local 3 // javax.security.auth.Policy untrustedImpl
        end local 2 // java.lang.String finalClass
        16: .line 254
            goto 22
      StackMap locals: java.lang.Class java.lang.String
      StackMap stack: java.lang.Exception
        17: pop
        18: .line 255
            new java.lang.SecurityException
            dup
        19: .line 257
            ldc "unable.to.instantiate.Subject.based.policy"
        20: .line 256
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
        21: .line 255
            invokespecial java.lang.SecurityException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.String policy_class
        22: .line 212
      StackMap locals:
      StackMap stack:
            aload 0
            monitorexit
        23: goto 26
      StackMap locals:
      StackMap stack: java.lang.Throwable
        24: aload 0
            monitorexit
        25: athrow
        26: .line 262
      StackMap locals:
      StackMap stack:
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            areturn
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            4   22     1   policy_class  Ljava/lang/String;
            9   16     2     finalClass  Ljava/lang/String;
           11   16     3  untrustedImpl  Ljavax/security/auth/Policy;
      Exception table:
        from    to  target  type
           8    16      17  Class java.lang.Exception
           2    23      24  any
          24    25      24  any

  public static void setPolicy(javax.security.auth.Policy);
    descriptor: (Ljavax/security/auth/Policy;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // javax.security.auth.Policy policy
         0: .line 282
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 1 /* sm */
        start local 1 // java.lang.SecurityManager sm
         1: .line 283
            aload 1 /* sm */
            ifnull 2
            aload 1 /* sm */
            new javax.security.auth.AuthPermission
            dup
            ldc "setPolicy"
            invokespecial javax.security.auth.AuthPermission.<init>:(Ljava/lang/String;)V
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         2: .line 284
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 0 /* policy */
            putstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
         3: .line 286
            aload 0 /* policy */
            ifnull 4
            iconst_1
            goto 5
      StackMap locals:
      StackMap stack:
         4: iconst_0
      StackMap locals:
      StackMap stack: int
         5: putstatic javax.security.auth.Policy.isCustomPolicy:Z
         6: .line 287
            return
        end local 1 // java.lang.SecurityManager sm
        end local 0 // javax.security.auth.Policy policy
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0  policy  Ljavax/security/auth/Policy;
            1    7     1      sm  Ljava/lang/SecurityManager;
    MethodParameters:
        Name  Flags
      policy  

  static boolean isCustomPolicySet(sun.security.util.Debug);
    descriptor: (Lsun/security/util/Debug;)Z
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // sun.security.util.Debug debug
         0: .line 300
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            ifnull 6
         1: .line 301
            aload 0 /* debug */
            ifnull 5
            getstatic javax.security.auth.Policy.isCustomPolicy:Z
            ifeq 5
         2: .line 302
            aload 0 /* debug */
            new java.lang.StringBuilder
            dup
            ldc "Providing backwards compatibility for javax.security.auth.policy implementation: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         3: .line 304
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         4: .line 302
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         5: .line 306
      StackMap locals:
      StackMap stack:
            getstatic javax.security.auth.Policy.isCustomPolicy:Z
            ireturn
         6: .line 310
      StackMap locals:
      StackMap stack:
            new javax.security.auth.Policy$4
            dup
            invokespecial javax.security.auth.Policy$4.<init>:()V
         7: .line 309
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 1 /* policyClass */
        start local 1 // java.lang.String policyClass
         8: .line 315
            aload 1 /* policyClass */
            ifnull 15
         9: .line 316
            aload 1 /* policyClass */
            ldc "com.sun.security.auth.PolicyFile"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 15
        10: .line 317
            aload 0 /* debug */
            ifnull 14
        11: .line 318
            aload 0 /* debug */
            new java.lang.StringBuilder
            dup
            ldc "Providing backwards compatibility for javax.security.auth.policy implementation: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        12: .line 320
            aload 1 /* policyClass */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 318
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 322
      StackMap locals: java.lang.String
      StackMap stack:
            iconst_1
            ireturn
        15: .line 324
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // java.lang.String policyClass
        end local 0 // sun.security.util.Debug debug
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   16     0        debug  Lsun/security/util/Debug;
            8   16     1  policyClass  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      debug  

  public abstract java.security.PermissionCollection getPermissions(javax.security.auth.Subject, java.security.CodeSource);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/CodeSource;)Ljava/security/PermissionCollection;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
         Name  Flags
      subject  
      cs       

  public abstract void refresh();
    descriptor: ()V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
}
SourceFile: "Policy.java"
NestMembers:
  javax.security.auth.Policy$1  javax.security.auth.Policy$2  javax.security.auth.Policy$3  javax.security.auth.Policy$4
InnerClasses:
  javax.security.auth.Policy$1
  javax.security.auth.Policy$2
  javax.security.auth.Policy$3
  javax.security.auth.Policy$4
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()