public final class jdk.dynalink.internal.AccessControlContextFactory
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: jdk.dynalink.internal.AccessControlContextFactory
  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 // jdk.dynalink.internal.AccessControlContextFactory this
         0: .line 38
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 39
            return
        end local 0 // jdk.dynalink.internal.AccessControlContextFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljdk/dynalink/internal/AccessControlContextFactory;

  public static java.security.AccessControlContext createAccessControlContext();
    descriptor: ()Ljava/security/AccessControlContext;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 46
            iconst_0
            anewarray java.security.Permission
            invokestatic jdk.dynalink.internal.AccessControlContextFactory.createAccessControlContext:([Ljava/security/Permission;)Ljava/security/AccessControlContext;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static java.security.AccessControlContext createAccessControlContext(java.security.Permission[]);
    descriptor: ([Ljava/security/Permission;)Ljava/security/AccessControlContext;
    flags: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
    Code:
      stack=9, locals=6, args_size=1
        start local 0 // java.security.Permission[] permissions
         0: .line 55
            new java.security.Permissions
            dup
            invokespecial java.security.Permissions.<init>:()V
            astore 1 /* perms */
        start local 1 // java.security.Permissions perms
         1: .line 56
            aload 0 /* permissions */
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 5
      StackMap locals: java.security.Permission[] java.security.Permissions top int int java.security.Permission[]
      StackMap stack:
         2: aload 5
            iload 3
            aaload
            astore 2 /* permission */
        start local 2 // java.security.Permission permission
         3: .line 57
            aload 1 /* perms */
            aload 2 /* permission */
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
        end local 2 // java.security.Permission permission
         4: .line 56
            iinc 3 1
      StackMap locals:
      StackMap stack:
         5: iload 3
            iload 4
            if_icmplt 2
         6: .line 59
            new java.security.AccessControlContext
            dup
            iconst_1
            anewarray java.security.ProtectionDomain
            dup
            iconst_0
            new java.security.ProtectionDomain
            dup
            aconst_null
            aload 1 /* perms */
            invokespecial java.security.ProtectionDomain.<init>:(Ljava/security/CodeSource;Ljava/security/PermissionCollection;)V
            aastore
            invokespecial java.security.AccessControlContext.<init>:([Ljava/security/ProtectionDomain;)V
            areturn
        end local 1 // java.security.Permissions perms
        end local 0 // java.security.Permission[] permissions
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0  permissions  [Ljava/security/Permission;
            1    7     1        perms  Ljava/security/Permissions;
            3    4     2   permission  Ljava/security/Permission;
    MethodParameters:
             Name  Flags
      permissions  final

  public static java.security.AccessControlContext createAccessControlContext(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)Ljava/security/AccessControlContext;
    flags: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.lang.String[] runtimePermissionNames
         0: .line 71
            aload 0 /* runtimePermissionNames */
            invokestatic jdk.dynalink.internal.AccessControlContextFactory.makeRuntimePermissions:([Ljava/lang/String;)[Ljava/security/Permission;
            invokestatic jdk.dynalink.internal.AccessControlContextFactory.createAccessControlContext:([Ljava/security/Permission;)Ljava/security/AccessControlContext;
            areturn
        end local 0 // java.lang.String[] runtimePermissionNames
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0    1     0  runtimePermissionNames  [Ljava/lang/String;
    MethodParameters:
                        Name  Flags
      runtimePermissionNames  final

  private static java.security.Permission[] makeRuntimePermissions(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)[Ljava/security/Permission;
    flags: (0x008a) ACC_PRIVATE, ACC_STATIC, ACC_VARARGS
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String[] runtimePermissionNames
         0: .line 75
            aload 0 /* runtimePermissionNames */
            invokestatic java.util.stream.Stream.of:([Ljava/lang/Object;)Ljava/util/stream/Stream;
            invokedynamic apply()Ljava/util/function/Function;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)Ljava/lang/Object;
                  java/lang/RuntimePermission.<init>(Ljava/lang/String;)V (8)
                  (Ljava/lang/String;)Ljava/lang/RuntimePermission;
            invokeinterface java.util.stream.Stream.map:(Ljava/util/function/Function;)Ljava/util/stream/Stream;
            invokedynamic apply()Ljava/util/function/IntFunction;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (I)Ljava/lang/Object;
                  jdk/dynalink/internal/AccessControlContextFactory.lambda$1(I)[Ljava/security/Permission; (6)
                  (I)[Ljava/security/Permission;
            invokeinterface java.util.stream.Stream.toArray:(Ljava/util/function/IntFunction;)[Ljava/lang/Object;
            checkcast java.security.Permission[]
            areturn
        end local 0 // java.lang.String[] runtimePermissionNames
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            0    1     0  runtimePermissionNames  [Ljava/lang/String;
    MethodParameters:
                        Name  Flags
      runtimePermissionNames  final

  private static java.security.Permission[] lambda$1(int);
    descriptor: (I)[Ljava/security/Permission;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            iload 0
            anewarray java.security.Permission
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "AccessControlContextFactory.java"
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles