public class ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter extends ch.qos.logback.classic.turbo.TurboFilter
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter
super_class: ch.qos.logback.classic.turbo.TurboFilter
{
public static final long DEFAULT_REFRESH_PERIOD;
descriptor: J
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
ConstantValue: 60000
long refreshPeriod;
descriptor: J
flags: (0x0000)
java.net.URL mainConfigurationURL;
descriptor: Ljava/net/URL;
flags: (0x0000)
protected volatile long nextCheck;
descriptor: J
flags: (0x0044) ACC_PROTECTED, ACC_VOLATILE
ch.qos.logback.core.joran.spi.ConfigurationWatchList configurationWatchList;
descriptor: Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
flags: (0x0000)
private long invocationCounter;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private volatile long mask;
descriptor: J
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private volatile long lastMaskCheck;
descriptor: J
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private static final int MAX_MASK;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 65535
private static final long MASK_INCREASE_THRESHOLD;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 100
private static final long MASK_DECREASE_THRESHOLD;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 800
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
invokespecial ch.qos.logback.classic.turbo.TurboFilter.<init>:()V
1: aload 0
ldc 60000
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.refreshPeriod:J
2: aload 0
lconst_0
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.invocationCounter:J
3: aload 0
ldc 15
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
4: aload 0
invokestatic java.lang.System.currentTimeMillis:()J
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.lastMaskCheck:J
5: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
public void start();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=5, args_size=1
start local 0 0: aload 0
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.context:Lch/qos/logback/core/Context;
invokestatic ch.qos.logback.core.joran.util.ConfigurationWatchListUtil.getConfigurationWatchList:(Lch/qos/logback/core/Context;)Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
1: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
ifnull 17
2: aload 0
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
invokevirtual ch.qos.logback.core.joran.spi.ConfigurationWatchList.getMainURL:()Ljava/net/URL;
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mainConfigurationURL:Ljava/net/URL;
3: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mainConfigurationURL:Ljava/net/URL;
ifnonnull 6
4: aload 0
ldc "Due to missing top level configuration file, automatic reconfiguration is impossible."
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.addWarn:(Ljava/lang/String;)V
5: return
6: StackMap locals:
StackMap stack:
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
invokevirtual ch.qos.logback.core.joran.spi.ConfigurationWatchList.getCopyOfFileWatchList:()Ljava/util/List;
astore 1
start local 1 7: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.refreshPeriod:J
ldc 1000
ldiv
lstore 2
start local 2 8: aload 0
new java.lang.StringBuilder
dup
ldc "Will scan for changes in ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "] every "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
lload 2
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
ldc " seconds. "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.addInfo:(Ljava/lang/String;)V
9: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
dup
astore 4
monitorenter
10: aload 0
invokestatic java.lang.System.currentTimeMillis:()J
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.updateNextCheck:(J)V
11: aload 4
monitorexit
12: goto 15
StackMap locals: ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter java.util.List long ch.qos.logback.core.joran.spi.ConfigurationWatchList
StackMap stack: java.lang.Throwable
13: aload 4
monitorexit
14: athrow
15: StackMap locals:
StackMap stack:
aload 0
invokespecial ch.qos.logback.classic.turbo.TurboFilter.start:()V
end local 2 end local 1 16: goto 18
17: StackMap locals:
StackMap stack:
aload 0
ldc "Empty ConfigurationWatchList in context"
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.addWarn:(Ljava/lang/String;)V
18: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
7 16 1 watchList Ljava/util/List<Ljava/io/File;>;
8 16 2 inSeconds J
Exception table:
from to target type
10 12 13 any
13 14 13 any
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: new java.lang.StringBuilder
dup
ldc "ReconfigureOnChangeFilter{invocationCounter="
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.invocationCounter:J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
bipush 125
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
public ch.qos.logback.core.spi.FilterReply decide(org.slf4j.Marker, ch.qos.logback.classic.Logger, ch.qos.logback.classic.Level, java.lang.String, java.lang.Object[], java.lang.Throwable);
descriptor: (Lorg/slf4j/Marker;Lch/qos/logback/classic/Logger;Lch/qos/logback/classic/Level;Ljava/lang/String;[Ljava/lang/Object;Ljava/lang/Throwable;)Lch/qos/logback/core/spi/FilterReply;
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=10, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 0
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.isStarted:()Z
ifne 2
1: getstatic ch.qos.logback.core.spi.FilterReply.NEUTRAL:Lch/qos/logback/core/spi/FilterReply;
areturn
2: StackMap locals:
StackMap stack:
aload 0
dup
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.invocationCounter:J
dup2_x1
lconst_1
ladd
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.invocationCounter:J
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
land
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
lcmp
ifeq 4
3: getstatic ch.qos.logback.core.spi.FilterReply.NEUTRAL:Lch/qos/logback/core/spi/FilterReply;
areturn
4: StackMap locals:
StackMap stack:
invokestatic java.lang.System.currentTimeMillis:()J
lstore 7
start local 7 5: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
dup
astore 9
monitorenter
6: aload 0
lload 7
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.updateMaskIfNecessary:(J)V
7: aload 0
lload 7
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.changeDetected:(J)Z
ifeq 10
8: aload 0
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.disableSubsequentReconfiguration:()V
9: aload 0
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.detachReconfigurationToNewThread:()V
10: StackMap locals: long ch.qos.logback.core.joran.spi.ConfigurationWatchList
StackMap stack:
aload 9
monitorexit
11: goto 14
StackMap locals:
StackMap stack: java.lang.Throwable
12: aload 9
monitorexit
13: athrow
14: StackMap locals:
StackMap stack:
getstatic ch.qos.logback.core.spi.FilterReply.NEUTRAL:Lch/qos/logback/core/spi/FilterReply;
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
0 15 1 marker Lorg/slf4j/Marker;
0 15 2 logger Lch/qos/logback/classic/Logger;
0 15 3 level Lch/qos/logback/classic/Level;
0 15 4 format Ljava/lang/String;
0 15 5 params [Ljava/lang/Object;
0 15 6 t Ljava/lang/Throwable;
5 15 7 now J
Exception table:
from to target type
6 11 12 any
12 13 12 any
MethodParameters:
Name Flags
marker
logger
level
format
params
t
private void updateMaskIfNecessary(long);
descriptor: (J)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=5, args_size=2
start local 0 start local 1 0: lload 1
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.lastMaskCheck:J
lsub
lstore 3
start local 3 1: aload 0
lload 1
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.lastMaskCheck:J
2: lload 3
ldc 100
lcmp
ifge 5
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
ldc 65535
lcmp
ifge 5
3: aload 0
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
iconst_1
lshl
lconst_1
lor
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
4: goto 7
StackMap locals: long
StackMap stack:
5: lload 3
ldc 800
lcmp
ifle 7
6: aload 0
dup
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
iconst_2
lushr
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.mask:J
7: StackMap locals:
StackMap stack:
return
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
0 8 1 now J
1 8 3 timeElapsedSinceLastMaskUpdateCheck J
MethodParameters:
Name Flags
now
void detachReconfigurationToNewThread();
descriptor: ()V
flags: (0x0000)
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
new java.lang.StringBuilder
dup
ldc "Detected change in ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
invokevirtual ch.qos.logback.core.joran.spi.ConfigurationWatchList.getCopyOfFileWatchList:()Ljava/util/List;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "]"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.addInfo:(Ljava/lang/String;)V
1: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.context:Lch/qos/logback/core/Context;
invokeinterface ch.qos.logback.core.Context.getExecutorService:()Ljava/util/concurrent/ExecutorService;
new ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter$ReconfiguringThread
dup
aload 0
invokespecial ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter$ReconfiguringThread.<init>:(Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;)V
invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
pop
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
void updateNextCheck(long);
descriptor: (J)V
flags: (0x0000)
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: aload 0
lload 1
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.refreshPeriod:J
ladd
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.nextCheck:J
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
0 2 1 now J
MethodParameters:
Name Flags
now
protected boolean changeDetected(long);
descriptor: (J)Z
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: lload 1
aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.nextCheck:J
lcmp
iflt 3
1: aload 0
lload 1
invokevirtual ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.updateNextCheck:(J)V
2: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.configurationWatchList:Lch/qos/logback/core/joran/spi/ConfigurationWatchList;
invokevirtual ch.qos.logback.core.joran.spi.ConfigurationWatchList.changeDetected:()Z
ireturn
3: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
0 4 1 now J
MethodParameters:
Name Flags
now
void disableSubsequentReconfiguration();
descriptor: ()V
flags: (0x0000)
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
ldc 9223372036854775807
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.nextCheck:J
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
public long getRefreshPeriod();
descriptor: ()J
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.refreshPeriod:J
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
public void setRefreshPeriod(long);
descriptor: (J)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
lload 1
putfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.refreshPeriod:J
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;
0 2 1 refreshPeriod J
MethodParameters:
Name Flags
refreshPeriod
static ch.qos.logback.core.Context access$0(ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter);
descriptor: (Lch/qos/logback/classic/turbo/ReconfigureOnChangeFilter;)Lch/qos/logback/core/Context;
flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
getfield ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter.context:Lch/qos/logback/core/Context;
areturn
LocalVariableTable:
Start End Slot Name Signature
}
SourceFile: "ReconfigureOnChangeFilter.java"
NestMembers:
ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter$ReconfiguringThread
InnerClasses:
ReconfiguringThread = ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter$ReconfiguringThread of ch.qos.logback.classic.turbo.ReconfigureOnChangeFilter