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: .line 67
            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 // org.apache.logging.log4j.core.script.ScriptManager this
        start local 1 // org.apache.logging.log4j.core.config.Configuration configuration
        start local 2 // org.apache.logging.log4j.core.util.WatchManager watchManager
         0: .line 75
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 70
            aload 0 /* this */
            new javax.script.ScriptEngineManager
            dup
            invokespecial javax.script.ScriptEngineManager.<init>:()V
            putfield org.apache.logging.log4j.core.script.ScriptManager.manager:Ljavax/script/ScriptEngineManager;
         2: .line 71
            aload 0 /* this */
            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: .line 76
            aload 0 /* this */
            aload 1 /* configuration */
            putfield org.apache.logging.log4j.core.script.ScriptManager.configuration:Lorg/apache/logging/log4j/core/config/Configuration;
         4: .line 77
            aload 0 /* this */
            aload 2 /* watchManager */
            putfield org.apache.logging.log4j.core.script.ScriptManager.watchManager:Lorg/apache/logging/log4j/core/util/WatchManager;
         5: .line 78
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.manager:Ljavax/script/ScriptEngineManager;
            invokevirtual javax.script.ScriptEngineManager.getEngineFactories:()Ljava/util/List;
            astore 3 /* factories */
        start local 3 // java.util.List factories
         6: .line 79
            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: .line 80
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 4 /* sb */
        start local 4 // java.lang.StringBuilder sb
         8: .line 81
            aload 3 /* factories */
            invokeinterface java.util.List.size:()I
            istore 5 /* factorySize */
        start local 5 // int factorySize
         9: .line 82
            getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
            ldc "Installed {} script engine{}"
            iload 5 /* factorySize */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            iload 5 /* factorySize */
            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: .line 83
            aload 3 /* factories */
            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 /* factory */
        start local 6 // javax.script.ScriptEngineFactory factory
        14: .line 84
            aload 6 /* factory */
            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 /* threading */
        start local 8 // java.lang.String threading
        15: .line 85
            aload 8 /* threading */
            ifnonnull 17
        16: .line 86
            ldc "Not Thread Safe"
            astore 8 /* threading */
        17: .line 88
      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 /* names */
        start local 9 // java.lang.StringBuilder names
        18: .line 89
            aload 6 /* factory */
            invokeinterface javax.script.ScriptEngineFactory.getNames:()Ljava/util/List;
            astore 10 /* languageNames */
        start local 10 // java.util.List languageNames
        19: .line 90
            aload 10 /* languageNames */
            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 /* name */
        start local 11 // java.lang.String name
        21: .line 91
            aload 9 /* names */
            invokevirtual java.lang.StringBuilder.length:()I
            ifle 23
        22: .line 92
            aload 9 /* names */
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        23: .line 94
      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 /* names */
            aload 11 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 11 // java.lang.String name
        24: .line 90
      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: .line 96
            aload 4 /* sb */
            invokevirtual java.lang.StringBuilder.length:()I
            ifle 27
        26: .line 97
            aload 4 /* sb */
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        27: .line 99
      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 /* sb */
            aload 9 /* names */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;)Ljava/lang/StringBuilder;
            pop
        28: .line 100
            aload 6 /* factory */
            invokeinterface javax.script.ScriptEngineFactory.getScriptEngine:()Ljavax/script/ScriptEngine;
            instanceof javax.script.Compilable
            istore 11 /* compiled */
        start local 11 // boolean compiled
        29: .line 101
            getstatic org.apache.logging.log4j.core.script.ScriptManager.logger:Lorg/apache/logging/log4j/Logger;
            ldc "{} version: {}, language: {}, threading: {}, compile: {}, names: {}, factory class: {}"
        30: .line 102
            aload 6 /* factory */
            invokeinterface javax.script.ScriptEngineFactory.getEngineName:()Ljava/lang/String;
            aload 6 /* factory */
            invokeinterface javax.script.ScriptEngineFactory.getEngineVersion:()Ljava/lang/String;
            aload 6 /* factory */
            invokeinterface javax.script.ScriptEngineFactory.getLanguageName:()Ljava/lang/String;
            aload 8 /* threading */
        31: .line 103
            iload 11 /* compiled */
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            aload 10 /* languageNames */
            aload 6 /* factory */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
        32: .line 101
            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 // boolean compiled
        end local 10 // java.util.List languageNames
        end local 9 // java.lang.StringBuilder names
        end local 8 // java.lang.String threading
        end local 6 // javax.script.ScriptEngineFactory factory
        33: .line 83
      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: .line 105
            aload 0 /* this */
            aload 4 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            putfield org.apache.logging.log4j.core.script.ScriptManager.languages:Ljava/lang/String;
        end local 5 // int factorySize
        end local 4 // java.lang.StringBuilder sb
        35: .line 106
            goto 47
        36: .line 107
      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 /* names */
        start local 4 // java.lang.StringBuilder names
        37: .line 108
            aload 3 /* factories */
            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 /* factory */
        start local 5 // javax.script.ScriptEngineFactory factory
        39: .line 109
            aload 5 /* factory */
            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 /* name */
        start local 7 // java.lang.String name
        41: .line 110
            aload 4 /* names */
            invokevirtual java.lang.StringBuilder.length:()I
            ifle 43
        42: .line 111
            aload 4 /* names */
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        43: .line 113
      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 /* names */
            aload 7 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 7 // java.lang.String name
        44: .line 109
      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 // javax.script.ScriptEngineFactory factory
        45: .line 108
      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: .line 116
            aload 0 /* this */
            aload 4 /* names */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            putfield org.apache.logging.log4j.core.script.ScriptManager.languages:Ljava/lang/String;
        end local 4 // java.lang.StringBuilder names
        47: .line 118
      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 // java.util.List factories
        end local 2 // org.apache.logging.log4j.core.util.WatchManager watchManager
        end local 1 // org.apache.logging.log4j.core.config.Configuration configuration
        end local 0 // org.apache.logging.log4j.core.script.ScriptManager this
      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 // org.apache.logging.log4j.core.script.ScriptManager this
        start local 1 // org.apache.logging.log4j.core.script.AbstractScript script
         0: .line 121
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.manager:Ljavax/script/ScriptEngineManager;
            aload 1 /* script */
            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 /* engine */
        start local 2 // javax.script.ScriptEngine engine
         1: .line 122
            aload 2 /* engine */
            ifnonnull 6
         2: .line 123
            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 /* script */
            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: .line 124
            aload 0 /* this */
            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: .line 123
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;)V
         5: .line 125
            return
         6: .line 127
      StackMap locals: javax.script.ScriptEngine
      StackMap stack:
            aload 2 /* engine */
            invokeinterface javax.script.ScriptEngine.getFactory:()Ljavax/script/ScriptEngineFactory;
            ldc "THREADING"
            invokeinterface javax.script.ScriptEngineFactory.getParameter:(Ljava/lang/String;)Ljava/lang/Object;
            ifnonnull 9
         7: .line 128
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* script */
            invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
            new org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner
            dup
            aload 0 /* this */
            aload 1 /* script */
            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: .line 129
            goto 10
         9: .line 130
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* script */
            invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
            new org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner
            dup
            aload 0 /* this */
            aload 2 /* engine */
            aload 1 /* script */
            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: .line 133
      StackMap locals:
      StackMap stack:
            aload 1 /* script */
            instanceof org.apache.logging.log4j.core.script.ScriptFile
            ifeq 15
        11: .line 134
            aload 1 /* script */
            checkcast org.apache.logging.log4j.core.script.ScriptFile
            astore 3 /* scriptFile */
        start local 3 // org.apache.logging.log4j.core.script.ScriptFile scriptFile
        12: .line 135
            aload 3 /* scriptFile */
            invokevirtual org.apache.logging.log4j.core.script.ScriptFile.getPath:()Ljava/nio/file/Path;
            astore 4 /* path */
        start local 4 // java.nio.file.Path path
        13: .line 136
            aload 3 /* scriptFile */
            invokevirtual org.apache.logging.log4j.core.script.ScriptFile.isWatched:()Z
            ifeq 15
            aload 4 /* path */
            ifnull 15
        14: .line 137
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.watchManager:Lorg/apache/logging/log4j/core/util/WatchManager;
            aload 4 /* path */
            invokeinterface java.nio.file.Path.toFile:()Ljava/io/File;
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.util.WatchManager.watchFile:(Ljava/io/File;Lorg/apache/logging/log4j/core/util/FileWatcher;)V
        end local 4 // java.nio.file.Path path
        end local 3 // org.apache.logging.log4j.core.script.ScriptFile scriptFile
        15: .line 140
      StackMap locals:
      StackMap stack:
            return
        end local 2 // javax.script.ScriptEngine engine
        end local 1 // org.apache.logging.log4j.core.script.AbstractScript script
        end local 0 // org.apache.logging.log4j.core.script.ScriptManager this
      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 // org.apache.logging.log4j.core.script.ScriptManager this
        start local 1 // org.apache.logging.log4j.core.script.AbstractScript script
         0: .line 143
            aload 0 /* this */
            aload 1 /* script */
            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 // org.apache.logging.log4j.core.script.AbstractScript script
        end local 0 // org.apache.logging.log4j.core.script.ScriptManager this
      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 // org.apache.logging.log4j.core.script.ScriptManager this
        start local 1 // java.lang.String name
         0: .line 147
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* name */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
            astore 2 /* runner */
        start local 2 // org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner runner
         1: .line 148
            aload 2 /* runner */
            ifnull 2
            aload 2 /* runner */
            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 // org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner runner
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.script.ScriptManager this
      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 // org.apache.logging.log4j.core.script.ScriptManager this
        start local 1 // java.io.File file
         0: .line 153
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* file */
            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 /* runner */
        start local 2 // org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner runner
         1: .line 154
            aload 2 /* runner */
            ifnonnull 4
         2: .line 155
            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: .line 156
            return
         4: .line 158
      StackMap locals: org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
      StackMap stack:
            aload 2 /* runner */
            invokeinterface org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner.getScriptEngine:()Ljavax/script/ScriptEngine;
            astore 3 /* engine */
        start local 3 // javax.script.ScriptEngine engine
         5: .line 159
            aload 2 /* runner */
            invokeinterface org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner.getScript:()Lorg/apache/logging/log4j/core/script/AbstractScript;
            astore 4 /* script */
        start local 4 // org.apache.logging.log4j.core.script.AbstractScript script
         6: .line 160
            aload 3 /* engine */
            invokeinterface javax.script.ScriptEngine.getFactory:()Ljavax/script/ScriptEngineFactory;
            ldc "THREADING"
            invokeinterface javax.script.ScriptEngineFactory.getParameter:(Ljava/lang/String;)Ljava/lang/Object;
            ifnonnull 9
         7: .line 161
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 4 /* script */
            invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
            new org.apache.logging.log4j.core.script.ScriptManager$ThreadLocalScriptRunner
            dup
            aload 0 /* this */
            aload 4 /* script */
            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: .line 162
            goto 10
         9: .line 163
      StackMap locals: javax.script.ScriptEngine org.apache.logging.log4j.core.script.AbstractScript
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 4 /* script */
            invokevirtual org.apache.logging.log4j.core.script.AbstractScript.getName:()Ljava/lang/String;
            new org.apache.logging.log4j.core.script.ScriptManager$MainScriptRunner
            dup
            aload 0 /* this */
            aload 3 /* engine */
            aload 4 /* script */
            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: .line 166
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.apache.logging.log4j.core.script.AbstractScript script
        end local 3 // javax.script.ScriptEngine engine
        end local 2 // org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner runner
        end local 1 // java.io.File file
        end local 0 // org.apache.logging.log4j.core.script.ScriptManager this
      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 // org.apache.logging.log4j.core.script.ScriptManager this
        start local 1 // java.lang.String name
        start local 2 // javax.script.Bindings bindings
         0: .line 169
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* name */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
            astore 3 /* scriptRunner */
        start local 3 // org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner scriptRunner
         1: .line 170
            aload 3 /* scriptRunner */
            ifnonnull 4
         2: .line 171
            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: .line 172
            aconst_null
            areturn
         4: .line 174
      StackMap locals: org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner
      StackMap stack:
            new org.apache.logging.log4j.core.script.ScriptManager$1
            dup
            aload 0 /* this */
            aload 3 /* scriptRunner */
            aload 2 /* bindings */
            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 // org.apache.logging.log4j.core.script.ScriptManager$ScriptRunner scriptRunner
        end local 2 // javax.script.Bindings bindings
        end local 1 // java.lang.String name
        end local 0 // org.apache.logging.log4j.core.script.ScriptManager this
      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 // org.apache.logging.log4j.core.script.ScriptManager this
        start local 1 // org.apache.logging.log4j.core.script.AbstractScript script
         0: .line 284
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.script.ScriptManager.scriptRunners:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* script */
            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 // org.apache.logging.log4j.core.script.AbstractScript script
        end local 0 // org.apache.logging.log4j.core.script.ScriptManager this
      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