public final class org.apache.logging.log4j.core.appender.rolling.action.IfFileName implements org.apache.logging.log4j.core.appender.rolling.action.PathCondition
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: org.apache.logging.log4j.core.appender.rolling.action.IfFileName
super_class: java.lang.Object
{
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 java.nio.file.PathMatcher pathMatcher;
descriptor: Ljava/nio/file/PathMatcher;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.lang.String syntaxAndPattern;
descriptor: Ljava/lang/String;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.apache.logging.log4j.core.appender.rolling.action.PathCondition[] nestedConditions;
descriptor: [Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
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.appender.rolling.action.IfFileName.LOGGER:Lorg/apache/logging/log4j/Logger;
return
LocalVariableTable:
Start End Slot Name Signature
private void <init>(java.lang.String, java.lang.String, org.apache.logging.log4j.core.appender.rolling.action.PathCondition[]);
descriptor: (Ljava/lang/String;Ljava/lang/String;[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 2
ifnonnull 3
aload 1
ifnonnull 3
2: new java.lang.IllegalArgumentException
dup
ldc "Specify either a path glob or a regular expression. Both cannot be null."
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: org.apache.logging.log4j.core.appender.rolling.action.IfFileName java.lang.String java.lang.String org.apache.logging.log4j.core.appender.rolling.action.PathCondition[]
StackMap stack:
aload 0
aload 1
aload 2
invokestatic org.apache.logging.log4j.core.appender.rolling.action.IfFileName.createSyntaxAndPatternString:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
putfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.syntaxAndPattern:Ljava/lang/String;
4: aload 0
invokestatic java.nio.file.FileSystems.getDefault:()Ljava/nio/file/FileSystem;
aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.syntaxAndPattern:Ljava/lang/String;
invokevirtual java.nio.file.FileSystem.getPathMatcher:(Ljava/lang/String;)Ljava/nio/file/PathMatcher;
putfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.pathMatcher:Ljava/nio/file/PathMatcher;
5: aload 0
aload 3
ifnonnull 6
iconst_0
anewarray org.apache.logging.log4j.core.appender.rolling.action.PathCondition
goto 9
StackMap locals:
StackMap stack: org.apache.logging.log4j.core.appender.rolling.action.IfFileName
6: aload 3
7: aload 3
arraylength
8: invokestatic java.util.Arrays.copyOf:([Ljava/lang/Object;I)[Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.appender.rolling.action.PathCondition[]
StackMap locals: org.apache.logging.log4j.core.appender.rolling.action.IfFileName java.lang.String java.lang.String org.apache.logging.log4j.core.appender.rolling.action.PathCondition[]
StackMap stack: org.apache.logging.log4j.core.appender.rolling.action.IfFileName org.apache.logging.log4j.core.appender.rolling.action.PathCondition[]
9: putfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.nestedConditions:[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
10: return
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/appender/rolling/action/IfFileName;
0 11 1 glob Ljava/lang/String;
0 11 2 regex Ljava/lang/String;
0 11 3 nestedConditions [Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
MethodParameters:
Name Flags
glob final
regex final
nestedConditions final
static java.lang.String createSyntaxAndPatternString(java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
ifnull 4
1: aload 0
ldc "glob:"
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifeq 2
aload 0
goto 3
StackMap locals:
StackMap stack:
2: new java.lang.StringBuilder
dup
ldc "glob:"
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;
StackMap locals:
StackMap stack: java.lang.String
3: areturn
4: StackMap locals:
StackMap stack:
aload 1
ldc "regex:"
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifeq 5
aload 1
goto 6
StackMap locals:
StackMap stack:
5: new java.lang.StringBuilder
dup
ldc "regex:"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
StackMap locals:
StackMap stack: java.lang.String
6: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 glob Ljava/lang/String;
0 7 1 regex Ljava/lang/String;
MethodParameters:
Name Flags
glob final
regex final
public java.lang.String getSyntaxAndPattern();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.syntaxAndPattern:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/rolling/action/IfFileName;
public java.util.List<org.apache.logging.log4j.core.appender.rolling.action.PathCondition> getNestedConditions();
descriptor: ()Ljava/util/List;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.nestedConditions:[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/rolling/action/IfFileName;
Signature: ()Ljava/util/List<Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;>;
public boolean accept(java.nio.file.Path, java.nio.file.Path, java.nio.file.attribute.BasicFileAttributes);
descriptor: (Ljava/nio/file/Path;Ljava/nio/file/Path;Ljava/nio/file/attribute/BasicFileAttributes;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=7, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.pathMatcher:Ljava/nio/file/PathMatcher;
aload 2
invokeinterface java.nio.file.PathMatcher.matches:(Ljava/nio/file/Path;)Z
istore 4
start local 4 1: iload 4
ifeq 2
ldc "matches"
goto 3
StackMap locals: int
StackMap stack:
2: ldc "does not match"
StackMap locals:
StackMap stack: java.lang.String
3: astore 5
start local 5 4: iload 4
ifeq 5
ldc "ACCEPTED"
goto 6
StackMap locals: java.lang.String
StackMap stack:
5: ldc "REJECTED"
StackMap locals:
StackMap stack: java.lang.String
6: astore 6
start local 6 7: getstatic org.apache.logging.log4j.core.appender.rolling.action.IfFileName.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "IfFileName {}: '{}' {} relative path '{}'"
aload 6
aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.syntaxAndPattern:Ljava/lang/String;
aload 5
aload 2
invokeinterface org.apache.logging.log4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
8: iload 4
ifeq 10
9: aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.nestedConditions:[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
aload 1
aload 2
aload 3
invokestatic org.apache.logging.log4j.core.appender.rolling.action.IfAll.accept:([Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;Ljava/nio/file/Path;Ljava/nio/file/Path;Ljava/nio/file/attribute/BasicFileAttributes;)Z
ireturn
10: StackMap locals: java.lang.String
StackMap stack:
iload 4
ireturn
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 11 0 this Lorg/apache/logging/log4j/core/appender/rolling/action/IfFileName;
0 11 1 basePath Ljava/nio/file/Path;
0 11 2 relativePath Ljava/nio/file/Path;
0 11 3 attrs Ljava/nio/file/attribute/BasicFileAttributes;
1 11 4 result Z
4 11 5 match Ljava/lang/String;
7 11 6 accept Ljava/lang/String;
MethodParameters:
Name Flags
basePath final
relativePath final
attrs final
public void beforeFileTreeWalk();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.nestedConditions:[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
invokestatic org.apache.logging.log4j.core.appender.rolling.action.IfAll.beforeFileTreeWalk:([Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/logging/log4j/core/appender/rolling/action/IfFileName;
public static org.apache.logging.log4j.core.appender.rolling.action.IfFileName createNameCondition(java.lang.String, java.lang.String, org.apache.logging.log4j.core.appender.rolling.action.PathCondition[]);
descriptor: (Ljava/lang/String;Ljava/lang/String;[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;)Lorg/apache/logging/log4j/core/appender/rolling/action/IfFileName;
flags: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
Code:
stack=5, locals=3, args_size=3
start local 0 start local 1 start local 2 0: new org.apache.logging.log4j.core.appender.rolling.action.IfFileName
dup
aload 0
aload 1
aload 2
invokespecial org.apache.logging.log4j.core.appender.rolling.action.IfFileName.<init>:(Ljava/lang/String;Ljava/lang/String;[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;)V
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 glob Ljava/lang/String;
0 1 1 regex Ljava/lang/String;
0 1 2 nestedConditions [Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
RuntimeVisibleAnnotations:
org.apache.logging.log4j.core.config.plugins.PluginFactory()
RuntimeVisibleParameterAnnotations:
0:
org.apache.logging.log4j.core.config.plugins.PluginAttribute(value = "glob")
1:
org.apache.logging.log4j.core.config.plugins.PluginAttribute(value = "regex")
2:
org.apache.logging.log4j.core.config.plugins.PluginElement(value = "PathConditions")
MethodParameters:
Name Flags
glob final
regex final
nestedConditions final
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.nestedConditions:[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
arraylength
ifne 1
ldc ""
goto 2
StackMap locals:
StackMap stack:
1: new java.lang.StringBuilder
dup
ldc " AND "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.nestedConditions:[Lorg/apache/logging/log4j/core/appender/rolling/action/PathCondition;
invokestatic java.util.Arrays.toString:([Ljava/lang/Object;)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
StackMap locals:
StackMap stack: java.lang.String
2: astore 1
start local 1 3: new java.lang.StringBuilder
dup
ldc "IfFileName("
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield org.apache.logging.log4j.core.appender.rolling.action.IfFileName.syntaxAndPattern:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ")"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/logging/log4j/core/appender/rolling/action/IfFileName;
3 4 1 nested Ljava/lang/String;
}
SourceFile: "IfFileName.java"
RuntimeVisibleAnnotations:
org.apache.logging.log4j.core.config.plugins.Plugin(name = "IfFileName", category = "Core", printObject = true)