final class org.apache.logging.log4j.core.util.WatchManager$WatchRunnable implements java.lang.Runnable
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: org.apache.logging.log4j.core.util.WatchManager$WatchRunnable
super_class: java.lang.Object
{
private final java.lang.String SIMPLE_NAME;
descriptor: Ljava/lang/String;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
final org.apache.logging.log4j.core.util.WatchManager this$0;
descriptor: Lorg/apache/logging/log4j/core/util/WatchManager;
flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC
private void <init>(org.apache.logging.log4j.core.util.WatchManager);
descriptor: (Lorg/apache/logging/log4j/core/util/WatchManager;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 0: aload 0
aload 1
putfield org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.this$0:Lorg/apache/logging/log4j/core/util/WatchManager;
aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
ldc Lorg/apache/logging/log4j/core/util/WatchManager$WatchRunnable;
invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
putfield org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.SIMPLE_NAME:Ljava/lang/String;
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/logging/log4j/core/util/WatchManager$WatchRunnable;
MethodParameters:
Name Flags
this$0 final
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=7, args_size=1
start local 0 0: getstatic org.apache.logging.log4j.core.util.WatchManager.logger:Lorg/apache/logging/log4j/Logger;
ldc "{} run triggered."
aload 0
getfield org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.SIMPLE_NAME:Ljava/lang/String;
invokeinterface org.apache.logging.log4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
1: aload 0
getfield org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.this$0:Lorg/apache/logging/log4j/core/util/WatchManager;
getfield org.apache.logging.log4j.core.util.WatchManager.watchers:Ljava/util/concurrent/ConcurrentMap;
invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 2
goto 14
StackMap locals: org.apache.logging.log4j.core.util.WatchManager$WatchRunnable top java.util.Iterator
StackMap stack:
2: aload 2
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.Map$Entry
astore 1
start local 1 3: aload 1
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
checkcast java.io.File
astore 3
start local 3 4: aload 1
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.util.WatchManager$FileMonitor
astore 4
start local 4 5: aload 3
invokevirtual java.io.File.lastModified:()J
lstore 5
start local 5 6: aload 0
aload 4
lload 5
invokevirtual org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.fileModified:(Lorg/apache/logging/log4j/core/util/WatchManager$FileMonitor;J)Z
ifeq 14
7: getstatic org.apache.logging.log4j.core.util.WatchManager.logger:Lorg/apache/logging/log4j/Logger;
invokeinterface org.apache.logging.log4j.Logger.isInfoEnabled:()Z
ifeq 12
8: getstatic org.apache.logging.log4j.core.util.WatchManager.logger:Lorg/apache/logging/log4j/Logger;
ldc "File '{}' was modified on {} ({}), previous modification was on {} ({})"
aload 3
9: aload 0
getfield org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.this$0:Lorg/apache/logging/log4j/core/util/WatchManager;
lload 5
invokevirtual org.apache.logging.log4j.core.util.WatchManager.millisToString:(J)Ljava/lang/String;
lload 5
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
aload 0
getfield org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.this$0:Lorg/apache/logging/log4j/core/util/WatchManager;
aload 4
getfield org.apache.logging.log4j.core.util.WatchManager$FileMonitor.lastModifiedMillis:J
invokevirtual org.apache.logging.log4j.core.util.WatchManager.millisToString:(J)Ljava/lang/String;
10: aload 4
getfield org.apache.logging.log4j.core.util.WatchManager$FileMonitor.lastModifiedMillis:J
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
11: invokeinterface org.apache.logging.log4j.Logger.info:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
12: StackMap locals: org.apache.logging.log4j.core.util.WatchManager$WatchRunnable java.util.Map$Entry java.util.Iterator java.io.File org.apache.logging.log4j.core.util.WatchManager$FileMonitor long
StackMap stack:
aload 4
lload 5
putfield org.apache.logging.log4j.core.util.WatchManager$FileMonitor.lastModifiedMillis:J
13: aload 4
getfield org.apache.logging.log4j.core.util.WatchManager$FileMonitor.fileWatcher:Lorg/apache/logging/log4j/core/util/FileWatcher;
aload 3
invokeinterface org.apache.logging.log4j.core.util.FileWatcher.fileModified:(Ljava/io/File;)V
end local 5 end local 4 end local 3 end local 1 14: StackMap locals: org.apache.logging.log4j.core.util.WatchManager$WatchRunnable top java.util.Iterator
StackMap stack:
aload 2
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
15: getstatic org.apache.logging.log4j.core.util.WatchManager.logger:Lorg/apache/logging/log4j/Logger;
ldc "{} run ended."
aload 0
getfield org.apache.logging.log4j.core.util.WatchManager$WatchRunnable.SIMPLE_NAME:Ljava/lang/String;
invokeinterface org.apache.logging.log4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
16: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Lorg/apache/logging/log4j/core/util/WatchManager$WatchRunnable;
3 14 1 entry Ljava/util/Map$Entry<Ljava/io/File;Lorg/apache/logging/log4j/core/util/WatchManager$FileMonitor;>;
4 14 3 file Ljava/io/File;
5 14 4 fileMonitor Lorg/apache/logging/log4j/core/util/WatchManager$FileMonitor;
6 14 5 lastModfied J
private boolean fileModified(org.apache.logging.log4j.core.util.WatchManager$FileMonitor, long);
descriptor: (Lorg/apache/logging/log4j/core/util/WatchManager$FileMonitor;J)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=4, args_size=3
start local 0 start local 1 start local 2 0: lload 2
aload 1
getfield org.apache.logging.log4j.core.util.WatchManager$FileMonitor.lastModifiedMillis:J
lcmp
ifeq 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/logging/log4j/core/util/WatchManager$WatchRunnable;
0 2 1 fileMonitor Lorg/apache/logging/log4j/core/util/WatchManager$FileMonitor;
0 2 2 lastModifiedMillis J
MethodParameters:
Name Flags
fileMonitor final
lastModifiedMillis final
}
SourceFile: "WatchManager.java"
NestHost: org.apache.logging.log4j.core.util.WatchManager
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map
private final FileMonitor = org.apache.logging.log4j.core.util.WatchManager$FileMonitor of org.apache.logging.log4j.core.util.WatchManager
private final WatchRunnable = org.apache.logging.log4j.core.util.WatchManager$WatchRunnable of org.apache.logging.log4j.core.util.WatchManager