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 270
            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: 
      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 328
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* acc */
        start local 1 // java.security.AccessControlContext acc
         1: .line 329
            aload 1 /* acc */
            ifnonnull 3
         2: .line 330
            aload 0 /* action */
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            areturn
         3: .line 332
      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 333
            aload 0 /* action */
         5: .line 334
            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 333
            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 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: 
      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=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 424
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 425
            aload 2 /* perms */
            ifnonnull 3
         2: .line 426
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 428
      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 429
            aload 0 /* action */
            aconst_null
         5: .line 430
            aload 4 /* caller */
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
         6: .line 429
            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: 
      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 486
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 487
            aload 3 /* parent */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
        start local 4 // java.security.DomainCombiner dc
         2: .line 488
            aload 4 /* dc */
            ifnonnull 4
            aload 1 /* context */
            ifnull 4
         3: .line 489
            aload 1 /* context */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
         4: .line 491
      StackMap locals: java.security.AccessControlContext java.security.DomainCombiner
      StackMap stack:
            aload 2 /* perms */
            ifnonnull 6
         5: .line 492
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 494
      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 495
            aload 0 /* action */
            aload 4 /* dc */
            aload 5 /* caller */
         8: .line 496
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
         9: .line 495
            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 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: 
      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 564
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* acc */
        start local 1 // java.security.AccessControlContext acc
         1: .line 565
            aload 1 /* acc */
            ifnonnull 3
         2: .line 566
            aload 0 /* action */
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            areturn
         3: .line 568
      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 569
            aload 0 /* action */
         5: .line 570
            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 569
            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 579
            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 590
            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 592
            aload 3 /* context */
            ifnull 5
            aload 3 /* context */
            invokevirtual java.security.AccessControlContext.isAuthorized:()Z
            ifne 5
         2: .line 593
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            ifnull 5
         3: .line 594
            aload 5 /* callerPD */
            invokevirtual java.security.ProtectionDomain.impliesCreateAccessControlContext:()Z
            ifne 5
         4: .line 596
            invokestatic java.security.AccessController.getInnocuousAcc:()Ljava/security/AccessControlContext;
            areturn
         5: .line 598
      StackMap locals: java.security.ProtectionDomain
      StackMap stack:
            new java.security.AccessControlContext
            dup
            aload 5 /* callerPD */
            aload 0 /* combiner */
            aload 2 /* parent */
         6: .line 599
            aload 3 /* context */
            aload 4 /* perms */
         7: .line 598
            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 611
            getstatic java.security.AccessController$AccHolder.innocuousAcc:Ljava/security/AccessControlContext;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  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 616
            new java.security.AccessController$1
            dup
            aload 0 /* caller */
            invokespecial java.security.AccessController$1.<init>:(Ljava/lang/Class;)V
         1: .line 615
            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 622
            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: 
      jdk.internal.reflect.CallerSensitive()
    MethodParameters:
         Name  Flags
      action   
      context  

  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=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 719
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 720
            aload 2 /* perms */
            ifnonnull 3
         2: .line 721
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 723
      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 724
            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: 
      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 784
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* parent */
        start local 3 // java.security.AccessControlContext parent
         1: .line 785
            aload 3 /* parent */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
        start local 4 // java.security.DomainCombiner dc
         2: .line 786
            aload 4 /* dc */
            ifnonnull 4
            aload 1 /* context */
            ifnull 4
         3: .line 787
            aload 1 /* context */
            invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
            astore 4 /* dc */
         4: .line 789
      StackMap locals: java.security.AccessControlContext java.security.DomainCombiner
      StackMap stack:
            aload 2 /* perms */
            ifnonnull 6
         5: .line 790
            new java.lang.NullPointerException
            dup
            ldc "null permissions parameter"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 792
      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 793
            aload 0 /* action */
            aload 4 /* dc */
            aload 5 /* caller */
         8: .line 794
            aload 3 /* parent */
            aload 1 /* context */
            aload 2 /* perms */
         9: .line 793
            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 831
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 0 /* acc */
        start local 0 // java.security.AccessControlContext acc
         1: .line 832
            aload 0 /* acc */
            ifnonnull 3
         2: .line 835
            new java.security.AccessControlContext
            dup
            aconst_null
            iconst_1
            invokespecial java.security.AccessControlContext.<init>:([Ljava/security/ProtectionDomain;Z)V
            areturn
         3: .line 837
      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 865
            aload 0 /* perm */
            ifnonnull 2
         1: .line 866
            new java.lang.NullPointerException
            dup
            ldc "permission can't be null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 869
      StackMap locals:
      StackMap stack:
            invokestatic java.security.AccessController.getStackAccessControlContext:()Ljava/security/AccessControlContext;
            astore 1 /* stack */
        start local 1 // java.security.AccessControlContext stack
         3: .line 871
            aload 1 /* stack */
            ifnonnull 21
         4: .line 872
            invokestatic java.security.AccessControlContext.getDebug:()Lsun/security/util/Debug;
            astore 2 /* debug */
        start local 2 // sun.security.util.Debug debug
         5: .line 873
            iconst_0
            istore 3 /* dumpDebug */
        start local 3 // boolean dumpDebug
         6: .line 874
            aload 2 /* debug */
            ifnull 14
         7: .line 875
            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 876
            iload 3 /* dumpDebug */
            ldc "permission="
            invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 12
        11: .line 877
            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 880
      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 881
            invokestatic java.lang.Thread.dumpStack:()V
        16: .line 884
      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 885
            aload 2 /* debug */
            ldc "domain (context is null)"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        18: .line 888
      StackMap locals:
      StackMap stack:
            iload 3 /* dumpDebug */
            ifeq 20
        19: .line 889
            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 891
      StackMap locals:
      StackMap stack:
            return
        end local 3 // boolean dumpDebug
        end local 2 // sun.security.util.Debug debug
        21: .line 894
      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 895
            aload 2 /* acc */
            aload 0 /* perm */
            invokevirtual java.security.AccessControlContext.checkPermission:(Ljava/security/Permission;)V
        23: .line 896
            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  java.security.AccessController$AccHolder
InnerClasses:
  java.security.AccessController$1
  private AccHolder = java.security.AccessController$AccHolder of java.security.AccessController