public final class java.security.AccessController
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: java.security.AccessController
  super_class: java.lang.Object
{
  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.AccessController this
         0: .line 244
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // java.security.AccessController this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/AccessController;

  public static native <T> T doPrivileged(java.security.PrivilegedAction<T>);
    descriptor: (Ljava/security/PrivilegedAction;)Ljava/lang/Object;
    flags: (0x0109) ACC_PUBLIC, ACC_STATIC, ACC_NATIVE
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
        Name  Flags
      action  

  public static <T> T doPrivilegedWithCombiner(java.security.PrivilegedAction<T>);
    descriptor: (Ljava/security/PrivilegedAction;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // java.security.PrivilegedAction action
         0: .line 296
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* acc */
        start local 1 // java.security.AccessControlContext acc
         1: .line 297
            aload 1 /* acc */
            ifnonnull 3
         2: .line 298
            aload 0 /* action */
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            areturn
         3: .line 300
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
            aload 1 /* acc */
            invokevirtual java.security.AccessControlContext.getAssignedCombiner:()Ljava/security/DomainCombiner;
            astore 2 /* dc */
        start local 2 // java.security.DomainCombiner dc
         4: .line 301
            aload 0 /* action */
            aload 2 /* dc */
            invokestatic sun.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            invokestatic java.security.AccessController.preserveCombiner:(Ljava/security/DomainCombiner;Ljava/lang/Class;)Ljava/security/AccessControlContext;
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 2 // java.security.DomainCombiner dc
        end local 1 // java.security.AccessControlContext acc
        end local 0 // java.security.PrivilegedAction action
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0  action  Ljava/security/PrivilegedAction<TT;>;
            1    5     1     acc  Ljava/security/AccessControlContext;
            4    5     2      dc  Ljava/security/DomainCombiner;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
        Name  Flags
      action  

  public static native <T> T doPrivileged(java.security.PrivilegedAction<T>, java.security.AccessControlContext);
    descriptor: (Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0109) ACC_PUBLIC, ACC_STATIC, ACC_NATIVE
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;Ljava/security/AccessControlContext;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  

  static <T> T doPrivileged(java.security.PrivilegedAction<T>, java.security.AccessControlContext, java.security.Permission[]);
    descriptor: (Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/lang/Object;
    flags: (0x0088) ACC_STATIC, ACC_VARARGS
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // java.security.PrivilegedAction action
        start local 1 // java.security.AccessControlContext context
        start local 2 // java.security.Permission[] perms
         0: .line 376
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 377
            aload 2 /* perms */
            ifnonnull 3
         2: .line 378
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 380
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
            invokestatic sun.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 4 /* caller */
        start local 4 // java.lang.Class caller
         4: .line 381
            aload 0 /* action */
            aconst_null
         5: .line 382
            aload 4 /* caller */
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
         6: .line 381
            invokestatic java.security.AccessController.createWrapper:(Ljava/security/DomainCombiner;Ljava/lang/Class;Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/security/AccessControlContext;
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 4 // java.lang.Class caller
        end local 3 // java.security.AccessControlContext parent
        end local 2 // java.security.Permission[] perms
        end local 1 // java.security.AccessControlContext context
        end local 0 // java.security.PrivilegedAction action
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0   action  Ljava/security/PrivilegedAction<TT;>;
            0    7     1  context  Ljava/security/AccessControlContext;
            0    7     2    perms  [Ljava/security/Permission;
            1    7     3   parent  Ljava/security/AccessControlContext;
            4    7     4   caller  Ljava/lang/Class<*>;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;Ljava/security/AccessControlContext;[Ljava/security/Permission;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  
      perms    

  public static native <T> T doPrivileged(java.security.PrivilegedExceptionAction<T>);
    descriptor: (Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
    flags: (0x0109) ACC_PUBLIC, ACC_STATIC, ACC_NATIVE
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
        Name  Flags
      action  

  public static <T> T doPrivilegedWithCombiner(java.security.PrivilegedExceptionAction<T>);
    descriptor: (Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // java.security.PrivilegedExceptionAction action
         0: .line 444
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* acc */
        start local 1 // java.security.AccessControlContext acc
         1: .line 445
            aload 1 /* acc */
            ifnonnull 3
         2: .line 446
            aload 0 /* action */
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            areturn
         3: .line 448
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
            aload 1 /* acc */
            invokevirtual java.security.AccessControlContext.getAssignedCombiner:()Ljava/security/DomainCombiner;
            astore 2 /* dc */
        start local 2 // java.security.DomainCombiner dc
         4: .line 449
            aload 0 /* action */
            aload 2 /* dc */
            invokestatic sun.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            invokestatic java.security.AccessController.preserveCombiner:(Ljava/security/DomainCombiner;Ljava/lang/Class;)Ljava/security/AccessControlContext;
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 2 // java.security.DomainCombiner dc
        end local 1 // java.security.AccessControlContext acc
        end local 0 // java.security.PrivilegedExceptionAction action
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0  action  Ljava/security/PrivilegedExceptionAction<TT;>;
            1    5     1     acc  Ljava/security/AccessControlContext;
            4    5     2      dc  Ljava/security/DomainCombiner;
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
        Name  Flags
      action  

  private static java.security.AccessControlContext preserveCombiner(java.security.DomainCombiner, java.lang.Class<?>);
    descriptor: (Ljava/security/DomainCombiner;Ljava/lang/Class;)Ljava/security/AccessControlContext;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // java.security.DomainCombiner combiner
        start local 1 // java.lang.Class caller
         0: .line 457
            aload 0 /* combiner */
            aload 1 /* caller */
            aconst_null
            aconst_null
            aconst_null
            invokestatic java.security.AccessController.createWrapper:(Ljava/security/DomainCombiner;Ljava/lang/Class;Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/security/AccessControlContext;
            areturn
        end local 1 // java.lang.Class caller
        end local 0 // java.security.DomainCombiner combiner
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0  combiner  Ljava/security/DomainCombiner;
            0    1     1    caller  Ljava/lang/Class<*>;
    Signature: (Ljava/security/DomainCombiner;Ljava/lang/Class<*>;)Ljava/security/AccessControlContext;
    MethodParameters:
          Name  Flags
      combiner  
      caller    final

  private static java.security.AccessControlContext createWrapper(java.security.DomainCombiner, java.lang.Class<?>, java.security.AccessControlContext, java.security.AccessControlContext, java.security.Permission[]);
    descriptor: (Ljava/security/DomainCombiner;Ljava/lang/Class;Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/security/AccessControlContext;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=7, args_size=5
        start local 0 // java.security.DomainCombiner combiner
        start local 1 // java.lang.Class caller
        start local 2 // java.security.AccessControlContext parent
        start local 3 // java.security.AccessControlContext context
        start local 4 // java.security.Permission[] perms
         0: .line 468
            aload 1 /* caller */
            invokestatic java.security.AccessController.getCallerPD:(Ljava/lang/Class;)Ljava/security/ProtectionDomain;
            astore 5 /* callerPD */
        start local 5 // java.security.ProtectionDomain callerPD
         1: .line 470
            aload 3 /* context */
            ifnull 6
            aload 3 /* context */
            invokevirtual java.security.AccessControlContext.isAuthorized:()Z
            ifne 6
         2: .line 471
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            ifnull 6
         3: .line 472
            aload 5 /* callerPD */
            invokevirtual java.security.ProtectionDomain.impliesCreateAccessControlContext:()Z
            ifne 6
         4: .line 474
            new java.security.ProtectionDomain
            dup
            aconst_null
            aconst_null
            invokespecial java.security.ProtectionDomain.<init>:(Ljava/security/CodeSource;Ljava/security/PermissionCollection;)V
            astore 6 /* nullPD */
        start local 6 // java.security.ProtectionDomain nullPD
         5: .line 475
            new java.security.AccessControlContext
            dup
            iconst_1
            anewarray java.security.ProtectionDomain
            dup
            iconst_0
            aload 6 /* nullPD */
            aastore
            invokespecial java.security.AccessControlContext.<init>:([Ljava/security/ProtectionDomain;)V
            areturn
        end local 6 // java.security.ProtectionDomain nullPD
         6: .line 477
      StackMap locals: java.security.ProtectionDomain
      StackMap stack:
            new java.security.AccessControlContext
            dup
            aload 5 /* callerPD */
            aload 0 /* combiner */
            aload 2 /* parent */
         7: .line 478
            aload 3 /* context */
            aload 4 /* perms */
         8: .line 477
            invokespecial java.security.AccessControlContext.<init>:(Ljava/security/ProtectionDomain;Ljava/security/DomainCombiner;Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)V
            areturn
        end local 5 // java.security.ProtectionDomain callerPD
        end local 4 // java.security.Permission[] perms
        end local 3 // java.security.AccessControlContext context
        end local 2 // java.security.AccessControlContext parent
        end local 1 // java.lang.Class caller
        end local 0 // java.security.DomainCombiner combiner
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0  combiner  Ljava/security/DomainCombiner;
            0    9     1    caller  Ljava/lang/Class<*>;
            0    9     2    parent  Ljava/security/AccessControlContext;
            0    9     3   context  Ljava/security/AccessControlContext;
            0    9     4     perms  [Ljava/security/Permission;
            1    9     5  callerPD  Ljava/security/ProtectionDomain;
            5    6     6    nullPD  Ljava/security/ProtectionDomain;
    Signature: (Ljava/security/DomainCombiner;Ljava/lang/Class<*>;Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/security/AccessControlContext;
    MethodParameters:
          Name  Flags
      combiner  
      caller    
      parent    
      context   
      perms     

  private static java.security.ProtectionDomain getCallerPD(java.lang.Class<?>);
    descriptor: (Ljava/lang/Class;)Ljava/security/ProtectionDomain;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.lang.Class caller
         0: .line 484
            new java.security.AccessController$1
            dup
            aload 0 /* caller */
            invokespecial java.security.AccessController$1.<init>:(Ljava/lang/Class;)V
         1: .line 483
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.security.ProtectionDomain
            astore 1 /* callerPd */
        start local 1 // java.security.ProtectionDomain callerPd
         2: .line 490
            aload 1 /* callerPd */
            areturn
        end local 1 // java.security.ProtectionDomain callerPd
        end local 0 // java.lang.Class caller
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0    caller  Ljava/lang/Class<*>;
            2    3     1  callerPd  Ljava/security/ProtectionDomain;
    Signature: (Ljava/lang/Class<*>;)Ljava/security/ProtectionDomain;
    MethodParameters:
        Name  Flags
      caller  final

  public static native <T> T doPrivileged(java.security.PrivilegedExceptionAction<T>, java.security.AccessControlContext);
    descriptor: (Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0109) ACC_PUBLIC, ACC_STATIC, ACC_NATIVE
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;Ljava/security/AccessControlContext;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  

  static <T> T doPrivileged(java.security.PrivilegedExceptionAction<T>, java.security.AccessControlContext, java.security.Permission[]);
    descriptor: (Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/lang/Object;
    flags: (0x0088) ACC_STATIC, ACC_VARARGS
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // java.security.PrivilegedExceptionAction action
        start local 1 // java.security.AccessControlContext context
        start local 2 // java.security.Permission[] perms
         0: .line 579
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 580
            aload 2 /* perms */
            ifnonnull 3
         2: .line 581
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 583
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
            invokestatic sun.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 4 /* caller */
        start local 4 // java.lang.Class caller
         4: .line 584
            aload 0 /* action */
            aconst_null
            aload 4 /* caller */
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
            invokestatic java.security.AccessController.createWrapper:(Ljava/security/DomainCombiner;Ljava/lang/Class;Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/security/AccessControlContext;
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 4 // java.lang.Class caller
        end local 3 // java.security.AccessControlContext parent
        end local 2 // java.security.Permission[] perms
        end local 1 // java.security.AccessControlContext context
        end local 0 // java.security.PrivilegedExceptionAction action
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0   action  Ljava/security/PrivilegedExceptionAction<TT;>;
            0    5     1  context  Ljava/security/AccessControlContext;
            0    5     2    perms  [Ljava/security/Permission;
            1    5     3   parent  Ljava/security/AccessControlContext;
            4    5     4   caller  Ljava/lang/Class<*>;
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;Ljava/security/AccessControlContext;[Ljava/security/Permission;)TT;
    RuntimeVisibleAnnotations: 
      sun.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  
      perms    

  private static native java.security.AccessControlContext getStackAccessControlContext();
    descriptor: ()Ljava/security/AccessControlContext;
    flags: (0x010a) ACC_PRIVATE, ACC_STATIC, ACC_NATIVE

  static native java.security.AccessControlContext getInheritedAccessControlContext();
    descriptor: ()Ljava/security/AccessControlContext;
    flags: (0x0108) ACC_STATIC, ACC_NATIVE

  public static java.security.AccessControlContext getContext();
    descriptor: ()Ljava/security/AccessControlContext;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=1, args_size=0
         0: .line 621
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 0 /* acc */
        start local 0 // java.security.AccessControlContext acc
         1: .line 622
            aload 0 /* acc */
            ifnonnull 3
         2: .line 625
            new java.security.AccessControlContext
            dup
            aconst_null
            iconst_1
            invokespecial java.security.AccessControlContext.<init>:([Ljava/security/ProtectionDomain;Z)V
            areturn
         3: .line 627
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
            aload 0 /* acc */
            invokevirtual java.security.AccessControlContext.optimize:()Ljava/security/AccessControlContext;
            areturn
        end local 0 // java.security.AccessControlContext acc
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            1    4     0   acc  Ljava/security/AccessControlContext;

  public static void checkPermission(java.security.Permission);
    descriptor: (Ljava/security/Permission;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // java.security.Permission perm
         0: .line 653
            aload 0 /* perm */
            ifnonnull 2
         1: .line 654
            new java.lang.NullPointerException
            dup
            ldc "permission can't be null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 657
      StackMap locals:
      StackMap stack:
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* stack */
        start local 1 // java.security.AccessControlContext stack
         3: .line 659
            aload 1 /* stack */
            ifnonnull 21
         4: .line 660
            invokestatic java.security.AccessControlContext.getDebug:()Lsun/security/util/Debug;
            astore 2 /* debug */
        start local 2 // sun.security.util.Debug debug
         5: .line 661
            iconst_0
            istore 3 /* dumpDebug */
        start local 3 // boolean dumpDebug
         6: .line 662
            aload 2 /* debug */
            ifnull 14
         7: .line 663
            ldc "codebase="
            invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 8
            iconst_0
            goto 9
      StackMap locals: java.security.AccessControlContext sun.security.util.Debug int
      StackMap stack:
         8: iconst_1
      StackMap locals:
      StackMap stack: int
         9: istore 3 /* dumpDebug */
        10: .line 664
            iload 3 /* dumpDebug */
            ldc "permission="
            invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 12
        11: .line 665
            new java.lang.StringBuilder
            dup
            ldc "permission="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* perm */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getCanonicalName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
            ifne 12
            iconst_0
            goto 13
      StackMap locals:
      StackMap stack: int
        12: iconst_1
      StackMap locals: java.security.Permission java.security.AccessControlContext sun.security.util.Debug int
      StackMap stack: int int
        13: iand
            istore 3 /* dumpDebug */
        14: .line 668
      StackMap locals:
      StackMap stack:
            iload 3 /* dumpDebug */
            ifeq 16
            ldc "stack"
            invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 16
        15: .line 669
            invokestatic java.lang.Thread.dumpStack:()V
        16: .line 672
      StackMap locals:
      StackMap stack:
            iload 3 /* dumpDebug */
            ifeq 18
            ldc "domain"
            invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 18
        17: .line 673
            aload 2 /* debug */
            ldc "domain (context is null)"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        18: .line 676
      StackMap locals:
      StackMap stack:
            iload 3 /* dumpDebug */
            ifeq 20
        19: .line 677
            aload 2 /* debug */
            new java.lang.StringBuilder
            dup
            ldc "access allowed "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* perm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        20: .line 679
      StackMap locals:
      StackMap stack:
            return
        end local 3 // boolean dumpDebug
        end local 2 // sun.security.util.Debug debug
        21: .line 682
      StackMap locals:
      StackMap stack:
            aload 1 /* stack */
            invokevirtual java.security.AccessControlContext.optimize:()Ljava/security/AccessControlContext;
            astore 2 /* acc */
        start local 2 // java.security.AccessControlContext acc
        22: .line 683
            aload 2 /* acc */
            aload 0 /* perm */
            invokevirtual java.security.AccessControlContext.checkPermission:(Ljava/security/Permission;)V
        23: .line 684
            return
        end local 2 // java.security.AccessControlContext acc
        end local 1 // java.security.AccessControlContext stack
        end local 0 // java.security.Permission perm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   24     0       perm  Ljava/security/Permission;
            3   24     1      stack  Ljava/security/AccessControlContext;
            5   21     2      debug  Lsun/security/util/Debug;
            6   21     3  dumpDebug  Z
           22   24     2        acc  Ljava/security/AccessControlContext;
    Exceptions:
      throws java.security.AccessControlException
    MethodParameters:
      Name  Flags
      perm  
}
SourceFile: "AccessController.java"
NestMembers:
  java.security.AccessController$1
InnerClasses:
  java.security.AccessController$1