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 179
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 168
            aload 0 /* this */
         2: .line 169
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            putfield javax.security.auth.Policy.acc:Ljava/security/AccessControlContext;
         3: .line 179
            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 199
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 0 /* sm */
        start local 0 // java.lang.SecurityManager sm
         1: .line 200
            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 201
      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 211
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            ifnonnull 24
         1: .line 213
            ldc Ljavax/security/auth/Policy;
            dup
            astore 0
            monitorenter
         2: .line 215
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            ifnonnull 20
         3: .line 216
            aconst_null
            astore 1 /* policy_class */
        start local 1 // java.lang.String policy_class
         4: .line 218
            new javax.security.auth.Policy$1
            dup
            invokespecial javax.security.auth.Policy$1.<init>:()V
         5: .line 217
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 1 /* policy_class */
         6: .line 224
            aload 1 /* policy_class */
            ifnonnull 8
         7: .line 225
            ldc "com.sun.security.auth.PolicyFile"
            astore 1 /* policy_class */
         8: .line 229
      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 231
            new javax.security.auth.Policy$2
            dup
            aload 2 /* finalClass */
            invokespecial javax.security.auth.Policy$2.<init>:(Ljava/lang/String;)V
        10: .line 230
            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 243
            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
        12: .line 250
            aload 3 /* untrustedImpl */
            getfield javax.security.auth.Policy.acc:Ljava/security/AccessControlContext;
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.AccessControlContext
        13: .line 242
            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
        14: .line 252
            goto 20
      StackMap locals:
      StackMap stack: java.lang.Exception
        15: pop
        16: .line 253
            new java.lang.SecurityException
            dup
        17: .line 255
            ldc "unable.to.instantiate.Subject.based.policy"
        18: .line 254
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
        19: .line 253
            invokespecial java.lang.SecurityException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.String policy_class
        20: .line 213
      StackMap locals:
      StackMap stack:
            aload 0
            monitorexit
        21: goto 24
      StackMap locals:
      StackMap stack: java.lang.Throwable
        22: aload 0
            monitorexit
        23: athrow
        24: .line 260
      StackMap locals:
      StackMap stack:
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            areturn
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            4   20     1   policy_class  Ljava/lang/String;
            9   14     2     finalClass  Ljava/lang/String;
           11   14     3  untrustedImpl  Ljavax/security/auth/Policy;
      Exception table:
        from    to  target  type
           8    14      15  Class java.lang.Exception
           2    21      22  any
          22    23      22  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 280
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 1 /* sm */
        start local 1 // java.lang.SecurityManager sm
         1: .line 281
            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 282
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 0 /* policy */
            putstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
         3: .line 284
            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 285
            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 298
            getstatic javax.security.auth.Policy.policy:Ljavax/security/auth/Policy;
            ifnull 6
         1: .line 299
            aload 0 /* debug */
            ifnull 5
            getstatic javax.security.auth.Policy.isCustomPolicy:Z
            ifeq 5
         2: .line 300
            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 302
            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 300
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         5: .line 304
      StackMap locals:
      StackMap stack:
            getstatic javax.security.auth.Policy.isCustomPolicy:Z
            ireturn
         6: .line 308
      StackMap locals:
      StackMap stack:
            new javax.security.auth.Policy$4
            dup
            invokespecial javax.security.auth.Policy$4.<init>:()V
         7: .line 307
            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 313
            aload 1 /* policyClass */
            ifnull 15
         9: .line 314
            aload 1 /* policyClass */
            ldc "com.sun.security.auth.PolicyFile"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 15
        10: .line 315
            aload 0 /* debug */
            ifnull 14
        11: .line 316
            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 318
            aload 1 /* policyClass */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 316
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 320
      StackMap locals: java.lang.String
      StackMap stack:
            iconst_1
            ireturn
        15: .line 322
      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()