public abstract class java.security.Policy
minor version: 0
major version: 59
flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
this_class: java.security.Policy
super_class: java.lang.Object
{
public static final java.security.PermissionCollection UNSUPPORTED_EMPTY_COLLECTION;
descriptor: Ljava/security/PermissionCollection;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
private static java.util.concurrent.atomic.AtomicReference<java.security.Policy$PolicyInfo> policy;
descriptor: Ljava/util/concurrent/atomic/AtomicReference;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Signature: Ljava/util/concurrent/atomic/AtomicReference<Ljava/security/Policy$PolicyInfo;>;
private static final sun.security.util.Debug debug;
descriptor: Lsun/security/util/Debug;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private java.util.WeakHashMap<java.security.ProtectionDomain$Key, java.security.PermissionCollection> pdMapping;
descriptor: Ljava/util/WeakHashMap;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/util/WeakHashMap<Ljava/security/ProtectionDomain$Key;Ljava/security/PermissionCollection;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=6, locals=0, args_size=0
0: new java.security.Policy$UnsupportedEmptyCollection
dup
invokespecial java.security.Policy$UnsupportedEmptyCollection.<init>:()V
1: putstatic java.security.Policy.UNSUPPORTED_EMPTY_COLLECTION:Ljava/security/PermissionCollection;
2: new java.util.concurrent.atomic.AtomicReference
dup
new java.security.Policy$PolicyInfo
dup
aconst_null
iconst_0
invokespecial java.security.Policy$PolicyInfo.<init>:(Ljava/security/Policy;Z)V
invokespecial java.util.concurrent.atomic.AtomicReference.<init>:(Ljava/lang/Object;)V
3: putstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
4: ldc "policy"
invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
putstatic java.security.Policy.debug:Lsun/security/util/Debug;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/Policy;
static boolean isSet();
descriptor: ()Z
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=1, args_size=0
0: getstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.security.Policy$PolicyInfo
astore 0
start local 0 1: aload 0
getfield java.security.Policy$PolicyInfo.policy:Ljava/security/Policy;
ifnull 2
aload 0
getfield java.security.Policy$PolicyInfo.initialized:Z
ifeq 2
iconst_1
ireturn
StackMap locals: java.security.Policy$PolicyInfo
StackMap stack:
2: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
1 3 0 pi Ljava/security/Policy$PolicyInfo;
private static void checkPermission(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=6, 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
new java.security.SecurityPermission
dup
new java.lang.StringBuilder
dup
ldc "createPolicy."
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.security.SecurityPermission.<init>:(Ljava/lang/String;)V
invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
3: StackMap locals: java.lang.SecurityManager
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 type Ljava/lang/String;
1 4 1 sm Ljava/lang/SecurityManager;
MethodParameters:
Name Flags
type
public static java.security.Policy getPolicy();
descriptor: ()Ljava/security/Policy;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=1, args_size=0
0: invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
astore 0
start local 0 1: aload 0
ifnull 3
2: aload 0
getstatic sun.security.util.SecurityConstants.GET_POLICY_PERMISSION:Ljava/security/SecurityPermission;
invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
3: StackMap locals: java.lang.SecurityManager
StackMap stack:
invokestatic java.security.Policy.getPolicyNoCheck:()Ljava/security/Policy;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
1 4 0 sm Ljava/lang/SecurityManager;
static java.security.Policy getPolicyNoCheck();
descriptor: ()Ljava/security/Policy;
flags: (0x0008) ACC_STATIC
Code:
stack=4, locals=7, args_size=0
0: getstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.security.Policy$PolicyInfo
astore 0
start local 0 1: aload 0
getfield java.security.Policy$PolicyInfo.initialized:Z
ifeq 2
aload 0
getfield java.security.Policy$PolicyInfo.policy:Ljava/security/Policy;
ifnonnull 32
2: StackMap locals: java.security.Policy$PolicyInfo
StackMap stack:
ldc Ljava/security/Policy;
dup
astore 1
monitorenter
3: getstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.security.Policy$PolicyInfo
astore 2
start local 2 4: aload 2
getfield java.security.Policy$PolicyInfo.policy:Ljava/security/Policy;
ifnonnull 28
5: new java.security.Policy$1
dup
invokespecial java.security.Policy$1.<init>:()V
6: invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
checkcast java.lang.String
astore 3
start local 3 7: aload 3
ifnonnull 9
8: ldc "sun.security.provider.PolicyFile"
astore 3
9: StackMap locals: java.lang.Class java.security.Policy$PolicyInfo java.lang.String
StackMap stack:
new java.security.Policy$PolicyInfo
dup
10: aload 3
invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
invokevirtual java.lang.Class.newInstance:()Ljava/lang/Object;
checkcast java.security.Policy
11: iconst_1
12: invokespecial java.security.Policy$PolicyInfo.<init>:(Ljava/security/Policy;Z)V
astore 2
13: goto 27
StackMap locals:
StackMap stack: java.lang.Exception
14: pop
15: new sun.security.provider.PolicyFile
dup
invokespecial sun.security.provider.PolicyFile.<init>:()V
astore 4
start local 4 16: new java.security.Policy$PolicyInfo
dup
aload 4
iconst_0
invokespecial java.security.Policy$PolicyInfo.<init>:(Ljava/security/Policy;Z)V
astore 2
17: getstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
aload 2
invokevirtual java.util.concurrent.atomic.AtomicReference.set:(Ljava/lang/Object;)V
18: aload 3
astore 5
start local 5 19: new java.security.Policy$2
dup
aload 5
invokespecial java.security.Policy$2.<init>:(Ljava/lang/String;)V
20: invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
checkcast java.security.Policy
astore 6
start local 6 21: aload 6
ifnull 24
22: new java.security.Policy$PolicyInfo
dup
aload 6
iconst_1
invokespecial java.security.Policy$PolicyInfo.<init>:(Ljava/security/Policy;Z)V
astore 2
23: goto 27
24: StackMap locals: java.security.Policy java.lang.String java.security.Policy
StackMap stack:
getstatic java.security.Policy.debug:Lsun/security/util/Debug;
ifnull 26
25: getstatic java.security.Policy.debug:Lsun/security/util/Debug;
ldc "using sun.security.provider.PolicyFile"
invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
26: StackMap locals:
StackMap stack:
new java.security.Policy$PolicyInfo
dup
aload 4
iconst_1
invokespecial java.security.Policy$PolicyInfo.<init>:(Ljava/security/Policy;Z)V
astore 2
end local 6 end local 5 end local 4 27: StackMap locals:
StackMap stack:
getstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
aload 2
invokevirtual java.util.concurrent.atomic.AtomicReference.set:(Ljava/lang/Object;)V
end local 3 28: StackMap locals:
StackMap stack:
aload 2
getfield java.security.Policy$PolicyInfo.policy:Ljava/security/Policy;
aload 1
monitorexit
29: areturn
end local 2 30: StackMap locals: java.security.Policy$PolicyInfo java.lang.Class
StackMap stack: java.lang.Throwable
aload 1
monitorexit
31: athrow
32: StackMap locals:
StackMap stack:
aload 0
getfield java.security.Policy$PolicyInfo.policy:Ljava/security/Policy;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
1 33 0 pi Ljava/security/Policy$PolicyInfo;
4 30 2 pinfo Ljava/security/Policy$PolicyInfo;
7 28 3 policy_class Ljava/lang/String;
16 27 4 polFile Ljava/security/Policy;
19 27 5 pc Ljava/lang/String;
21 27 6 pol Ljava/security/Policy;
Exception table:
from to target type
9 13 14 Class java.lang.Exception
3 29 30 any
30 31 30 any
public static void setPolicy(java.security.Policy);
descriptor: (Ljava/security/Policy;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=5, locals=3, args_size=1
start local 0 0: invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
astore 1
start local 1 1: aload 1
ifnull 4
aload 1
2: new java.security.SecurityPermission
dup
ldc "setPolicy"
invokespecial java.security.SecurityPermission.<init>:(Ljava/lang/String;)V
3: invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
4: StackMap locals: java.lang.SecurityManager
StackMap stack:
aload 0
ifnull 6
5: aload 0
invokestatic java.security.Policy.initPolicy:(Ljava/security/Policy;)V
6: StackMap locals:
StackMap stack:
ldc Ljava/security/Policy;
dup
astore 2
monitorenter
7: getstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
8: new java.security.Policy$PolicyInfo
dup
aload 0
aload 0
ifnull 9
iconst_1
goto 10
StackMap locals: java.security.Policy java.lang.SecurityManager java.lang.Class
StackMap stack: java.util.concurrent.atomic.AtomicReference new 8 new 8 java.security.Policy
9: iconst_0
StackMap locals: java.security.Policy java.lang.SecurityManager java.lang.Class
StackMap stack: java.util.concurrent.atomic.AtomicReference new 8 new 8 java.security.Policy int
10: invokespecial java.security.Policy$PolicyInfo.<init>:(Ljava/security/Policy;Z)V
invokevirtual java.util.concurrent.atomic.AtomicReference.set:(Ljava/lang/Object;)V
11: aload 2
monitorexit
12: goto 15
StackMap locals:
StackMap stack: java.lang.Throwable
13: aload 2
monitorexit
14: athrow
15: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 p Ljava/security/Policy;
1 16 1 sm Ljava/lang/SecurityManager;
Exception table:
from to target type
7 12 13 any
13 14 13 any
MethodParameters:
Name Flags
p
private static void initPolicy(java.security.Policy);
descriptor: (Ljava/security/Policy;)V
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=5, args_size=1
start local 0 0: new java.security.Policy$3
dup
aload 0
invokespecial java.security.Policy$3.<init>:(Ljava/security/Policy;)V
invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
checkcast java.security.ProtectionDomain
1: astore 1
start local 1 2: aconst_null
astore 2
start local 2 3: aload 0
dup
astore 3
monitorenter
4: aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
ifnonnull 6
5: aload 0
new java.util.WeakHashMap
dup
invokespecial java.util.WeakHashMap.<init>:()V
putfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
6: StackMap locals: java.security.ProtectionDomain java.security.PermissionCollection java.security.Policy
StackMap stack:
aload 3
monitorexit
7: goto 10
StackMap locals:
StackMap stack: java.lang.Throwable
8: aload 3
monitorexit
9: athrow
10: StackMap locals:
StackMap stack:
aload 1
invokevirtual java.security.ProtectionDomain.getCodeSource:()Ljava/security/CodeSource;
ifnull 23
11: getstatic java.security.Policy.policy:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast java.security.Policy$PolicyInfo
getfield java.security.Policy$PolicyInfo.policy:Ljava/security/Policy;
astore 3
start local 3 12: aload 3
ifnull 14
13: aload 3
aload 1
invokevirtual java.security.Policy.getPermissions:(Ljava/security/ProtectionDomain;)Ljava/security/PermissionCollection;
astore 2
14: StackMap locals: java.security.Policy
StackMap stack:
aload 2
ifnonnull 17
15: new java.security.Permissions
dup
invokespecial java.security.Permissions.<init>:()V
astore 2
16: aload 2
getstatic sun.security.util.SecurityConstants.ALL_PERMISSION:Ljava/security/AllPermission;
invokevirtual java.security.PermissionCollection.add:(Ljava/security/Permission;)V
17: StackMap locals:
StackMap stack:
aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
dup
astore 4
monitorenter
18: aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
aload 1
getfield java.security.ProtectionDomain.key:Ljava/security/ProtectionDomain$Key;
aload 2
invokevirtual java.util.WeakHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
19: aload 4
monitorexit
20: goto 23
StackMap locals: java.security.Policy java.security.ProtectionDomain java.security.PermissionCollection java.security.Policy java.util.WeakHashMap
StackMap stack: java.lang.Throwable
21: aload 4
monitorexit
22: athrow
end local 3 23: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 p Ljava/security/Policy;
2 24 1 policyDomain Ljava/security/ProtectionDomain;
3 24 2 policyPerms Ljava/security/PermissionCollection;
12 23 3 pol Ljava/security/Policy;
Exception table:
from to target type
4 7 8 any
8 9 8 any
18 20 21 any
21 22 21 any
MethodParameters:
Name Flags
p final
public static java.security.Policy getInstance(java.lang.String, java.security.Policy$Parameters);
descriptor: (Ljava/lang/String;Ljava/security/Policy$Parameters;)Ljava/security/Policy;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=6, locals=3, args_size=2
start local 0 start local 1 0: aload 0
invokestatic java.security.Policy.checkPermission:(Ljava/lang/String;)V
1: ldc "Policy"
2: ldc Ljava/security/PolicySpi;
3: aload 0
4: aload 1
5: invokestatic sun.security.jca.GetInstance.getInstance:(Ljava/lang/String;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Object;)Lsun/security/jca/GetInstance$Instance;
astore 2
start local 2 6: new java.security.Policy$PolicyDelegate
dup
aload 2
getfield sun.security.jca.GetInstance$Instance.impl:Ljava/lang/Object;
checkcast java.security.PolicySpi
7: aload 2
getfield sun.security.jca.GetInstance$Instance.provider:Ljava/security/Provider;
8: aload 0
9: aload 1
10: invokespecial java.security.Policy$PolicyDelegate.<init>:(Ljava/security/PolicySpi;Ljava/security/Provider;Ljava/lang/String;Ljava/security/Policy$Parameters;)V
11: areturn
end local 2 12: StackMap locals:
StackMap stack: java.security.NoSuchAlgorithmException
astore 2
start local 2 13: aload 2
invokestatic java.security.Policy.handleException:(Ljava/security/NoSuchAlgorithmException;)Ljava/security/Policy;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 type Ljava/lang/String;
0 14 1 params Ljava/security/Policy$Parameters;
6 12 2 instance Lsun/security/jca/GetInstance$Instance;
13 14 2 nsae Ljava/security/NoSuchAlgorithmException;
Exception table:
from to target type
1 11 12 Class java.security.NoSuchAlgorithmException
Exceptions:
throws java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
type
params
public static java.security.Policy getInstance(java.lang.String, java.security.Policy$Parameters, java.lang.String);
descriptor: (Ljava/lang/String;Ljava/security/Policy$Parameters;Ljava/lang/String;)Ljava/security/Policy;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=6, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 2
ifnull 1
aload 2
invokevirtual java.lang.String.length:()I
ifne 2
1: StackMap locals:
StackMap stack:
new java.lang.IllegalArgumentException
dup
ldc "missing provider"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
invokestatic java.security.Policy.checkPermission:(Ljava/lang/String;)V
3: ldc "Policy"
4: ldc Ljava/security/PolicySpi;
5: aload 0
6: aload 1
7: aload 2
8: invokestatic sun.security.jca.GetInstance.getInstance:(Ljava/lang/String;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)Lsun/security/jca/GetInstance$Instance;
astore 3
start local 3 9: new java.security.Policy$PolicyDelegate
dup
aload 3
getfield sun.security.jca.GetInstance$Instance.impl:Ljava/lang/Object;
checkcast java.security.PolicySpi
10: aload 3
getfield sun.security.jca.GetInstance$Instance.provider:Ljava/security/Provider;
11: aload 0
12: aload 1
13: invokespecial java.security.Policy$PolicyDelegate.<init>:(Ljava/security/PolicySpi;Ljava/security/Provider;Ljava/lang/String;Ljava/security/Policy$Parameters;)V
14: areturn
end local 3 15: StackMap locals:
StackMap stack: java.security.NoSuchAlgorithmException
astore 3
start local 3 16: aload 3
invokestatic java.security.Policy.handleException:(Ljava/security/NoSuchAlgorithmException;)Ljava/security/Policy;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 type Ljava/lang/String;
0 17 1 params Ljava/security/Policy$Parameters;
0 17 2 provider Ljava/lang/String;
9 15 3 instance Lsun/security/jca/GetInstance$Instance;
16 17 3 nsae Ljava/security/NoSuchAlgorithmException;
Exception table:
from to target type
3 14 15 Class java.security.NoSuchAlgorithmException
Exceptions:
throws java.security.NoSuchProviderException, java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
type
params
provider
public static java.security.Policy getInstance(java.lang.String, java.security.Policy$Parameters, java.security.Provider);
descriptor: (Ljava/lang/String;Ljava/security/Policy$Parameters;Ljava/security/Provider;)Ljava/security/Policy;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=6, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 2
ifnonnull 2
1: new java.lang.IllegalArgumentException
dup
ldc "missing provider"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
invokestatic java.security.Policy.checkPermission:(Ljava/lang/String;)V
3: ldc "Policy"
4: ldc Ljava/security/PolicySpi;
5: aload 0
6: aload 1
7: aload 2
8: invokestatic sun.security.jca.GetInstance.getInstance:(Ljava/lang/String;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Object;Ljava/security/Provider;)Lsun/security/jca/GetInstance$Instance;
astore 3
start local 3 9: new java.security.Policy$PolicyDelegate
dup
aload 3
getfield sun.security.jca.GetInstance$Instance.impl:Ljava/lang/Object;
checkcast java.security.PolicySpi
10: aload 3
getfield sun.security.jca.GetInstance$Instance.provider:Ljava/security/Provider;
11: aload 0
12: aload 1
13: invokespecial java.security.Policy$PolicyDelegate.<init>:(Ljava/security/PolicySpi;Ljava/security/Provider;Ljava/lang/String;Ljava/security/Policy$Parameters;)V
14: areturn
end local 3 15: StackMap locals:
StackMap stack: java.security.NoSuchAlgorithmException
astore 3
start local 3 16: aload 3
invokestatic java.security.Policy.handleException:(Ljava/security/NoSuchAlgorithmException;)Ljava/security/Policy;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 type Ljava/lang/String;
0 17 1 params Ljava/security/Policy$Parameters;
0 17 2 provider Ljava/security/Provider;
9 15 3 instance Lsun/security/jca/GetInstance$Instance;
16 17 3 nsae Ljava/security/NoSuchAlgorithmException;
Exception table:
from to target type
3 14 15 Class java.security.NoSuchAlgorithmException
Exceptions:
throws java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
type
params
provider
private static java.security.Policy handleException(java.security.NoSuchAlgorithmException);
descriptor: (Ljava/security/NoSuchAlgorithmException;)Ljava/security/Policy;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
invokevirtual java.security.NoSuchAlgorithmException.getCause:()Ljava/lang/Throwable;
astore 1
start local 1 1: aload 1
instanceof java.lang.IllegalArgumentException
ifeq 3
2: aload 1
checkcast java.lang.IllegalArgumentException
athrow
3: StackMap locals: java.lang.Throwable
StackMap stack:
aload 0
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 nsae Ljava/security/NoSuchAlgorithmException;
1 4 1 cause Ljava/lang/Throwable;
Exceptions:
throws java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
nsae
public java.security.Provider getProvider();
descriptor: ()Ljava/security/Provider;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/Policy;
public java.lang.String getType();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/Policy;
public java.security.Policy$Parameters getParameters();
descriptor: ()Ljava/security/Policy$Parameters;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/Policy;
public java.security.PermissionCollection getPermissions(java.security.CodeSource);
descriptor: (Ljava/security/CodeSource;)Ljava/security/PermissionCollection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: getstatic java.security.Policy.UNSUPPORTED_EMPTY_COLLECTION:Ljava/security/PermissionCollection;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/Policy;
0 1 1 codesource Ljava/security/CodeSource;
MethodParameters:
Name Flags
codesource
public java.security.PermissionCollection getPermissions(java.security.ProtectionDomain);
descriptor: (Ljava/security/ProtectionDomain;)Ljava/security/PermissionCollection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=2
start local 0 start local 1 0: aconst_null
astore 2
start local 2 1: aload 1
ifnonnull 3
2: new java.security.Permissions
dup
invokespecial java.security.Permissions.<init>:()V
areturn
3: StackMap locals: java.security.PermissionCollection
StackMap stack:
aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
ifnonnull 5
4: aload 0
invokestatic java.security.Policy.initPolicy:(Ljava/security/Policy;)V
5: StackMap locals:
StackMap stack:
aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
dup
astore 3
monitorenter
6: aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
aload 1
getfield java.security.ProtectionDomain.key:Ljava/security/ProtectionDomain$Key;
invokevirtual java.util.WeakHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.security.PermissionCollection
astore 2
7: aload 3
monitorexit
8: goto 11
StackMap locals: java.security.Policy java.security.ProtectionDomain java.security.PermissionCollection java.util.WeakHashMap
StackMap stack: java.lang.Throwable
9: aload 3
monitorexit
10: athrow
11: StackMap locals:
StackMap stack:
aload 2
ifnull 23
12: new java.security.Permissions
dup
invokespecial java.security.Permissions.<init>:()V
astore 3
start local 3 13: aload 2
dup
astore 4
monitorenter
14: aload 2
invokevirtual java.security.PermissionCollection.elements:()Ljava/util/Enumeration;
astore 5
start local 5 15: goto 17
16: StackMap locals: java.security.Permissions java.security.PermissionCollection java.util.Enumeration
StackMap stack:
aload 3
aload 5
invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
checkcast java.security.Permission
invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
17: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Enumeration.hasMoreElements:()Z
ifne 16
end local 5 18: aload 4
monitorexit
19: goto 22
StackMap locals: java.security.Policy java.security.ProtectionDomain java.security.PermissionCollection java.security.Permissions java.security.PermissionCollection
StackMap stack: java.lang.Throwable
20: aload 4
monitorexit
21: athrow
22: StackMap locals:
StackMap stack:
aload 3
areturn
end local 3 23: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual java.security.ProtectionDomain.getCodeSource:()Ljava/security/CodeSource;
invokevirtual java.security.Policy.getPermissions:(Ljava/security/CodeSource;)Ljava/security/PermissionCollection;
astore 2
24: aload 2
ifnull 25
aload 2
getstatic java.security.Policy.UNSUPPORTED_EMPTY_COLLECTION:Ljava/security/PermissionCollection;
if_acmpne 26
25: StackMap locals:
StackMap stack:
new java.security.Permissions
dup
invokespecial java.security.Permissions.<init>:()V
astore 2
26: StackMap locals:
StackMap stack:
aload 0
aload 2
aload 1
invokevirtual java.security.ProtectionDomain.getPermissions:()Ljava/security/PermissionCollection;
invokevirtual java.security.Policy.addStaticPerms:(Ljava/security/PermissionCollection;Ljava/security/PermissionCollection;)V
27: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Ljava/security/Policy;
0 28 1 domain Ljava/security/ProtectionDomain;
1 28 2 pc Ljava/security/PermissionCollection;
13 23 3 perms Ljava/security/Permissions;
15 18 5 e Ljava/util/Enumeration<Ljava/security/Permission;>;
Exception table:
from to target type
6 8 9 any
9 10 9 any
14 19 20 any
20 21 20 any
MethodParameters:
Name Flags
domain
private void addStaticPerms(java.security.PermissionCollection, java.security.PermissionCollection);
descriptor: (Ljava/security/PermissionCollection;Ljava/security/PermissionCollection;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 2
ifnull 10
1: aload 2
dup
astore 3
monitorenter
2: aload 2
invokevirtual java.security.PermissionCollection.elements:()Ljava/util/Enumeration;
astore 4
start local 4 3: goto 5
4: StackMap locals: java.security.PermissionCollection java.util.Enumeration
StackMap stack:
aload 1
aload 4
invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
checkcast java.security.Permission
invokevirtual java.security.PermissionCollection.add:(Ljava/security/Permission;)V
5: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Enumeration.hasMoreElements:()Z
ifne 4
end local 4 6: aload 3
monitorexit
7: goto 10
StackMap locals: java.security.Policy java.security.PermissionCollection java.security.PermissionCollection java.security.PermissionCollection
StackMap stack: java.lang.Throwable
8: aload 3
monitorexit
9: athrow
10: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Ljava/security/Policy;
0 11 1 perms Ljava/security/PermissionCollection;
0 11 2 statics Ljava/security/PermissionCollection;
3 6 4 e Ljava/util/Enumeration<Ljava/security/Permission;>;
Exception table:
from to target type
2 7 8 any
8 9 8 any
MethodParameters:
Name Flags
perms
statics
public boolean implies(java.security.ProtectionDomain, java.security.Permission);
descriptor: (Ljava/security/ProtectionDomain;Ljava/security/Permission;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
ifnonnull 2
1: aload 0
invokestatic java.security.Policy.initPolicy:(Ljava/security/Policy;)V
2: StackMap locals:
StackMap stack:
aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
dup
astore 4
monitorenter
3: aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
aload 1
getfield java.security.ProtectionDomain.key:Ljava/security/ProtectionDomain$Key;
invokevirtual java.util.WeakHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.security.PermissionCollection
astore 3
start local 3 4: aload 4
monitorexit
5: goto 8
end local 3 StackMap locals: java.security.Policy java.security.ProtectionDomain java.security.Permission top java.util.WeakHashMap
StackMap stack: java.lang.Throwable
6: aload 4
monitorexit
7: athrow
start local 3 8: StackMap locals: java.security.Policy java.security.ProtectionDomain java.security.Permission java.security.PermissionCollection
StackMap stack:
aload 3
ifnull 10
9: aload 3
aload 2
invokevirtual java.security.PermissionCollection.implies:(Ljava/security/Permission;)Z
ireturn
10: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual java.security.Policy.getPermissions:(Ljava/security/ProtectionDomain;)Ljava/security/PermissionCollection;
astore 3
11: aload 3
ifnonnull 13
12: iconst_0
ireturn
13: StackMap locals:
StackMap stack:
aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
dup
astore 4
monitorenter
14: aload 0
getfield java.security.Policy.pdMapping:Ljava/util/WeakHashMap;
aload 1
getfield java.security.ProtectionDomain.key:Ljava/security/ProtectionDomain$Key;
aload 3
invokevirtual java.util.WeakHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
15: aload 4
monitorexit
16: goto 19
StackMap locals: java.security.Policy java.security.ProtectionDomain java.security.Permission java.security.PermissionCollection java.util.WeakHashMap
StackMap stack: java.lang.Throwable
17: aload 4
monitorexit
18: athrow
19: StackMap locals:
StackMap stack:
aload 3
aload 2
invokevirtual java.security.PermissionCollection.implies:(Ljava/security/Permission;)Z
ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Ljava/security/Policy;
0 20 1 domain Ljava/security/ProtectionDomain;
0 20 2 permission Ljava/security/Permission;
4 6 3 pc Ljava/security/PermissionCollection;
8 20 3 pc Ljava/security/PermissionCollection;
Exception table:
from to target type
3 5 6 any
6 7 6 any
14 16 17 any
17 18 17 any
MethodParameters:
Name Flags
domain
permission
public void refresh();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=0, locals=1, args_size=1
start local 0 0: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/Policy;
}
SourceFile: "Policy.java"
NestMembers:
java.security.Policy$1 java.security.Policy$2 java.security.Policy$3 java.security.Policy$Parameters java.security.Policy$PolicyDelegate java.security.Policy$PolicyInfo java.security.Policy$UnsupportedEmptyCollection
InnerClasses:
java.security.Policy$1
java.security.Policy$2
java.security.Policy$3
public abstract Parameters = java.security.Policy$Parameters of java.security.Policy
private PolicyDelegate = java.security.Policy$PolicyDelegate of java.security.Policy
private PolicyInfo = java.security.Policy$PolicyInfo of java.security.Policy
private UnsupportedEmptyCollection = java.security.Policy$UnsupportedEmptyCollection of java.security.Policy
final Key = java.security.ProtectionDomain$Key of java.security.ProtectionDomain
public final Instance = sun.security.jca.GetInstance$Instance of sun.security.jca.GetInstance