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
{
  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 276
            ldc Ljava/security/AccessController;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic java.security.AccessController.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  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 281
            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 <T> T doPrivileged(java.security.PrivilegedAction<T>);
    descriptor: (Ljava/security/PrivilegedAction;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.security.PrivilegedAction action
         0: .line 312
            aload 0 /* action */
            aconst_null
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            invokestatic java.security.AccessController.executePrivileged:(Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/lang/Object;
            areturn
        end local 0 // java.security.PrivilegedAction action
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0  action  Ljava/security/PrivilegedAction<TT;>;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.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 342
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* acc */
        start local 1 // java.security.AccessControlContext acc
         1: .line 343
            aload 1 /* acc */
            ifnonnull 3
         2: .line 344
            aload 0 /* action */
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            areturn
         3: .line 346
      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 347
            aload 0 /* action */
         5: .line 348
            aload 2 /* dc */
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            invokestatic java.security.AccessController.preserveCombiner:(Ljava/security/DomainCombiner;Ljava/lang/Class;)Ljava/security/AccessControlContext;
         6: .line 347
            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    7     0  action  Ljava/security/PrivilegedAction<TT;>;
            1    7     1     acc  Ljava/security/AccessControlContext;
            4    7     2      dc  Ljava/security/DomainCombiner;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.reflect.CallerSensitive()
    MethodParameters:
        Name  Flags
      action  

  public static <T> T doPrivileged(java.security.PrivilegedAction<T>, java.security.AccessControlContext);
    descriptor: (Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // java.security.PrivilegedAction action
        start local 1 // java.security.AccessControlContext context
         0: .line 389
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 2 /* caller */
        start local 2 // java.lang.Class caller
         1: .line 390
            aload 1 /* context */
            aload 2 /* caller */
            invokestatic java.security.AccessController.checkContext:(Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/security/AccessControlContext;
            astore 1 /* context */
         2: .line 391
            aload 0 /* action */
            aload 1 /* context */
            aload 2 /* caller */
            invokestatic java.security.AccessController.executePrivileged:(Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/lang/Object;
            areturn
        end local 2 // java.lang.Class caller
        end local 1 // java.security.AccessControlContext context
        end local 0 // java.security.PrivilegedAction action
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0   action  Ljava/security/PrivilegedAction<TT;>;
            0    3     1  context  Ljava/security/AccessControlContext;
            1    3     2   caller  Ljava/lang/Class<*>;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;Ljava/security/AccessControlContext;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  

  public 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: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
    Code:
      stack=6, locals=6, 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 443
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 444
            aload 2 /* perms */
            ifnonnull 3
         2: .line 445
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 447
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 4 /* caller */
        start local 4 // java.lang.Class caller
         4: .line 448
            aload 1 /* context */
            ifnonnull 5
            aconst_null
            goto 6
      StackMap locals: java.lang.Class
      StackMap stack:
         5: aload 1 /* context */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
      StackMap locals:
      StackMap stack: java.security.DomainCombiner
         6: astore 5 /* dc */
        start local 5 // java.security.DomainCombiner dc
         7: .line 449
            aload 0 /* action */
            aload 5 /* dc */
         8: .line 450
            aload 4 /* caller */
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
         9: .line 449
            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 5 // java.security.DomainCombiner dc
        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   10     0   action  Ljava/security/PrivilegedAction<TT;>;
            0   10     1  context  Ljava/security/AccessControlContext;
            0   10     2    perms  [Ljava/security/Permission;
            1   10     3   parent  Ljava/security/AccessControlContext;
            4   10     4   caller  Ljava/lang/Class<*>;
            7   10     5       dc  Ljava/security/DomainCombiner;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;Ljava/security/AccessControlContext;[Ljava/security/Permission;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  
      perms    

  public static <T> T doPrivilegedWithCombiner(java.security.PrivilegedAction<T>, java.security.AccessControlContext, java.security.Permission[]);
    descriptor: (Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/lang/Object;
    flags: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
    Code:
      stack=6, locals=6, 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 506
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 507
            aload 3 /* parent */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
        start local 4 // java.security.DomainCombiner dc
         2: .line 508
            aload 4 /* dc */
            ifnonnull 4
            aload 1 /* context */
            ifnull 4
         3: .line 509
            aload 1 /* context */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
         4: .line 511
      StackMap locals: java.security.AccessControlContext java.security.DomainCombiner
      StackMap stack:
            aload 2 /* perms */
            ifnonnull 6
         5: .line 512
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 514
      StackMap locals:
      StackMap stack:
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 5 /* caller */
        start local 5 // java.lang.Class caller
         7: .line 515
            aload 0 /* action */
            aload 4 /* dc */
            aload 5 /* caller */
         8: .line 516
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
         9: .line 515
            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 5 // java.lang.Class caller
        end local 4 // java.security.DomainCombiner dc
        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   10     0   action  Ljava/security/PrivilegedAction<TT;>;
            0   10     1  context  Ljava/security/AccessControlContext;
            0   10     2    perms  [Ljava/security/Permission;
            1   10     3   parent  Ljava/security/AccessControlContext;
            2   10     4       dc  Ljava/security/DomainCombiner;
            7   10     5   caller  Ljava/lang/Class<*>;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;Ljava/security/AccessControlContext;[Ljava/security/Permission;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  
      perms    

  public static <T> T doPrivileged(java.security.PrivilegedExceptionAction<T>);
    descriptor: (Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // java.security.PrivilegedExceptionAction action
         0: .line 551
            aconst_null
            astore 1 /* context */
        start local 1 // java.security.AccessControlContext context
         1: .line 552
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 2 /* caller */
        start local 2 // java.lang.Class caller
         2: .line 554
            aload 0 /* action */
            aload 1 /* context */
            aload 2 /* caller */
            invokestatic java.security.AccessController.executePrivileged:(Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/lang/Object;
         3: areturn
         4: .line 555
      StackMap locals: java.security.PrivilegedExceptionAction java.security.AccessControlContext java.lang.Class
      StackMap stack: java.lang.RuntimeException
            astore 3 /* e */
        start local 3 // java.lang.RuntimeException e
         5: .line 556
            aload 3 /* e */
            athrow
        end local 3 // java.lang.RuntimeException e
         6: .line 557
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 3 /* e */
        start local 3 // java.lang.Exception e
         7: .line 558
            aload 3 /* e */
            invokestatic java.security.AccessController.wrapException:(Ljava/lang/Exception;)Ljava/security/PrivilegedActionException;
            athrow
        end local 3 // java.lang.Exception e
        end local 2 // java.lang.Class caller
        end local 1 // java.security.AccessControlContext context
        end local 0 // java.security.PrivilegedExceptionAction action
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0   action  Ljava/security/PrivilegedExceptionAction<TT;>;
            1    8     1  context  Ljava/security/AccessControlContext;
            2    8     2   caller  Ljava/lang/Class<*>;
            5    6     3        e  Ljava/lang/RuntimeException;
            7    8     3        e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.RuntimeException
           2     3       6  Class java.lang.Exception
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.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 594
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* acc */
        start local 1 // java.security.AccessControlContext acc
         1: .line 595
            aload 1 /* acc */
            ifnonnull 3
         2: .line 596
            aload 0 /* action */
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            areturn
         3: .line 598
      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 599
            aload 0 /* action */
         5: .line 600
            aload 2 /* dc */
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            invokestatic java.security.AccessController.preserveCombiner:(Ljava/security/DomainCombiner;Ljava/lang/Class;)Ljava/security/AccessControlContext;
         6: .line 599
            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    7     0  action  Ljava/security/PrivilegedExceptionAction<TT;>;
            1    7     1     acc  Ljava/security/AccessControlContext;
            4    7     2      dc  Ljava/security/DomainCombiner;
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.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 609
            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    

  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=6, 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 620
            aload 1 /* caller */
            invokestatic java.security.AccessController.getProtectionDomain:(Ljava/lang/Class;)Ljava/security/ProtectionDomain;
            astore 5 /* callerPD */
        start local 5 // java.security.ProtectionDomain callerPD
         1: .line 622
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            ifnull 5
         2: .line 623
            aload 3 /* context */
            ifnull 5
            aload 3 /* context */
            invokevirtual java.security.AccessControlContext.isAuthorized:()Z
            ifne 5
         3: .line 624
            aload 5 /* callerPD */
            getstatic sun.security.util.SecurityConstants.CREATE_ACC_PERMISSION:Ljava/security/SecurityPermission;
            invokevirtual java.security.ProtectionDomain.implies:(Ljava/security/Permission;)Z
            ifne 5
         4: .line 626
            invokestatic java.security.AccessController.getInnocuousAcc:()Ljava/security/AccessControlContext;
            areturn
         5: .line 628
      StackMap locals: java.security.ProtectionDomain
      StackMap stack:
            new java.security.AccessControlContext
            dup
            aload 5 /* callerPD */
            aload 0 /* combiner */
            aload 2 /* parent */
         6: .line 629
            aload 3 /* context */
            aload 4 /* perms */
         7: .line 628
            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    8     0  combiner  Ljava/security/DomainCombiner;
            0    8     1    caller  Ljava/lang/Class<*>;
            0    8     2    parent  Ljava/security/AccessControlContext;
            0    8     3   context  Ljava/security/AccessControlContext;
            0    8     4     perms  [Ljava/security/Permission;
            1    8     5  callerPD  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.AccessControlContext getInnocuousAcc();
    descriptor: ()Ljava/security/AccessControlContext;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 641
            getstatic java.security.AccessController$AccHolder.innocuousAcc:Ljava/security/AccessControlContext;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static native java.security.ProtectionDomain getProtectionDomain(java.lang.Class<?>);
    descriptor: (Ljava/lang/Class;)Ljava/security/ProtectionDomain;
    flags: (0x010a) ACC_PRIVATE, ACC_STATIC, ACC_NATIVE
    Signature: (Ljava/lang/Class<*>;)Ljava/security/ProtectionDomain;
    MethodParameters:
        Name  Flags
      caller  final

  public static <T> T doPrivileged(java.security.PrivilegedExceptionAction<T>, java.security.AccessControlContext);
    descriptor: (Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // java.security.PrivilegedExceptionAction action
        start local 1 // java.security.AccessControlContext context
         0: .line 688
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 2 /* caller */
        start local 2 // java.lang.Class caller
         1: .line 689
            aload 1 /* context */
            aload 2 /* caller */
            invokestatic java.security.AccessController.checkContext:(Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/security/AccessControlContext;
            astore 1 /* context */
         2: .line 691
            aload 0 /* action */
            aload 1 /* context */
            aload 2 /* caller */
            invokestatic java.security.AccessController.executePrivileged:(Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/lang/Object;
         3: areturn
         4: .line 692
      StackMap locals: java.security.PrivilegedExceptionAction java.security.AccessControlContext java.lang.Class
      StackMap stack: java.lang.RuntimeException
            astore 3 /* e */
        start local 3 // java.lang.RuntimeException e
         5: .line 693
            aload 3 /* e */
            athrow
        end local 3 // java.lang.RuntimeException e
         6: .line 694
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 3 /* e */
        start local 3 // java.lang.Exception e
         7: .line 695
            aload 3 /* e */
            invokestatic java.security.AccessController.wrapException:(Ljava/lang/Exception;)Ljava/security/PrivilegedActionException;
            athrow
        end local 3 // java.lang.Exception e
        end local 2 // java.lang.Class caller
        end local 1 // java.security.AccessControlContext context
        end local 0 // java.security.PrivilegedExceptionAction action
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0   action  Ljava/security/PrivilegedExceptionAction<TT;>;
            0    8     1  context  Ljava/security/AccessControlContext;
            1    8     2   caller  Ljava/lang/Class<*>;
            5    6     3        e  Ljava/lang/RuntimeException;
            7    8     3        e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.RuntimeException
           2     3       6  Class java.lang.Exception
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;Ljava/security/AccessControlContext;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  

  private static java.security.AccessControlContext checkContext(java.security.AccessControlContext, java.lang.Class<?>);
    descriptor: (Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/security/AccessControlContext;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // java.security.AccessControlContext context
        start local 1 // java.lang.Class caller
         0: .line 703
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            ifnull 6
         1: .line 704
            aload 0 /* context */
            ifnull 6
            aload 0 /* context */
            invokevirtual java.security.AccessControlContext.isAuthorized:()Z
            ifne 6
         2: .line 705
            aload 0 /* context */
            invokestatic java.security.AccessController.getInnocuousAcc:()Ljava/security/AccessControlContext;
            if_acmpeq 6
         3: .line 707
            aload 1 /* caller */
            invokestatic java.security.AccessController.getProtectionDomain:(Ljava/lang/Class;)Ljava/security/ProtectionDomain;
            astore 2 /* callerPD */
        start local 2 // java.security.ProtectionDomain callerPD
         4: .line 708
            aload 2 /* callerPD */
            ifnull 6
            aload 2 /* callerPD */
            getstatic sun.security.util.SecurityConstants.CREATE_ACC_PERMISSION:Ljava/security/SecurityPermission;
            invokevirtual java.security.ProtectionDomain.implies:(Ljava/security/Permission;)Z
            ifne 6
         5: .line 709
            invokestatic java.security.AccessController.getInnocuousAcc:()Ljava/security/AccessControlContext;
            areturn
        end local 2 // java.security.ProtectionDomain callerPD
         6: .line 712
      StackMap locals:
      StackMap stack:
            aload 0 /* context */
            areturn
        end local 1 // java.lang.Class caller
        end local 0 // java.security.AccessControlContext context
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0   context  Ljava/security/AccessControlContext;
            0    7     1    caller  Ljava/lang/Class<*>;
            4    6     2  callerPD  Ljava/security/ProtectionDomain;
    Signature: (Ljava/security/AccessControlContext;Ljava/lang/Class<*>;)Ljava/security/AccessControlContext;
    MethodParameters:
         Name  Flags
      context  
      caller   

  private static native void ensureMaterializedForStackWalk(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x010a) ACC_PRIVATE, ACC_STATIC, ACC_NATIVE
    RuntimeVisibleAnnotations: 
      jdk.internal.vm.annotation.Hidden()
    MethodParameters:
      Name  Flags
      o     

  private static boolean isPrivileged();
    descriptor: ()Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=0
         0: .line 729
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 0 /* ctx */
        start local 0 // java.security.AccessControlContext ctx
         1: .line 730
            aload 0 /* ctx */
            ifnull 2
            aload 0 /* ctx */
            invokevirtual java.security.AccessControlContext.isPrivileged:()Z
            ifne 2
            iconst_0
            ireturn
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
         2: iconst_1
            ireturn
        end local 0 // java.security.AccessControlContext ctx
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            1    3     0   ctx  Ljava/security/AccessControlContext;

  private static <T> T executePrivileged(java.security.PrivilegedAction<T>, java.security.AccessControlContext, java.lang.Class<?>);
    descriptor: (Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/lang/Object;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // java.security.PrivilegedAction action
        start local 1 // java.security.AccessControlContext context
        start local 2 // java.lang.Class caller
         0: .line 748
            aload 1 /* context */
            ifnull 2
         1: .line 749
            aload 1 /* context */
            invokestatic java.security.AccessController.ensureMaterializedForStackWalk:(Ljava/lang/Object;)V
         2: .line 752
      StackMap locals:
      StackMap stack:
            getstatic java.security.AccessController.$assertionsDisabled:Z
            ifne 3
            invokestatic java.security.AccessController.isPrivileged:()Z
            ifne 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 753
      StackMap locals:
      StackMap stack:
            aload 0 /* action */
            invokeinterface java.security.PrivilegedAction.run:()Ljava/lang/Object;
            astore 3 /* result */
        start local 3 // java.lang.Object result
         4: .line 754
            getstatic java.security.AccessController.$assertionsDisabled:Z
            ifne 5
            invokestatic java.security.AccessController.isPrivileged:()Z
            ifne 5
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         5: .line 758
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 1 /* context */
            invokestatic java.lang.ref.Reference.reachabilityFence:(Ljava/lang/Object;)V
         6: .line 759
            aload 2 /* caller */
            invokestatic java.lang.ref.Reference.reachabilityFence:(Ljava/lang/Object;)V
         7: .line 760
            aload 3 /* result */
            areturn
        end local 3 // java.lang.Object result
        end local 2 // java.lang.Class caller
        end local 1 // java.security.AccessControlContext context
        end local 0 // java.security.PrivilegedAction action
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0   action  Ljava/security/PrivilegedAction<TT;>;
            0    8     1  context  Ljava/security/AccessControlContext;
            0    8     2   caller  Ljava/lang/Class<*>;
            4    8     3   result  TT;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedAction<TT;>;Ljava/security/AccessControlContext;Ljava/lang/Class<*>;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.vm.annotation.Hidden()
      jdk.internal.vm.annotation.ForceInline()
    MethodParameters:
         Name  Flags
      action   
      context  
      caller   

  private static <T> T executePrivileged(java.security.PrivilegedExceptionAction<T>, java.security.AccessControlContext, java.lang.Class<?>);
    descriptor: (Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;Ljava/lang/Class;)Ljava/lang/Object;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // java.security.PrivilegedExceptionAction action
        start local 1 // java.security.AccessControlContext context
        start local 2 // java.lang.Class caller
         0: .line 779
            aload 1 /* context */
            ifnull 2
         1: .line 780
            aload 1 /* context */
            invokestatic java.security.AccessController.ensureMaterializedForStackWalk:(Ljava/lang/Object;)V
         2: .line 783
      StackMap locals:
      StackMap stack:
            getstatic java.security.AccessController.$assertionsDisabled:Z
            ifne 3
            invokestatic java.security.AccessController.isPrivileged:()Z
            ifne 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 784
      StackMap locals:
      StackMap stack:
            aload 0 /* action */
            invokeinterface java.security.PrivilegedExceptionAction.run:()Ljava/lang/Object;
            astore 3 /* result */
        start local 3 // java.lang.Object result
         4: .line 785
            getstatic java.security.AccessController.$assertionsDisabled:Z
            ifne 5
            invokestatic java.security.AccessController.isPrivileged:()Z
            ifne 5
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         5: .line 789
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 1 /* context */
            invokestatic java.lang.ref.Reference.reachabilityFence:(Ljava/lang/Object;)V
         6: .line 790
            aload 2 /* caller */
            invokestatic java.lang.ref.Reference.reachabilityFence:(Ljava/lang/Object;)V
         7: .line 791
            aload 3 /* result */
            areturn
        end local 3 // java.lang.Object result
        end local 2 // java.lang.Class caller
        end local 1 // java.security.AccessControlContext context
        end local 0 // java.security.PrivilegedExceptionAction action
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0   action  Ljava/security/PrivilegedExceptionAction<TT;>;
            0    8     1  context  Ljava/security/AccessControlContext;
            0    8     2   caller  Ljava/lang/Class<*>;
            4    8     3   result  TT;
    Exceptions:
      throws java.lang.Exception
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;Ljava/security/AccessControlContext;Ljava/lang/Class<*>;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.vm.annotation.Hidden()
      jdk.internal.vm.annotation.ForceInline()
    MethodParameters:
         Name  Flags
      action   
      context  
      caller   

  private static java.security.PrivilegedActionException wrapException(java.lang.Exception);
    descriptor: (Ljava/lang/Exception;)Ljava/security/PrivilegedActionException;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.lang.Exception e
         0: .line 805
            new java.security.PrivilegedActionException
            dup
            aload 0 /* e */
            invokespecial java.security.PrivilegedActionException.<init>:(Ljava/lang/Exception;)V
            areturn
        end local 0 // java.lang.Exception e
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0     e  Ljava/lang/Exception;
    RuntimeVisibleAnnotations: 
      jdk.internal.vm.annotation.Hidden()
      jdk.internal.vm.annotation.ForceInline()
      jdk.internal.vm.annotation.ReservedStackAccess()
    MethodParameters:
      Name  Flags
      e     

  public 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: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
    Code:
      stack=6, locals=6, 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 859
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 860
            aload 2 /* perms */
            ifnonnull 3
         2: .line 861
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 863
      StackMap locals: java.security.AccessControlContext
      StackMap stack:
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 4 /* caller */
        start local 4 // java.lang.Class caller
         4: .line 864
            aload 1 /* context */
            ifnonnull 5
            aconst_null
            goto 6
      StackMap locals: java.lang.Class
      StackMap stack:
         5: aload 1 /* context */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
      StackMap locals:
      StackMap stack: java.security.DomainCombiner
         6: astore 5 /* dc */
        start local 5 // java.security.DomainCombiner dc
         7: .line 865
            aload 0 /* action */
            aload 5 /* dc */
            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 5 // java.security.DomainCombiner dc
        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    8     0   action  Ljava/security/PrivilegedExceptionAction<TT;>;
            0    8     1  context  Ljava/security/AccessControlContext;
            0    8     2    perms  [Ljava/security/Permission;
            1    8     3   parent  Ljava/security/AccessControlContext;
            4    8     4   caller  Ljava/lang/Class<*>;
            7    8     5       dc  Ljava/security/DomainCombiner;
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;Ljava/security/AccessControlContext;[Ljava/security/Permission;)TT;
    RuntimeVisibleAnnotations: 
      jdk.internal.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  
      perms    

  public static <T> T doPrivilegedWithCombiner(java.security.PrivilegedExceptionAction<T>, java.security.AccessControlContext, java.security.Permission[]);
    descriptor: (Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/lang/Object;
    flags: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
    Code:
      stack=6, locals=6, 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 925
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 926
            aload 3 /* parent */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
        start local 4 // java.security.DomainCombiner dc
         2: .line 927
            aload 4 /* dc */
            ifnonnull 4
            aload 1 /* context */
            ifnull 4
         3: .line 928
            aload 1 /* context */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
         4: .line 930
      StackMap locals: java.security.AccessControlContext java.security.DomainCombiner
      StackMap stack:
            aload 2 /* perms */
            ifnonnull 6
         5: .line 931
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 933
      StackMap locals:
      StackMap stack:
            invokestatic jdk.internal.reflect.Reflection.getCallerClass:()Ljava/lang/Class;
            astore 5 /* caller */
        start local 5 // java.lang.Class caller
         7: .line 934
            aload 0 /* action */
            aload 4 /* dc */
            aload 5 /* caller */
         8: .line 935
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
         9: .line 934
            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 5 // java.lang.Class caller
        end local 4 // java.security.DomainCombiner dc
        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   10     0   action  Ljava/security/PrivilegedExceptionAction<TT;>;
            0   10     1  context  Ljava/security/AccessControlContext;
            0   10     2    perms  [Ljava/security/Permission;
            1   10     3   parent  Ljava/security/AccessControlContext;
            2   10     4       dc  Ljava/security/DomainCombiner;
            7   10     5   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: 
      jdk.internal.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 972
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 0 /* acc */
        start local 0 // java.security.AccessControlContext acc
         1: .line 973
            aload 0 /* acc */
            ifnonnull 3
         2: .line 976
            new java.security.AccessControlContext
            dup
            aconst_null
            iconst_1
            invokespecial java.security.AccessControlContext.<init>:([Ljava/security/ProtectionDomain;Z)V
            areturn
         3: .line 978
      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 1006
            aload 0 /* perm */
            ifnonnull 2
         1: .line 1007
            new java.lang.NullPointerException
            dup
            ldc "permission can't be null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 1010
      StackMap locals:
      StackMap stack:
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* stack */
        start local 1 // java.security.AccessControlContext stack
         3: .line 1012
            aload 1 /* stack */
            ifnonnull 21
         4: .line 1013
            invokestatic java.security.AccessControlContext.getDebug:()Lsun/security/util/Debug;
            astore 2 /* debug */
        start local 2 // sun.security.util.Debug debug
         5: .line 1014
            iconst_0
            istore 3 /* dumpDebug */
        start local 3 // boolean dumpDebug
         6: .line 1015
            aload 2 /* debug */
            ifnull 14
         7: .line 1016
            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 1017
            iload 3 /* dumpDebug */
            ldc "permission="
            invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 12
        11: .line 1018
            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 1021
      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 1022
            invokestatic java.lang.Thread.dumpStack:()V
        16: .line 1025
      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 1026
            aload 2 /* debug */
            ldc "domain (context is null)"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        18: .line 1029
      StackMap locals:
      StackMap stack:
            iload 3 /* dumpDebug */
            ifeq 20
        19: .line 1030
            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 1032
      StackMap locals:
      StackMap stack:
            return
        end local 3 // boolean dumpDebug
        end local 2 // sun.security.util.Debug debug
        21: .line 1035
      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 1036
            aload 2 /* acc */
            aload 0 /* perm */
            invokevirtual java.security.AccessControlContext.checkPermission:(Ljava/security/Permission;)V
        23: .line 1037
            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$AccHolder
InnerClasses:
  private AccHolder = java.security.AccessController$AccHolder of java.security.AccessController