public class org.apache.logging.log4j.core.script.ScriptManager implements org.apache.logging.log4j.core.util.FileWatcher, java.io.Serializable
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.logging.log4j.core.script.ScriptManager
super_class: java.lang.Object
{
private static final long serialVersionUID;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: -2534169384971965196
private static final java.lang.String KEY_THREADING;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "THREADING"
private static final org.apache.logging.log4j.Logger logger;
descriptor: Lorg/apache/logging/log4j/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private final org.apache.logging.log4j.core.config.Configuration configuration;
descriptor: Lorg/apache/logging/log4j/core/config/Configuration;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final javax.script.ScriptEngineManager manager;
descriptor: Ljavax/script/ScriptEngineManager;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.ConcurrentMap<java.lang.String, org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner> scriptRunners;
descriptor: Ljava/util/concurrent/ConcurrentMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Lorg/apache/logging/log4j/core/script/ScriptManager$ScriptRunner;>;
private final java.lang.String languages;
descriptor: Ljava/lang/String;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.apache.logging.log4j.core.util.WatchManager watchManager;
descriptor: Lorg/apache/logging/log4j/core/util/WatchManager;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
putstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(org.apache.logging.log4j.core.config.Configuration, org.apache.logging.log4j.core.util.WatchManager);
descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;Lorg/apache/logging/log4j/core/util/WatchManager;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=9, locals=13, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new javax.script.ScriptEngineManager
dup
invokespecial javax.script.ScriptEngineManager.<init>:()V
putfield org.apache.logging.log4j.core.script.ScriptManager.manager:Ljavax/script/ScriptEngineManager;
2: aload 0
new java.util.concurrent.ConcurrentHashMap
dup
invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
putfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
3: aload 0
aload 1
putfield org.apache.logging.log4j.core.script.ScriptManager.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
4: aload 0
aload 2
putfield org.apache.logging.log4j.core.script.ScriptManager.watchManager:Lorg/apache/logging/log4j/core/util/WatchManager;
5: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.manager:Ljavax/script/ScriptEngineManager;
invokevirtual javax.script.ScriptEngineManager.getEngineFactories:()Ljava/util/List;
astore 3
start local 3 6: getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
invokeinterface org.apache.logging.log4j.Logger.isDebugEnabled:()Z
ifeq 36
7: new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 4
start local 4 8: aload 3
invokeinterface java.util.List.size:()I
istore 5
start local 5 9: getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
ldc "Installed {} script engine{}"
iload 5
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
iload 5
iconst_1
if_icmpeq 10
ldc "s"
goto 11
StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int
StackMap stack: org.apache.logging.log4j.Logger java.lang.String java.lang.Integer
10: ldc ""
StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int
StackMap stack: org.apache.logging.log4j.Logger java.lang.String java.lang.Integer java.lang.String
11: invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
12: aload 3
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 7
goto 33
StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int top java.util.Iterator
StackMap stack:
13: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast javax.script.ScriptEngineFactory
astore 6
start local 6 14: aload 6
ldc "THREADING"
invokeinterface javax.script.ScriptEngineFactory.getParameter:(Ljava/lang/String;)Ljava/lang/Object;
aconst_null
invokestatic java.util.Objects.toString:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/String;
astore 8
start local 8 15: aload 8
ifnonnull 17
16: ldc "Not Thread Safe"
astore 8
17: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int javax.script.ScriptEngineFactory java.util.Iterator java.lang.String
StackMap stack:
new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 9
start local 9 18: aload 6
invokeinterface javax.script.ScriptEngineFactory.getNames:()Ljava/util/List;
astore 10
start local 10 19: aload 10
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 12
goto 24
StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int javax.script.ScriptEngineFactory java.util.Iterator java.lang.String java.lang.StringBuilder java.util.List top java.util.Iterator
StackMap stack:
20: aload 12
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 11
start local 11 21: aload 9
invokevirtual java.lang.StringBuilder.length:()I
ifle 23
22: aload 9
ldc ", "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
23: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int javax.script.ScriptEngineFactory java.util.Iterator java.lang.String java.lang.StringBuilder java.util.List java.lang.String java.util.Iterator
StackMap stack:
aload 9
aload 11
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 11 24: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int javax.script.ScriptEngineFactory java.util.Iterator java.lang.String java.lang.StringBuilder java.util.List top java.util.Iterator
StackMap stack:
aload 12
invokeinterface java.util.Iterator.hasNext:()Z
ifne 20
25: aload 4
invokevirtual java.lang.StringBuilder.length:()I
ifle 27
26: aload 4
ldc ", "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
27: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int javax.script.ScriptEngineFactory java.util.Iterator java.lang.String java.lang.StringBuilder java.util.List
StackMap stack:
aload 4
aload 9
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;)Ljava/lang/StringBuilder;
pop
28: aload 6
invokeinterface javax.script.ScriptEngineFactory.getScriptEngine:()Ljavax/script/ScriptEngine;
instanceof javax.script.Compilable
istore 11
start local 11 29: getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
ldc "{} version: {}, language: {}, threading: {}, compile: {}, names: {}, factory class: {}"
30: aload 6
invokeinterface javax.script.ScriptEngineFactory.getEngineName:()Ljava/lang/String;
aload 6
invokeinterface javax.script.ScriptEngineFactory.getEngineVersion:()Ljava/lang/String;
aload 6
invokeinterface javax.script.ScriptEngineFactory.getLanguageName:()Ljava/lang/String;
aload 8
31: iload 11
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
aload 10
aload 6
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
32: invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
end local 11 end local 10 end local 9 end local 8 end local 6 33: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder int top java.util.Iterator
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 13
34: aload 0
aload 4
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
putfield org.apache.logging.log4j.core.script.ScriptManager.languages:Ljava/lang/String;
end local 5 end local 4 35: goto 47
36: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List
StackMap stack:
new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 4
start local 4 37: aload 3
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 6
goto 45
StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder top java.util.Iterator
StackMap stack:
38: aload 6
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast javax.script.ScriptEngineFactory
astore 5
start local 5 39: aload 5
invokeinterface javax.script.ScriptEngineFactory.getNames:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 8
goto 44
StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder javax.script.ScriptEngineFactory java.util.Iterator top java.util.Iterator
StackMap stack:
40: aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 7
start local 7 41: aload 4
invokevirtual java.lang.StringBuilder.length:()I
ifle 43
42: aload 4
ldc ", "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
43: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder javax.script.ScriptEngineFactory java.util.Iterator java.lang.String java.util.Iterator
StackMap stack:
aload 4
aload 7
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 7 44: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder javax.script.ScriptEngineFactory java.util.Iterator top java.util.Iterator
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 40
end local 5 45: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List java.lang.StringBuilder top java.util.Iterator
StackMap stack:
aload 6
invokeinterface java.util.Iterator.hasNext:()Z
ifne 38
46: aload 0
aload 4
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
putfield org.apache.logging.log4j.core.script.ScriptManager.languages:Ljava/lang/String;
end local 4 47: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager org.apache.logging.log4j.core.config.Configuration org.apache.logging.log4j.core.util.WatchManager java.util.List
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 48 0 this Lorg/apache/logging/log4j/core/script/ScriptManager;
0 48 1 configuration Lorg/apache/logging/log4j/core/config/Configuration;
0 48 2 watchManager Lorg/apache/logging/log4j/core/util/WatchManager;
6 48 3 factories Ljava/util/List<Ljavax/script/ScriptEngineFactory;>;
8 35 4 sb Ljava/lang/StringBuilder;
9 35 5 factorySize I
14 33 6 factory Ljavax/script/ScriptEngineFactory;
15 33 8 threading Ljava/lang/String;
18 33 9 names Ljava/lang/StringBuilder;
19 33 10 languageNames Ljava/util/List<Ljava/lang/String;>;
21 24 11 name Ljava/lang/String;
29 33 11 compiled Z
37 47 4 names Ljava/lang/StringBuilder;
39 45 5 factory Ljavax/script/ScriptEngineFactory;
41 44 7 name Ljava/lang/String;
MethodParameters:
Name Flags
configuration final
watchManager final
public void addScript(org.apache.logging.log4j.core.script.AbstractScript);
descriptor: (Lorg/apache/logging/log4j/core/script/AbstractScript;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=5, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.manager:Ljavax/script/ScriptEngineManager;
aload 1
invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getLanguage:()Ljava/lang/String;
invokevirtual javax.script.ScriptEngineManager.getEngineByName:(Ljava/lang/String;)Ljavax/script/ScriptEngine;
astore 2
start local 2 1: aload 2
ifnonnull 6
2: getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
new java.lang.StringBuilder
dup
ldc "No ScriptEngine found for language "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getLanguage:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ". Available languages are: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
3: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.languages:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
4: invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;)V
5: return
6: StackMap locals: javax.script.ScriptEngine
StackMap stack:
aload 2
invokeinterface javax.script.ScriptEngine.getFactory:()Ljavax/script/ScriptEngineFactory;
ldc "THREADING"
invokeinterface javax.script.ScriptEngineFactory.getParameter:(Ljava/lang/String;)Ljava/lang/Object;
ifnonnull 9
7: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 1
invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
new org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner
dup
aload 0
aload 1
invokespecial org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner.<init>:(Lorg/apache/logging/log4j/core/script/ScriptManager;Lorg/apache/logging/log4j/core/script/AbstractScript;)V
invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
8: goto 10
9: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 1
invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
new org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner
dup
aload 0
aload 2
aload 1
invokespecial org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner.<init>:(Lorg/apache/logging/log4j/core/script/ScriptManager;Ljavax/script/ScriptEngine;Lorg/apache/logging/log4j/core/script/AbstractScript;)V
invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
10: StackMap locals:
StackMap stack:
aload 1
instanceof org.apache.logging.log4j.core.script.ScriptFile
ifeq 15
11: aload 1
checkcast org.apache.logging.log4j.core.script.ScriptFile
astore 3
start local 3 12: aload 3
invokevirtual org.apache.logging.log4j.core.script.ScriptFile.getPath:()Ljava/nio/file/Path;
astore 4
start local 4 13: aload 3
invokevirtual org.apache.logging.log4j.core.script.ScriptFile.isWatched:()Z
ifeq 15
aload 4
ifnull 15
14: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.watchManager:Lorg/apache/logging/log4j/core/util/WatchManager;
aload 4
invokeinterface java.nio.file.Path.toFile:()Ljava/io/File;
aload 0
invokevirtual org.apache.logging.log4j.core.util.WatchManager.watchFile:(Ljava/io/File;Lorg/apache/logging/log4j/core/util/FileWatcher;)V
end local 4 end local 3 15: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/apache/logging/log4j/core/script/ScriptManager;
0 16 1 script Lorg/apache/logging/log4j/core/script/AbstractScript;
1 16 2 engine Ljavax/script/ScriptEngine;
12 15 3 scriptFile Lorg/apache/logging/log4j/core/script/ScriptFile;
13 15 4 path Ljava/nio/file/Path;
MethodParameters:
Name Flags
script final
public javax.script.Bindings createBindings(org.apache.logging.log4j.core.script.AbstractScript);
descriptor: (Lorg/apache/logging/log4j/core/script/AbstractScript;)Ljavax/script/Bindings;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual org.apache.logging.log4j.core.script.ScriptManager.getScriptRunner:(Lorg/apache/logging/log4j/core/script/AbstractScript;)Lorg/apache/logging/log4j/core/script/ScriptManager$ScriptRunner;
invokeinterface org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner.createBindings:()Ljavax/script/Bindings;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/script/ScriptManager;
0 1 1 script Lorg/apache/logging/log4j/core/script/AbstractScript;
MethodParameters:
Name Flags
script final
public org.apache.logging.log4j.core.script.AbstractScript getScript(java.lang.String);
descriptor: (Ljava/lang/String;)Lorg/apache/logging/log4j/core/script/AbstractScript;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 1
invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
astore 2
start local 2 1: aload 2
ifnull 2
aload 2
invokeinterface org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner.getScript:()Lorg/apache/logging/log4j/core/script/AbstractScript;
goto 3
StackMap locals: org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
StackMap stack:
2: aconst_null
StackMap locals:
StackMap stack: org.apache.logging.log4j.core.script.AbstractScript
3: areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/logging/log4j/core/script/ScriptManager;
0 4 1 name Ljava/lang/String;
1 4 2 runner Lorg/apache/logging/log4j/core/script/ScriptManager$ScriptRunner;
MethodParameters:
Name Flags
name final
public void fileModified(java.io.File);
descriptor: (Ljava/io/File;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=5, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 1
invokevirtual java.io.File.toString:()Ljava/lang/String;
invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
astore 2
start local 2 1: aload 2
ifnonnull 4
2: getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
ldc "{} is not a running script"
invokeinterface org.apache.logging.log4j.Logger.info:(Ljava/lang/String;)V
3: return
4: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
StackMap stack:
aload 2
invokeinterface org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner.getScriptEngine:()Ljavax/script/ScriptEngine;
astore 3
start local 3 5: aload 2
invokeinterface org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner.getScript:()Lorg/apache/logging/log4j/core/script/AbstractScript;
astore 4
start local 4 6: aload 3
invokeinterface javax.script.ScriptEngine.getFactory:()Ljavax/script/ScriptEngineFactory;
ldc "THREADING"
invokeinterface javax.script.ScriptEngineFactory.getParameter:(Ljava/lang/String;)Ljava/lang/Object;
ifnonnull 9
7: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 4
invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
new org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner
dup
aload 0
aload 4
invokespecial org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner.<init>:(Lorg/apache/logging/log4j/core/script/ScriptManager;Lorg/apache/logging/log4j/core/script/AbstractScript;)V
invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
8: goto 10
9: StackMap locals: javax.script.ScriptEngine org.apache.logging.log4j.core.script.AbstractScript
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 4
invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
new org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner
dup
aload 0
aload 3
aload 4
invokespecial org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner.<init>:(Lorg/apache/logging/log4j/core/script/ScriptManager;Ljavax/script/ScriptEngine;Lorg/apache/logging/log4j/core/script/AbstractScript;)V
invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
10: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/apache/logging/log4j/core/script/ScriptManager;
0 11 1 file Ljava/io/File;
1 11 2 runner Lorg/apache/logging/log4j/core/script/ScriptManager$ScriptRunner;
5 11 3 engine Ljavax/script/ScriptEngine;
6 11 4 script Lorg/apache/logging/log4j/core/script/AbstractScript;
MethodParameters:
Name Flags
file final
public java.lang.Object execute(java.lang.String, javax.script.Bindings);
descriptor: (Ljava/lang/String;Ljavax/script/Bindings;)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 1
invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
astore 3
start local 3 1: aload 3
ifnonnull 4
2: getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
ldc "No script named {} could be found"
invokeinterface org.apache.logging.log4j.Logger.warn:(Ljava/lang/String;)V
3: aconst_null
areturn
4: StackMap locals: org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
StackMap stack:
new org.apache.logging.log4j.core.script.ScriptManager$1
dup
aload 0
aload 3
aload 2
invokespecial org.apache.logging.log4j.core.script.ScriptManager$1.<init>:(Lorg/apache/logging/log4j/core/script/ScriptManager;Lorg/apache/logging/log4j/core/script/ScriptManager$ScriptRunner;Ljavax/script/Bindings;)V
invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/logging/log4j/core/script/ScriptManager;
0 5 1 name Ljava/lang/String;
0 5 2 bindings Ljavax/script/Bindings;
1 5 3 scriptRunner Lorg/apache/logging/log4j/core/script/ScriptManager$ScriptRunner;
MethodParameters:
Name Flags
name final
bindings final
private org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner getScriptRunner(org.apache.logging.log4j.core.script.AbstractScript);
descriptor: (Lorg/apache/logging/log4j/core/script/AbstractScript;)Lorg/apache/logging/log4j/core/script/ScriptManager$ScriptRunner;
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
aload 1
invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/script/ScriptManager;
0 1 1 script Lorg/apache/logging/log4j/core/script/AbstractScript;
MethodParameters:
Name Flags
script final
}
SourceFile: "ScriptManager.java"
NestMembers:
org.apache.logging.log4j.core.script.ScriptManager$1 org.apache.logging.log4j.core.script.ScriptManager$AbstractScriptRunner org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner$1 org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner$1
InnerClasses:
org.apache.logging.log4j.core.script.ScriptManager$1
private abstract AbstractScriptRunner = org.apache.logging.log4j.core.script.ScriptManager$AbstractScriptRunner of org.apache.logging.log4j.core.script.ScriptManager
private MainScriptRunner = org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner of org.apache.logging.log4j.core.script.ScriptManager
private abstract ScriptRunner = org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner of org.apache.logging.log4j.core.script.ScriptManager
private ThreadLocalScriptRunner = org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner of org.apache.logging.log4j.core.script.ScriptManager