public class org.apache.juli.OneLineFormatter extends java.util.logging.Formatter
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.juli.OneLineFormatter
super_class: java.util.logging.Formatter
{
private static final java.lang.String UNKNOWN_THREAD_NAME;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "Unknown thread with ID "
private static final java.lang.Object threadMxBeanLock;
descriptor: Ljava/lang/Object;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static volatile java.lang.management.ThreadMXBean threadMxBean;
descriptor: Ljava/lang/management/ThreadMXBean;
flags: (0x004a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE
private static final int THREAD_NAME_CACHE_SIZE;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 10000
private static java.lang.ThreadLocal<org.apache.juli.OneLineFormatter$ThreadNameCache> threadNameCache;
descriptor: Ljava/lang/ThreadLocal;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Signature: Ljava/lang/ThreadLocal<Lorg/apache/juli/OneLineFormatter$ThreadNameCache;>;
private static final java.lang.String DEFAULT_TIME_FORMAT;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "dd-MMM-yyyy HH:mm:ss"
private static final int globalCacheSize;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 30
private static final int localCacheSize;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 5
private java.lang.ThreadLocal<org.apache.juli.DateFormatCache> localDateCache;
descriptor: Ljava/lang/ThreadLocal;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/lang/ThreadLocal<Lorg/apache/juli/DateFormatCache;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new java.lang.Object
dup
invokespecial java.lang.Object.<init>:()V
putstatic org.apache.juli.OneLineFormatter.threadMxBeanLock:Ljava/lang/Object;
1: aconst_null
putstatic org.apache.juli.OneLineFormatter.threadMxBean:Ljava/lang/management/ThreadMXBean;
2: new org.apache.juli.OneLineFormatter$1
dup
invokespecial org.apache.juli.OneLineFormatter$1.<init>:()V
putstatic org.apache.juli.OneLineFormatter.threadNameCache:Ljava/lang/ThreadLocal;
3: return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=1
start local 0 0: aload 0
invokespecial java.util.logging.Formatter.<init>:()V
1: invokestatic java.util.logging.LogManager.getLogManager:()Ljava/util/logging/LogManager;
2: new java.lang.StringBuilder
dup
ldc Lorg/apache/juli/OneLineFormatter;
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc ".timeFormat"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
3: invokevirtual java.util.logging.LogManager.getProperty:(Ljava/lang/String;)Ljava/lang/String;
astore 1
start local 1 4: aload 1
ifnonnull 6
5: ldc "dd-MMM-yyyy HH:mm:ss"
astore 1
6: StackMap locals: org.apache.juli.OneLineFormatter java.lang.String
StackMap stack:
aload 0
aload 1
invokevirtual org.apache.juli.OneLineFormatter.setTimeFormat:(Ljava/lang/String;)V
7: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/apache/juli/OneLineFormatter;
4 8 1 timeFormat Ljava/lang/String;
public void setTimeFormat(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=3, args_size=2
start local 0 start local 1 0: new org.apache.juli.DateFormatCache
dup
bipush 30
aload 1
aconst_null
invokespecial org.apache.juli.DateFormatCache.<init>:(ILjava/lang/String;Lorg/apache/juli/DateFormatCache;)V
1: astore 2
start local 2 2: aload 0
new org.apache.juli.OneLineFormatter$2
dup
aload 0
aload 1
aload 2
invokespecial org.apache.juli.OneLineFormatter$2.<init>:(Lorg/apache/juli/OneLineFormatter;Ljava/lang/String;Lorg/apache/juli/DateFormatCache;)V
putfield org.apache.juli.OneLineFormatter.localDateCache:Ljava/lang/ThreadLocal;
3: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/juli/OneLineFormatter;
0 4 1 timeFormat Ljava/lang/String;
2 4 2 globalDateCache Lorg/apache/juli/DateFormatCache;
MethodParameters:
Name Flags
timeFormat final
public java.lang.String getTimeFormat();
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.juli.OneLineFormatter.localDateCache:Ljava/lang/ThreadLocal;
invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
checkcast org.apache.juli.DateFormatCache
invokevirtual org.apache.juli.DateFormatCache.getTimeFormat:()Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/juli/OneLineFormatter;
public java.lang.String format(java.util.logging.LogRecord);
descriptor: (Ljava/util/logging/LogRecord;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=5, args_size=2
start local 0 start local 1 0: new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 2
start local 2 1: aload 0
aload 2
aload 1
invokevirtual java.util.logging.LogRecord.getMillis:()J
invokevirtual org.apache.juli.OneLineFormatter.addTimestamp:(Ljava/lang/StringBuilder;J)V
2: aload 2
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
3: aload 2
aload 1
invokevirtual java.util.logging.LogRecord.getLevel:()Ljava/util/logging/Level;
invokevirtual java.util.logging.Level.getLocalizedName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
4: aload 2
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
5: aload 2
bipush 91
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
6: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
instanceof org.apache.juli.AsyncFileHandler$LoggerThread
ifeq 9
7: aload 2
aload 1
invokevirtual java.util.logging.LogRecord.getThreadID:()I
invokestatic org.apache.juli.OneLineFormatter.getThreadName:(I)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
8: goto 10
9: StackMap locals: java.lang.StringBuilder
StackMap stack:
aload 2
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
10: StackMap locals:
StackMap stack:
aload 2
bipush 93
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
11: aload 2
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
12: aload 2
aload 1
invokevirtual java.util.logging.LogRecord.getSourceClassName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
13: aload 2
bipush 46
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
14: aload 2
aload 1
invokevirtual java.util.logging.LogRecord.getSourceMethodName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
15: aload 2
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
16: aload 2
aload 0
aload 1
invokevirtual org.apache.juli.OneLineFormatter.formatMessage:(Ljava/util/logging/LogRecord;)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
17: aload 2
invokestatic java.lang.System.lineSeparator:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
18: aload 1
invokevirtual java.util.logging.LogRecord.getThrown:()Ljava/lang/Throwable;
ifnull 24
19: new java.io.StringWriter
dup
invokespecial java.io.StringWriter.<init>:()V
astore 3
start local 3 20: new org.apache.juli.OneLineFormatter$IndentingPrintWriter
dup
aload 3
invokespecial org.apache.juli.OneLineFormatter$IndentingPrintWriter.<init>:(Ljava/io/Writer;)V
astore 4
start local 4 21: aload 1
invokevirtual java.util.logging.LogRecord.getThrown:()Ljava/lang/Throwable;
aload 4
invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintWriter;)V
22: aload 4
invokevirtual java.io.PrintWriter.close:()V
23: aload 2
aload 3
invokevirtual java.io.StringWriter.getBuffer:()Ljava/lang/StringBuffer;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/StringBuffer;)Ljava/lang/StringBuilder;
pop
end local 4 end local 3 24: StackMap locals:
StackMap stack:
aload 2
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 25 0 this Lorg/apache/juli/OneLineFormatter;
0 25 1 record Ljava/util/logging/LogRecord;
1 25 2 sb Ljava/lang/StringBuilder;
20 24 3 sw Ljava/io/StringWriter;
21 24 4 pw Ljava/io/PrintWriter;
MethodParameters:
Name Flags
record
protected void addTimestamp(java.lang.StringBuilder, long);
descriptor: (Ljava/lang/StringBuilder;J)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 1
aload 0
getfield org.apache.juli.OneLineFormatter.localDateCache:Ljava/lang/ThreadLocal;
invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
checkcast org.apache.juli.DateFormatCache
lload 2
invokevirtual org.apache.juli.DateFormatCache.getFormat:(J)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
1: lload 2
ldc 1000
lrem
lstore 4
start local 4 2: aload 1
bipush 46
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
3: lload 4
ldc 100
lcmp
ifge 9
4: lload 4
ldc 10
lcmp
ifge 8
5: aload 1
bipush 48
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
6: aload 1
bipush 48
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
7: goto 9
8: StackMap locals: long
StackMap stack:
aload 1
bipush 48
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
9: StackMap locals:
StackMap stack:
aload 1
lload 4
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
pop
10: return
end local 4 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/apache/juli/OneLineFormatter;
0 11 1 buf Ljava/lang/StringBuilder;
0 11 2 timestamp J
2 11 4 frac J
MethodParameters:
Name Flags
buf
timestamp
private static java.lang.String getThreadName(int);
descriptor: (I)Ljava/lang/String;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=4, args_size=1
start local 0 0: getstatic org.apache.juli.OneLineFormatter.threadNameCache:Ljava/lang/ThreadLocal;
invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
checkcast java.util.Map
astore 1
start local 1 1: aconst_null
astore 2
start local 2 2: iload 0
ldc 1073741823
if_icmple 4
3: aload 1
iload 0
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.String
astore 2
4: StackMap locals: java.util.Map java.lang.String
StackMap stack:
aload 2
ifnull 6
5: aload 2
areturn
6: StackMap locals:
StackMap stack:
iload 0
ldc 1073741823
if_icmple 9
7: new java.lang.StringBuilder
dup
ldc "Unknown thread with ID "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 0
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
astore 2
8: goto 22
9: StackMap locals:
StackMap stack:
getstatic org.apache.juli.OneLineFormatter.threadMxBean:Ljava/lang/management/ThreadMXBean;
ifnonnull 17
10: getstatic org.apache.juli.OneLineFormatter.threadMxBeanLock:Ljava/lang/Object;
dup
astore 3
monitorenter
11: getstatic org.apache.juli.OneLineFormatter.threadMxBean:Ljava/lang/management/ThreadMXBean;
ifnonnull 13
12: invokestatic java.lang.management.ManagementFactory.getThreadMXBean:()Ljava/lang/management/ThreadMXBean;
putstatic org.apache.juli.OneLineFormatter.threadMxBean:Ljava/lang/management/ThreadMXBean;
13: StackMap locals: java.lang.Object
StackMap stack:
aload 3
monitorexit
14: goto 17
StackMap locals:
StackMap stack: java.lang.Throwable
15: aload 3
monitorexit
16: athrow
17: StackMap locals:
StackMap stack:
getstatic org.apache.juli.OneLineFormatter.threadMxBean:Ljava/lang/management/ThreadMXBean;
iload 0
i2l
invokeinterface java.lang.management.ThreadMXBean.getThreadInfo:(J)Ljava/lang/management/ThreadInfo;
18: astore 3
start local 3 19: aload 3
ifnonnull 21
20: iload 0
i2l
invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
areturn
21: StackMap locals: java.lang.management.ThreadInfo
StackMap stack:
aload 3
invokevirtual java.lang.management.ThreadInfo.getThreadName:()Ljava/lang/String;
astore 2
end local 3 22: StackMap locals:
StackMap stack:
aload 1
iload 0
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 2
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
23: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 logRecordThreadId I
1 24 1 cache Ljava/util/Map<Ljava/lang/Integer;Ljava/lang/String;>;
2 24 2 result Ljava/lang/String;
19 22 3 threadInfo Ljava/lang/management/ThreadInfo;
Exception table:
from to target type
11 14 15 any
15 16 15 any
MethodParameters:
Name Flags
logRecordThreadId
}
SourceFile: "OneLineFormatter.java"
NestMembers:
org.apache.juli.OneLineFormatter$1 org.apache.juli.OneLineFormatter$2 org.apache.juli.OneLineFormatter$IndentingPrintWriter org.apache.juli.OneLineFormatter$ThreadNameCache
InnerClasses:
protected LoggerThread = org.apache.juli.AsyncFileHandler$LoggerThread of org.apache.juli.AsyncFileHandler
org.apache.juli.OneLineFormatter$1
org.apache.juli.OneLineFormatter$2
private IndentingPrintWriter = org.apache.juli.OneLineFormatter$IndentingPrintWriter of org.apache.juli.OneLineFormatter
private ThreadNameCache = org.apache.juli.OneLineFormatter$ThreadNameCache of org.apache.juli.OneLineFormatter