public final class java.security.AccessControlContext
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: java.security.AccessControlContext
super_class: java.lang.Object
{
private java.security.ProtectionDomain[] context;
descriptor: [Ljava/security/ProtectionDomain;
flags: (0x0002) ACC_PRIVATE
private boolean isPrivileged;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private boolean isAuthorized;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private java.security.AccessControlContext privilegedContext;
descriptor: Ljava/security/AccessControlContext;
flags: (0x0002) ACC_PRIVATE
private java.security.DomainCombiner combiner;
descriptor: Ljava/security/DomainCombiner;
flags: (0x0002) ACC_PRIVATE
private java.security.Permission[] permissions;
descriptor: [Ljava/security/Permission;
flags: (0x0002) ACC_PRIVATE
private java.security.AccessControlContext parent;
descriptor: Ljava/security/AccessControlContext;
flags: (0x0002) ACC_PRIVATE
private boolean isWrapped;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private boolean isLimited;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private java.security.ProtectionDomain[] limitedContext;
descriptor: [Ljava/security/ProtectionDomain;
flags: (0x0002) ACC_PRIVATE
private static boolean debugInit;
descriptor: Z
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
private static sun.security.util.Debug debug;
descriptor: Lsun/security/util/Debug;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: iconst_0
putstatic java.security.AccessControlContext.debugInit:Z
1: aconst_null
putstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
return
LocalVariableTable:
Start End Slot Name Signature
static sun.security.util.Debug getDebug();
descriptor: ()Lsun/security/util/Debug;
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: getstatic java.security.AccessControlContext.debugInit:Z
ifeq 2
1: getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
areturn
2: StackMap locals:
StackMap stack:
invokestatic java.security.Policy.isSet:()Z
ifeq 5
3: ldc "access"
invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
putstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
4: iconst_1
putstatic java.security.AccessControlContext.debugInit:Z
5: StackMap locals:
StackMap stack:
getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
areturn
LocalVariableTable:
Start End Slot Name Signature
public void <init>(java.security.ProtectionDomain[]);
descriptor: ([Ljava/security/ProtectionDomain;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield java.security.AccessControlContext.isAuthorized:Z
2: aload 0
aconst_null
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
3: aload 1
arraylength
ifne 6
4: aload 0
aconst_null
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
5: goto 22
StackMap locals: java.security.AccessControlContext java.security.ProtectionDomain[]
StackMap stack:
6: aload 1
arraylength
iconst_1
if_icmpne 12
7: aload 1
iconst_0
aaload
ifnull 10
8: aload 0
aload 1
invokevirtual java.security.ProtectionDomain[].clone:()Ljava/lang/Object;
checkcast java.security.ProtectionDomain[]
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
9: goto 22
10: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
11: goto 22
12: StackMap locals:
StackMap stack:
new java.util.ArrayList
dup
aload 1
arraylength
invokespecial java.util.ArrayList.<init>:(I)V
astore 2
start local 2 13: iconst_0
istore 3
start local 3 14: goto 18
15: StackMap locals: java.util.List int
StackMap stack:
aload 1
iload 3
aaload
ifnull 17
aload 2
aload 1
iload 3
aaload
invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
ifne 17
16: aload 2
aload 1
iload 3
aaload
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
17: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
18: iload 3
aload 1
arraylength
if_icmplt 15
end local 3 19: aload 2
invokeinterface java.util.List.isEmpty:()Z
ifne 22
20: aload 0
aload 2
invokeinterface java.util.List.size:()I
anewarray java.security.ProtectionDomain
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
21: aload 0
aload 2
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
checkcast java.security.ProtectionDomain[]
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
end local 2 22: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 23 0 this Ljava/security/AccessControlContext;
0 23 1 context [Ljava/security/ProtectionDomain;
13 22 2 v Ljava/util/List<Ljava/security/ProtectionDomain;>;
14 19 3 i I
MethodParameters:
Name Flags
context
public void <init>(java.security.AccessControlContext, java.security.DomainCombiner);
descriptor: (Ljava/security/AccessControlContext;Ljava/security/DomainCombiner;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
aload 2
iconst_0
invokespecial java.security.AccessControlContext.<init>:(Ljava/security/AccessControlContext;Ljava/security/DomainCombiner;Z)V
1: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/security/AccessControlContext;
0 2 1 acc Ljava/security/AccessControlContext;
0 2 2 combiner Ljava/security/DomainCombiner;
MethodParameters:
Name Flags
acc
combiner
void <init>(java.security.AccessControlContext, java.security.DomainCombiner, boolean);
descriptor: (Ljava/security/AccessControlContext;Ljava/security/DomainCombiner;Z)V
flags: (0x0000)
Code:
stack=2, locals=5, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield java.security.AccessControlContext.isAuthorized:Z
2: aload 0
aconst_null
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
3: iload 3
ifne 9
4: invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
astore 4
start local 4 5: aload 4
ifnull 10
6: aload 4
getstatic sun.security.util.SecurityConstants.CREATE_ACC_PERMISSION:Ljava/security/SecurityPermission;
invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
7: aload 0
iconst_1
putfield java.security.AccessControlContext.isAuthorized:Z
end local 4 8: goto 10
9: StackMap locals: java.security.AccessControlContext java.security.AccessControlContext java.security.DomainCombiner int
StackMap stack:
aload 0
iconst_1
putfield java.security.AccessControlContext.isAuthorized:Z
10: StackMap locals:
StackMap stack:
aload 0
aload 1
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
11: aload 0
aload 2
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
12: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Ljava/security/AccessControlContext;
0 13 1 acc Ljava/security/AccessControlContext;
0 13 2 combiner Ljava/security/DomainCombiner;
0 13 3 preauthorized Z
5 8 4 sm Ljava/lang/SecurityManager;
MethodParameters:
Name Flags
acc
combiner
preauthorized
void <init>(java.security.ProtectionDomain, java.security.DomainCombiner, java.security.AccessControlContext, java.security.AccessControlContext, java.security.Permission[]);
descriptor: (Ljava/security/ProtectionDomain;Ljava/security/DomainCombiner;Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)V
flags: (0x0000)
Code:
stack=4, locals=9, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield java.security.AccessControlContext.isAuthorized:Z
2: aload 0
aconst_null
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
3: aconst_null
astore 6
start local 6 4: aload 1
ifnull 6
5: iconst_1
anewarray java.security.ProtectionDomain
dup
iconst_0
aload 1
aastore
astore 6
6: StackMap locals: java.security.AccessControlContext java.security.ProtectionDomain java.security.DomainCombiner java.security.AccessControlContext java.security.AccessControlContext java.security.Permission[] java.security.ProtectionDomain[]
StackMap stack:
aload 4
ifnull 12
7: aload 2
ifnull 10
8: aload 0
aload 2
aload 6
aload 4
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
invokeinterface java.security.DomainCombiner.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
9: goto 16
10: StackMap locals:
StackMap stack:
aload 0
aload 6
aload 4
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
invokestatic java.security.AccessControlContext.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
11: goto 16
12: StackMap locals:
StackMap stack:
aload 2
ifnull 15
13: aload 0
aload 2
aload 6
aconst_null
invokeinterface java.security.DomainCombiner.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
14: goto 16
15: StackMap locals:
StackMap stack:
aload 0
aload 6
aconst_null
invokestatic java.security.AccessControlContext.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
16: StackMap locals:
StackMap stack:
aload 0
aload 2
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
17: aconst_null
astore 7
start local 7 18: aload 5
ifnull 29
19: aload 5
arraylength
anewarray java.security.Permission
astore 7
20: iconst_0
istore 8
start local 8 21: goto 28
22: StackMap locals: java.security.Permission[] int
StackMap stack:
aload 5
iload 8
aaload
ifnonnull 24
23: new java.lang.NullPointerException
dup
ldc "permission can't be null"
invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
athrow
24: StackMap locals:
StackMap stack:
aload 5
iload 8
aaload
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
ldc Ljava/security/AllPermission;
if_acmpne 26
25: aconst_null
astore 3
26: StackMap locals:
StackMap stack:
aload 7
iload 8
aload 5
iload 8
aaload
invokestatic sun.security.util.FilePermCompat.newPermPlusAltPath:(Ljava/security/Permission;)Ljava/security/Permission;
aastore
27: iinc 8 1
StackMap locals:
StackMap stack:
28: iload 8
aload 5
arraylength
if_icmplt 22
end local 8 29: StackMap locals:
StackMap stack:
aload 3
ifnull 36
30: aload 0
aload 3
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
aload 3
getfield java.security.AccessControlContext.limitedContext:[Ljava/security/ProtectionDomain;
invokestatic java.security.AccessControlContext.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
putfield java.security.AccessControlContext.limitedContext:[Ljava/security/ProtectionDomain;
31: aload 0
iconst_1
putfield java.security.AccessControlContext.isLimited:Z
32: aload 0
iconst_1
putfield java.security.AccessControlContext.isWrapped:Z
33: aload 0
aload 7
putfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
34: aload 0
aload 3
putfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
35: aload 0
aload 4
putfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
36: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield java.security.AccessControlContext.isAuthorized:Z
37: return
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 38 0 this Ljava/security/AccessControlContext;
0 38 1 caller Ljava/security/ProtectionDomain;
0 38 2 combiner Ljava/security/DomainCombiner;
0 38 3 parent Ljava/security/AccessControlContext;
0 38 4 context Ljava/security/AccessControlContext;
0 38 5 perms [Ljava/security/Permission;
4 38 6 callerPDs [Ljava/security/ProtectionDomain;
18 38 7 tmp [Ljava/security/Permission;
21 29 8 i I
MethodParameters:
Name Flags
caller
combiner
parent
context
perms
void <init>(java.security.ProtectionDomain[], boolean);
descriptor: ([Ljava/security/ProtectionDomain;Z)V
flags: (0x0000)
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield java.security.AccessControlContext.isAuthorized:Z
2: aload 0
aconst_null
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
3: aload 0
aload 1
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
4: aload 0
iload 2
putfield java.security.AccessControlContext.isPrivileged:Z
5: aload 0
iconst_1
putfield java.security.AccessControlContext.isAuthorized:Z
6: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Ljava/security/AccessControlContext;
0 7 1 context [Ljava/security/ProtectionDomain;
0 7 2 isPrivileged Z
MethodParameters:
Name Flags
context
isPrivileged
void <init>(java.security.ProtectionDomain[], java.security.AccessControlContext);
descriptor: ([Ljava/security/ProtectionDomain;Ljava/security/AccessControlContext;)V
flags: (0x0000)
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield java.security.AccessControlContext.isAuthorized:Z
2: aload 0
aconst_null
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
3: aload 0
aload 1
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
4: aload 0
aload 2
putfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
5: aload 0
iconst_1
putfield java.security.AccessControlContext.isPrivileged:Z
6: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Ljava/security/AccessControlContext;
0 7 1 context [Ljava/security/ProtectionDomain;
0 7 2 privilegedContext Ljava/security/AccessControlContext;
MethodParameters:
Name Flags
context
privilegedContext
java.security.ProtectionDomain[] getContext();
descriptor: ()[Ljava/security/ProtectionDomain;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/AccessControlContext;
boolean isPrivileged();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield java.security.AccessControlContext.isPrivileged:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/AccessControlContext;
java.security.DomainCombiner getAssignedCombiner();
descriptor: ()Ljava/security/DomainCombiner;
flags: (0x0000)
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
getfield java.security.AccessControlContext.isPrivileged:Z
ifeq 3
1: aload 0
getfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
astore 1
start local 1 2: goto 4
end local 1 3: StackMap locals:
StackMap stack:
invokestatic java.security.AccessController.getInheritedAccessControlContext:()Ljava/security/AccessControlContext;
astore 1
start local 1 4: StackMap locals: java.security.AccessControlContext
StackMap stack:
aload 1
ifnull 6
5: aload 1
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
areturn
6: StackMap locals:
StackMap stack:
aconst_null
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Ljava/security/AccessControlContext;
2 3 1 acc Ljava/security/AccessControlContext;
4 7 1 acc Ljava/security/AccessControlContext;
public java.security.DomainCombiner getDomainCombiner();
descriptor: ()Ljava/security/DomainCombiner;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
astore 1
start local 1 1: aload 1
ifnull 3
2: aload 1
getstatic sun.security.util.SecurityConstants.GET_COMBINER_PERMISSION:Ljava/security/SecurityPermission;
invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
3: StackMap locals: java.lang.SecurityManager
StackMap stack:
aload 0
invokevirtual java.security.AccessControlContext.getCombiner:()Ljava/security/DomainCombiner;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/security/AccessControlContext;
1 4 1 sm Ljava/lang/SecurityManager;
java.security.DomainCombiner getCombiner();
descriptor: ()Ljava/security/DomainCombiner;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/AccessControlContext;
boolean isAuthorized();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield java.security.AccessControlContext.isAuthorized:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/AccessControlContext;
public void checkPermission(java.security.Permission);
descriptor: (Ljava/security/Permission;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=6, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: aload 1
ifnonnull 3
2: new java.lang.NullPointerException
dup
ldc "permission can't be null"
invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: int
StackMap stack:
invokestatic java.security.AccessControlContext.getDebug:()Lsun/security/util/Debug;
ifnull 32
4: ldc "codebase="
invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
ifeq 5
iconst_0
goto 6
StackMap locals:
StackMap stack:
5: iconst_1
StackMap locals:
StackMap stack: int
6: istore 2
7: iload 2
ifne 17
8: iconst_0
istore 3
start local 3 9: goto 16
10: StackMap locals: int
StackMap stack:
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 3
aaload
invokevirtual java.security.ProtectionDomain.getCodeSource:()Ljava/security/CodeSource;
ifnull 15
11: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 3
aaload
invokevirtual java.security.ProtectionDomain.getCodeSource:()Ljava/security/CodeSource;
invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
ifnull 15
12: new java.lang.StringBuilder
dup
ldc "codebase="
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 3
aaload
invokevirtual java.security.ProtectionDomain.getCodeSource:()Ljava/security/CodeSource;
invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
invokevirtual java.net.URL.toString:()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
ifeq 15
13: iconst_1
istore 2
14: goto 17
15: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
16: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
ifnull 17
iload 3
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
arraylength
if_icmplt 10
end local 3 17: StackMap locals:
StackMap stack:
iload 2
ldc "permission="
invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
ifeq 19
18: new java.lang.StringBuilder
dup
ldc "permission="
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
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 19
iconst_0
goto 20
StackMap locals:
StackMap stack: int
19: iconst_1
StackMap locals: java.security.AccessControlContext java.security.Permission int
StackMap stack: int int
20: iand
istore 2
21: iload 2
ifeq 23
ldc "stack"
invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
ifeq 23
22: invokestatic java.lang.Thread.dumpStack:()V
23: StackMap locals:
StackMap stack:
iload 2
ifeq 32
ldc "domain"
invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
ifeq 32
24: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
ifnonnull 27
25: getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
ldc "domain (context is null)"
invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
26: goto 32
27: StackMap locals:
StackMap stack:
iconst_0
istore 3
start local 3 28: goto 31
29: StackMap locals: int
StackMap stack:
getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
new java.lang.StringBuilder
dup
ldc "domain "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 3
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc " "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 3
aaload
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
30: iinc 3 1
StackMap locals:
StackMap stack:
31: iload 3
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
arraylength
if_icmplt 29
end local 3 32: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
ifnonnull 35
33: aload 0
aload 1
invokevirtual java.security.AccessControlContext.checkPermission2:(Ljava/security/Permission;)V
34: return
35: StackMap locals:
StackMap stack:
iconst_0
istore 3
start local 3 36: goto 49
37: StackMap locals: int
StackMap stack:
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 3
aaload
ifnull 48
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 3
aaload
aload 1
invokevirtual java.security.ProtectionDomain.impliesWithAltFilePerm:(Ljava/security/Permission;)Z
ifne 48
38: iload 2
ifeq 40
39: getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
new java.lang.StringBuilder
dup
ldc "access denied "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
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
40: StackMap locals:
StackMap stack:
ldc "failure"
invokestatic sun.security.util.Debug.isOn:(Ljava/lang/String;)Z
ifeq 47
getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
ifnull 47
41: iload 2
ifne 43
42: getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
new java.lang.StringBuilder
dup
ldc "access denied "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
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
43: StackMap locals:
StackMap stack:
invokestatic java.lang.Thread.dumpStack:()V
44: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 3
aaload
astore 4
start local 4 45: getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
astore 5
start local 5 46: new java.security.AccessControlContext$1
dup
aload 0
aload 5
aload 4
invokespecial java.security.AccessControlContext$1.<init>:(Ljava/security/AccessControlContext;Lsun/security/util/Debug;Ljava/security/ProtectionDomain;)V
invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
pop
end local 5 end local 4 47: StackMap locals:
StackMap stack:
new java.security.AccessControlException
dup
new java.lang.StringBuilder
dup
ldc "access denied "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 1
invokespecial java.security.AccessControlException.<init>:(Ljava/lang/String;Ljava/security/Permission;)V
athrow
48: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
49: iload 3
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
arraylength
if_icmplt 37
end local 3 50: iload 2
ifeq 52
51: getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
new java.lang.StringBuilder
dup
ldc "access allowed "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
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
52: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual java.security.AccessControlContext.checkPermission2:(Ljava/security/Permission;)V
53: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 54 0 this Ljava/security/AccessControlContext;
0 54 1 perm Ljava/security/Permission;
1 54 2 dumpDebug Z
9 17 3 i I
28 32 3 i I
36 50 3 i I
45 47 4 pd Ljava/security/ProtectionDomain;
46 47 5 db Lsun/security/util/Debug;
Exceptions:
throws java.security.AccessControlException
MethodParameters:
Name Flags
perm
private void checkPermission2(java.security.Permission);
descriptor: (Ljava/security/Permission;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=5, args_size=2
start local 0 start local 1 0: aload 0
getfield java.security.AccessControlContext.isLimited:Z
ifne 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
ifnull 4
3: aload 0
getfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
aload 1
invokevirtual java.security.AccessControlContext.checkPermission2:(Ljava/security/Permission;)V
4: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.isWrapped:Z
ifeq 6
5: return
6: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnull 15
7: aload 1
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
astore 2
start local 2 8: iconst_0
istore 3
start local 3 9: goto 14
10: StackMap locals: java.lang.Class int
StackMap stack:
aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
iload 3
aaload
astore 4
start local 4 11: aload 4
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
aload 2
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 13
aload 4
aload 1
invokevirtual java.security.Permission.implies:(Ljava/security/Permission;)Z
ifeq 13
12: return
end local 4 13: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
14: iload 3
aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
arraylength
if_icmplt 10
end local 3 end local 2 15: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
ifnull 20
16: aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnonnull 19
17: aload 0
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
aload 1
invokevirtual java.security.AccessControlContext.checkPermission2:(Ljava/security/Permission;)V
18: goto 20
19: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
aload 1
invokevirtual java.security.AccessControlContext.checkPermission:(Ljava/security/Permission;)V
20: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Ljava/security/AccessControlContext;
0 21 1 perm Ljava/security/Permission;
8 15 2 permClass Ljava/lang/Class<*>;
9 15 3 i I
11 13 4 limit Ljava/security/Permission;
MethodParameters:
Name Flags
perm
java.security.AccessControlContext optimize();
descriptor: ()Ljava/security/AccessControlContext;
flags: (0x0000)
Code:
stack=4, locals=10, args_size=1
start local 0 0: aconst_null
astore 2
start local 2 1: aconst_null
astore 3
start local 3 2: aconst_null
astore 4
start local 4 3: aload 0
getfield java.security.AccessControlContext.isPrivileged:Z
ifeq 10
4: aload 0
getfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
astore 1
start local 1 5: aload 1
ifnull 14
6: aload 1
getfield java.security.AccessControlContext.isWrapped:Z
ifeq 14
7: aload 1
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
astore 4
8: aload 1
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
astore 3
9: goto 14
end local 1 10: StackMap locals: java.security.AccessControlContext top java.security.DomainCombiner java.security.AccessControlContext java.security.Permission[]
StackMap stack:
invokestatic java.security.AccessController.getInheritedAccessControlContext:()Ljava/security/AccessControlContext;
astore 1
start local 1 11: aload 1
ifnull 14
12: aload 1
getfield java.security.AccessControlContext.isLimited:Z
ifeq 14
13: aload 1
astore 3
14: StackMap locals: java.security.AccessControlContext java.security.AccessControlContext java.security.DomainCombiner java.security.AccessControlContext java.security.Permission[]
StackMap stack:
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
ifnonnull 15
iconst_1
goto 16
StackMap locals:
StackMap stack:
15: iconst_0
StackMap locals:
StackMap stack: int
16: istore 5
start local 5 17: aload 1
ifnull 18
aload 1
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
ifnull 18
iconst_0
goto 19
StackMap locals: int
StackMap stack:
18: iconst_1
StackMap locals:
StackMap stack: int
19: istore 6
start local 6 20: iload 6
ifeq 21
aconst_null
goto 22
StackMap locals: int
StackMap stack:
21: aload 1
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
StackMap locals:
StackMap stack: java.security.ProtectionDomain[]
22: astore 7
start local 7 23: aload 1
ifnull 24
aload 1
getfield java.security.AccessControlContext.isWrapped:Z
ifne 25
StackMap locals: java.security.ProtectionDomain[]
StackMap stack:
24: aload 3
ifnonnull 25
iconst_1
goto 26
StackMap locals:
StackMap stack:
25: iconst_0
StackMap locals:
StackMap stack: int
26: istore 9
start local 9 27: aload 1
ifnull 33
aload 1
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
ifnull 33
28: invokestatic java.security.AccessControlContext.getDebug:()Lsun/security/util/Debug;
ifnull 30
29: getstatic java.security.AccessControlContext.debug:Lsun/security/util/Debug;
ldc "AccessControlContext invoking the Combiner"
invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
30: StackMap locals: java.security.AccessControlContext java.security.AccessControlContext java.security.DomainCombiner java.security.AccessControlContext java.security.Permission[] int int java.security.ProtectionDomain[] top int
StackMap stack:
aload 1
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
astore 2
31: aload 2
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
aload 7
invokeinterface java.security.DomainCombiner.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
astore 8
start local 8 32: goto 49
end local 8 33: StackMap locals:
StackMap stack:
iload 5
ifeq 39
34: iload 6
ifeq 37
35: aload 0
aload 1
aload 3
aload 4
invokevirtual java.security.AccessControlContext.calculateFields:(Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)V
36: aload 0
areturn
37: StackMap locals:
StackMap stack:
iload 9
ifeq 43
38: aload 1
areturn
39: StackMap locals:
StackMap stack:
aload 7
ifnull 43
40: iload 9
ifeq 43
41: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
arraylength
iconst_1
if_icmpne 43
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iconst_0
aaload
aload 7
iconst_0
aaload
if_acmpne 43
42: aload 1
areturn
43: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
aload 7
invokestatic java.security.AccessControlContext.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
astore 8
start local 8 44: iload 9
ifeq 46
iload 6
ifne 46
aload 8
aload 7
if_acmpne 46
45: aload 1
areturn
46: StackMap locals: java.security.AccessControlContext java.security.AccessControlContext java.security.DomainCombiner java.security.AccessControlContext java.security.Permission[] int int java.security.ProtectionDomain[] java.security.ProtectionDomain[] int
StackMap stack:
iload 6
ifeq 49
aload 8
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
if_acmpne 49
47: aload 0
aload 1
aload 3
aload 4
invokevirtual java.security.AccessControlContext.calculateFields:(Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)V
48: aload 0
areturn
49: StackMap locals:
StackMap stack:
aload 0
aload 8
putfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
50: aload 0
aload 2
putfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
51: aload 0
iconst_0
putfield java.security.AccessControlContext.isPrivileged:Z
52: aload 0
aload 1
aload 3
aload 4
invokevirtual java.security.AccessControlContext.calculateFields:(Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)V
53: aload 0
areturn
end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 54 0 this Ljava/security/AccessControlContext;
5 10 1 acc Ljava/security/AccessControlContext;
11 54 1 acc Ljava/security/AccessControlContext;
1 54 2 combiner Ljava/security/DomainCombiner;
2 54 3 parent Ljava/security/AccessControlContext;
3 54 4 permissions [Ljava/security/Permission;
17 54 5 skipStack Z
20 54 6 skipAssigned Z
23 54 7 assigned [Ljava/security/ProtectionDomain;
32 33 8 pd [Ljava/security/ProtectionDomain;
44 54 8 pd [Ljava/security/ProtectionDomain;
27 54 9 skipLimited Z
private static java.security.ProtectionDomain[] combine(java.security.ProtectionDomain[], java.security.ProtectionDomain[]);
descriptor: ([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=5, locals=10, args_size=2
start local 0 start local 1 0: aload 0
ifnonnull 1
iconst_1
goto 2
StackMap locals:
StackMap stack:
1: iconst_0
StackMap locals:
StackMap stack: int
2: istore 2
start local 2 3: aload 1
ifnonnull 4
iconst_1
goto 5
StackMap locals: int
StackMap stack:
4: iconst_0
StackMap locals:
StackMap stack: int
5: istore 3
start local 3 6: iload 2
ifeq 7
iconst_0
goto 8
StackMap locals: int
StackMap stack:
7: aload 0
arraylength
StackMap locals:
StackMap stack: int
8: istore 4
start local 4 9: iload 3
ifeq 11
iload 4
iconst_2
if_icmpgt 11
10: aload 0
areturn
11: StackMap locals: int
StackMap stack:
iload 3
ifeq 12
iconst_0
goto 13
StackMap locals:
StackMap stack:
12: aload 1
arraylength
StackMap locals:
StackMap stack: int
13: istore 5
start local 5 14: iload 4
iload 5
iadd
anewarray java.security.ProtectionDomain
astore 6
start local 6 15: iload 3
ifne 17
16: aload 1
iconst_0
aload 6
iconst_0
iload 5
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
17: StackMap locals: int java.security.ProtectionDomain[]
StackMap stack:
iconst_0
istore 7
start local 7 18: goto 29
19: StackMap locals: int
StackMap stack:
aload 0
iload 7
aaload
astore 8
start local 8 20: aload 8
ifnull 28
21: iconst_0
istore 9
start local 9 22: goto 26
23: StackMap locals: java.security.ProtectionDomain int
StackMap stack:
aload 8
aload 6
iload 9
aaload
if_acmpne 25
24: goto 28
25: StackMap locals:
StackMap stack:
iinc 9 1
StackMap locals:
StackMap stack:
26: iload 9
iload 5
if_icmplt 23
end local 9 27: aload 6
iload 5
iinc 5 1
aload 8
aastore
end local 8 28: StackMap locals:
StackMap stack:
iinc 7 1
StackMap locals:
StackMap stack:
29: iload 7
iload 4
if_icmplt 19
end local 7 30: iload 5
aload 6
arraylength
if_icmpeq 38
31: iload 3
ifne 33
iload 5
aload 1
arraylength
if_icmpne 33
32: aload 1
areturn
33: StackMap locals:
StackMap stack:
iload 3
ifeq 35
iload 5
iload 4
if_icmpne 35
34: aload 0
areturn
35: StackMap locals:
StackMap stack:
iload 5
anewarray java.security.ProtectionDomain
astore 7
start local 7 36: aload 6
iconst_0
aload 7
iconst_0
iload 5
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
37: aload 7
astore 6
end local 7 38: StackMap locals:
StackMap stack:
aload 6
areturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 39 0 current [Ljava/security/ProtectionDomain;
0 39 1 assigned [Ljava/security/ProtectionDomain;
3 39 2 skipStack Z
6 39 3 skipAssigned Z
9 39 4 slen I
14 39 5 n I
15 39 6 pd [Ljava/security/ProtectionDomain;
18 30 7 i I
20 28 8 sd Ljava/security/ProtectionDomain;
22 27 9 j I
36 38 7 tmp [Ljava/security/ProtectionDomain;
MethodParameters:
Name Flags
current
assigned
private void calculateFields(java.security.AccessControlContext, java.security.AccessControlContext, java.security.Permission[]);
descriptor: (Ljava/security/AccessControlContext;Ljava/security/AccessControlContext;[Ljava/security/Permission;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=7, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aconst_null
astore 4
start local 4 1: aconst_null
astore 5
start local 5 2: aload 2
ifnull 3
aload 2
getfield java.security.AccessControlContext.limitedContext:[Ljava/security/ProtectionDomain;
goto 4
StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[]
StackMap stack:
3: aconst_null
StackMap locals:
StackMap stack: java.security.ProtectionDomain[]
4: astore 4
5: aload 1
ifnull 6
aload 1
getfield java.security.AccessControlContext.limitedContext:[Ljava/security/ProtectionDomain;
goto 7
StackMap locals:
StackMap stack:
6: aconst_null
StackMap locals:
StackMap stack: java.security.ProtectionDomain[]
7: astore 5
8: aload 4
aload 5
invokestatic java.security.AccessControlContext.combine:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)[Ljava/security/ProtectionDomain;
astore 6
start local 6 9: aload 6
ifnull 15
10: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
ifnull 11
aload 6
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
invokestatic java.security.AccessControlContext.containsAllPDs:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)Z
ifne 15
11: StackMap locals: java.security.ProtectionDomain[]
StackMap stack:
aload 0
aload 6
putfield java.security.AccessControlContext.limitedContext:[Ljava/security/ProtectionDomain;
12: aload 0
aload 3
putfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
13: aload 0
aload 2
putfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
14: aload 0
iconst_1
putfield java.security.AccessControlContext.isLimited:Z
15: StackMap locals:
StackMap stack:
return
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Ljava/security/AccessControlContext;
0 16 1 assigned Ljava/security/AccessControlContext;
0 16 2 parent Ljava/security/AccessControlContext;
0 16 3 permissions [Ljava/security/Permission;
1 16 4 parentLimit [Ljava/security/ProtectionDomain;
2 16 5 assignedLimit [Ljava/security/ProtectionDomain;
9 16 6 newLimit [Ljava/security/ProtectionDomain;
MethodParameters:
Name Flags
assigned
parent
permissions
public boolean equals(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 1
aload 0
if_acmpne 2
1: iconst_1
ireturn
2: StackMap locals:
StackMap stack:
aload 1
instanceof java.security.AccessControlContext
ifne 4
3: iconst_0
ireturn
4: StackMap locals:
StackMap stack:
aload 1
checkcast java.security.AccessControlContext
astore 2
start local 2 5: aload 0
aload 2
invokevirtual java.security.AccessControlContext.equalContext:(Ljava/security/AccessControlContext;)Z
ifne 7
6: iconst_0
ireturn
7: StackMap locals: java.security.AccessControlContext
StackMap stack:
aload 0
aload 2
invokevirtual java.security.AccessControlContext.equalLimitedContext:(Ljava/security/AccessControlContext;)Z
ifne 9
8: iconst_0
ireturn
9: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Ljava/security/AccessControlContext;
0 10 1 obj Ljava/lang/Object;
5 10 2 that Ljava/security/AccessControlContext;
MethodParameters:
Name Flags
obj
private boolean equalContext(java.security.AccessControlContext);
descriptor: (Ljava/security/AccessControlContext;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
aload 1
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
invokevirtual java.security.AccessControlContext.equalPDs:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)Z
ifne 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
ifnonnull 4
aload 1
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
ifnull 4
3: iconst_0
ireturn
4: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
ifnull 6
aload 0
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
aload 1
getfield java.security.AccessControlContext.combiner:Ljava/security/DomainCombiner;
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifne 6
5: iconst_0
ireturn
6: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Ljava/security/AccessControlContext;
0 7 1 that Ljava/security/AccessControlContext;
MethodParameters:
Name Flags
that
private boolean equalPDs(java.security.ProtectionDomain[], java.security.ProtectionDomain[]);
descriptor: ([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 1
ifnonnull 3
1: aload 2
ifnonnull 2
iconst_1
ireturn
StackMap locals:
StackMap stack:
2: iconst_0
ireturn
3: StackMap locals:
StackMap stack:
aload 2
ifnonnull 5
4: iconst_0
ireturn
5: StackMap locals:
StackMap stack:
aload 1
aload 2
invokestatic java.security.AccessControlContext.containsAllPDs:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)Z
ifeq 6
aload 2
aload 1
invokestatic java.security.AccessControlContext.containsAllPDs:([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)Z
ifne 7
6: StackMap locals:
StackMap stack:
iconst_0
ireturn
7: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Ljava/security/AccessControlContext;
0 8 1 a [Ljava/security/ProtectionDomain;
0 8 2 b [Ljava/security/ProtectionDomain;
MethodParameters:
Name Flags
a
b
private boolean equalLimitedContext(java.security.AccessControlContext);
descriptor: (Ljava/security/AccessControlContext;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=4, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.isLimited:Z
ifne 4
aload 1
getfield java.security.AccessControlContext.isLimited:Z
ifne 4
3: iconst_1
ireturn
4: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.isLimited:Z
ifeq 5
aload 1
getfield java.security.AccessControlContext.isLimited:Z
ifne 6
5: StackMap locals:
StackMap stack:
iconst_0
ireturn
6: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.isWrapped:Z
ifeq 7
aload 1
getfield java.security.AccessControlContext.isWrapped:Z
ifeq 8
7: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.isWrapped:Z
ifne 9
aload 1
getfield java.security.AccessControlContext.isWrapped:Z
ifeq 9
8: StackMap locals:
StackMap stack:
iconst_0
ireturn
9: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnonnull 11
aload 1
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnull 11
10: iconst_0
ireturn
11: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnull 13
aload 1
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnonnull 13
12: iconst_0
ireturn
13: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual java.security.AccessControlContext.containsAllLimits:(Ljava/security/AccessControlContext;)Z
ifeq 14
aload 1
aload 0
invokevirtual java.security.AccessControlContext.containsAllLimits:(Ljava/security/AccessControlContext;)Z
ifne 15
14: StackMap locals:
StackMap stack:
iconst_0
ireturn
15: StackMap locals:
StackMap stack:
aload 0
invokestatic java.security.AccessControlContext.getNextPC:(Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
astore 2
start local 2 16: aload 1
invokestatic java.security.AccessControlContext.getNextPC:(Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
astore 3
start local 3 17: aload 2
ifnonnull 19
aload 3
ifnull 19
aload 3
getfield java.security.AccessControlContext.isLimited:Z
ifeq 19
18: iconst_0
ireturn
19: StackMap locals: java.security.AccessControlContext java.security.AccessControlContext
StackMap stack:
aload 2
ifnull 21
aload 2
aload 3
invokevirtual java.security.AccessControlContext.equalLimitedContext:(Ljava/security/AccessControlContext;)Z
ifne 21
20: iconst_0
ireturn
21: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
ifnonnull 23
aload 1
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
ifnull 23
22: iconst_0
ireturn
23: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
ifnull 25
aload 0
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
aload 1
getfield java.security.AccessControlContext.parent:Ljava/security/AccessControlContext;
invokevirtual java.security.AccessControlContext.equals:(Ljava/lang/Object;)Z
ifne 25
24: iconst_0
ireturn
25: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 26 0 this Ljava/security/AccessControlContext;
0 26 1 that Ljava/security/AccessControlContext;
16 26 2 thisNextPC Ljava/security/AccessControlContext;
17 26 3 thatNextPC Ljava/security/AccessControlContext;
MethodParameters:
Name Flags
that
private static java.security.AccessControlContext getNextPC(java.security.AccessControlContext);
descriptor: (Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: goto 4
1: StackMap locals:
StackMap stack:
aload 0
getfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
astore 0
2: aload 0
getfield java.security.AccessControlContext.isWrapped:Z
ifne 4
3: aload 0
areturn
4: StackMap locals:
StackMap stack:
aload 0
ifnull 5
aload 0
getfield java.security.AccessControlContext.privilegedContext:Ljava/security/AccessControlContext;
ifnonnull 1
5: StackMap locals:
StackMap stack:
aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 acc Ljava/security/AccessControlContext;
MethodParameters:
Name Flags
acc
private static boolean containsAllPDs(java.security.ProtectionDomain[], java.security.ProtectionDomain[]);
descriptor: ([Ljava/security/ProtectionDomain;[Ljava/security/ProtectionDomain;)Z
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=2, locals=8, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: iconst_0
istore 4
start local 4 2: goto 27
3: StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[] int top int
StackMap stack:
iconst_0
istore 2
4: aload 0
iload 4
aaload
dup
astore 3
start local 3 5: ifnonnull 14
6: iconst_0
istore 5
start local 5 7: goto 12
8: StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[] int java.security.ProtectionDomain int int
StackMap stack:
aload 1
iload 5
aaload
ifnonnull 9
iconst_1
goto 10
StackMap locals:
StackMap stack:
9: iconst_0
StackMap locals:
StackMap stack: int
10: istore 2
11: iinc 5 1
StackMap locals:
StackMap stack:
12: iload 5
aload 1
arraylength
if_icmpge 25
iload 2
ifeq 8
end local 5 13: goto 25
14: StackMap locals:
StackMap stack:
aload 3
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
astore 5
start local 5 15: iconst_0
istore 7
start local 7 16: goto 24
17: StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[] int java.security.ProtectionDomain int java.lang.Class top int
StackMap stack:
aload 1
iload 7
aaload
astore 6
start local 6 18: aload 6
ifnull 21
19: aload 5
aload 6
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
if_acmpne 21
aload 3
aload 6
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 21
20: iconst_1
goto 22
StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[] int java.security.ProtectionDomain int java.lang.Class java.security.ProtectionDomain int
StackMap stack:
21: iconst_0
StackMap locals:
StackMap stack: int
22: istore 2
23: iinc 7 1
end local 6 StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[] int java.security.ProtectionDomain int java.lang.Class top int
StackMap stack:
24: iload 7
aload 1
arraylength
if_icmpge 25
iload 2
ifeq 17
end local 7 end local 5 25: StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[] int java.security.ProtectionDomain int
StackMap stack:
iload 2
ifne 26
iconst_0
ireturn
26: StackMap locals:
StackMap stack:
iinc 4 1
end local 3 StackMap locals: java.security.ProtectionDomain[] java.security.ProtectionDomain[] int top int
StackMap stack:
27: iload 4
aload 0
arraylength
if_icmplt 3
end local 4 28: iload 2
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 29 0 thisContext [Ljava/security/ProtectionDomain;
0 29 1 thatContext [Ljava/security/ProtectionDomain;
1 29 2 match Z
5 27 3 thisPd Ljava/security/ProtectionDomain;
2 28 4 i I
7 13 5 j I
15 25 5 thisPdClass Ljava/lang/Class<*>;
18 24 6 thatPd Ljava/security/ProtectionDomain;
16 25 7 j I
MethodParameters:
Name Flags
thisContext
thatContext
private boolean containsAllLimits(java.security.AccessControlContext);
descriptor: (Ljava/security/AccessControlContext;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=8, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnonnull 3
aload 1
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
ifnonnull 3
2: iconst_1
ireturn
3: StackMap locals: int
StackMap stack:
iconst_0
istore 3
start local 3 4: goto 20
5: StackMap locals: int
StackMap stack:
aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
iload 3
aaload
astore 4
start local 4 6: aload 4
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
astore 5
start local 5 7: iconst_0
istore 2
8: iconst_0
istore 6
start local 6 9: goto 17
10: StackMap locals: java.security.Permission java.lang.Class int
StackMap stack:
aload 1
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
iload 6
aaload
astore 7
start local 7 11: aload 5
aload 7
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 14
12: aload 4
aload 7
invokevirtual java.security.Permission.equals:(Ljava/lang/Object;)Z
ifeq 14
13: iconst_1
goto 15
StackMap locals: java.security.Permission
StackMap stack:
14: iconst_0
StackMap locals:
StackMap stack: int
15: istore 2
end local 7 16: iinc 6 1
StackMap locals:
StackMap stack:
17: iload 6
aload 1
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
arraylength
if_icmpge 18
iload 2
ifeq 10
end local 6 18: StackMap locals:
StackMap stack:
iload 2
ifne 19
iconst_0
ireturn
end local 5 end local 4 19: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
20: iload 3
aload 0
getfield java.security.AccessControlContext.permissions:[Ljava/security/Permission;
arraylength
if_icmplt 5
end local 3 21: iload 2
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 22 0 this Ljava/security/AccessControlContext;
0 22 1 that Ljava/security/AccessControlContext;
1 22 2 match Z
4 21 3 i I
6 19 4 limit Ljava/security/Permission;
7 19 5 limitClass Ljava/lang/Class<*>;
9 18 6 j I
11 16 7 perm Ljava/security/Permission;
MethodParameters:
Name Flags
that
public int hashCode();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=1
start local 0 0: iconst_0
istore 1
start local 1 1: aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
ifnonnull 3
2: iload 1
ireturn
3: StackMap locals: int
StackMap stack:
iconst_0
istore 2
start local 2 4: goto 8
5: StackMap locals: int
StackMap stack:
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 2
aaload
ifnull 7
6: iload 1
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
iload 2
aaload
invokevirtual java.lang.Object.hashCode:()I
ixor
istore 1
7: StackMap locals:
StackMap stack:
iinc 2 1
StackMap locals:
StackMap stack:
8: iload 2
aload 0
getfield java.security.AccessControlContext.context:[Ljava/security/ProtectionDomain;
arraylength
if_icmplt 5
end local 2 9: iload 1
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Ljava/security/AccessControlContext;
1 10 1 hashCode I
4 9 2 i I
}
SourceFile: "AccessControlContext.java"
NestMembers:
java.security.AccessControlContext$1
InnerClasses:
java.security.AccessControlContext$1