class org.apache.lucene.index.ConcurrentMergeScheduler$1 extends org.apache.lucene.store.FilterDirectory
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: org.apache.lucene.index.ConcurrentMergeScheduler$1
super_class: org.apache.lucene.store.FilterDirectory
{
final org.apache.lucene.index.ConcurrentMergeScheduler this$0;
descriptor: Lorg/apache/lucene/index/ConcurrentMergeScheduler;
flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC
private final java.lang.Thread val$mergeThread;
descriptor: Ljava/lang/Thread;
flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC
private final org.apache.lucene.store.RateLimiter val$rateLimiter;
descriptor: Lorg/apache/lucene/store/RateLimiter;
flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC
void <init>(org.apache.lucene.index.ConcurrentMergeScheduler, org.apache.lucene.store.Directory, java.lang.Thread, org.apache.lucene.store.RateLimiter);
descriptor: (Lorg/apache/lucene/index/ConcurrentMergeScheduler;Lorg/apache/lucene/store/Directory;Ljava/lang/Thread;Lorg/apache/lucene/store/RateLimiter;)V
flags: (0x0000)
Code:
stack=2, locals=5, args_size=5
start local 0 start local 2 0: aload 0
aload 1
putfield org.apache.lucene.index.ConcurrentMergeScheduler$1.this$0:Lorg/apache/lucene/index/ConcurrentMergeScheduler;
aload 0
aload 3
putfield org.apache.lucene.index.ConcurrentMergeScheduler$1.val$mergeThread:Ljava/lang/Thread;
aload 0
aload 4
putfield org.apache.lucene.index.ConcurrentMergeScheduler$1.val$rateLimiter:Lorg/apache/lucene/store/RateLimiter;
aload 0
aload 2
invokespecial org.apache.lucene.store.FilterDirectory.<init>:(Lorg/apache/lucene/store/Directory;)V
return
end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/lucene/index/ConcurrentMergeScheduler$1;
0 1 2 $anonymous0 Lorg/apache/lucene/store/Directory;
MethodParameters:
Name Flags
this$0 final
$anonymous0
val$mergeThread final
val$rateLimiter final
public org.apache.lucene.store.IndexOutput createOutput(java.lang.String, org.apache.lucene.store.IOContext);
descriptor: (Ljava/lang/String;Lorg/apache/lucene/store/IOContext;)Lorg/apache/lucene/store/IndexOutput;
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$1.ensureOpen:()V
1: getstatic org.apache.lucene.index.ConcurrentMergeScheduler.$assertionsDisabled:Z
ifne 2
aload 2
getfield org.apache.lucene.store.IOContext.context:Lorg/apache/lucene/store/IOContext$Context;
getstatic org.apache.lucene.store.IOContext$Context.MERGE:Lorg/apache/lucene/store/IOContext$Context;
if_acmpeq 2
new java.lang.AssertionError
dup
new java.lang.StringBuilder
dup
ldc "got context="
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
getfield org.apache.lucene.store.IOContext.context:Lorg/apache/lucene/store/IOContext$Context;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
2: StackMap locals:
StackMap stack:
getstatic org.apache.lucene.index.ConcurrentMergeScheduler.$assertionsDisabled:Z
ifne 4
aload 0
getfield org.apache.lucene.index.ConcurrentMergeScheduler$1.val$mergeThread:Ljava/lang/Thread;
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
if_acmpeq 4
new java.lang.AssertionError
dup
new java.lang.StringBuilder
dup
ldc "Not the same merge thread, current="
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
3: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc ", expected="
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield org.apache.lucene.index.ConcurrentMergeScheduler$1.val$mergeThread:Ljava/lang/Thread;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
4: StackMap locals:
StackMap stack:
new org.apache.lucene.store.RateLimitedIndexOutput
dup
aload 0
getfield org.apache.lucene.index.ConcurrentMergeScheduler$1.val$rateLimiter:Lorg/apache/lucene/store/RateLimiter;
aload 0
getfield org.apache.lucene.index.ConcurrentMergeScheduler$1.in:Lorg/apache/lucene/store/Directory;
aload 1
aload 2
invokevirtual org.apache.lucene.store.Directory.createOutput:(Ljava/lang/String;Lorg/apache/lucene/store/IOContext;)Lorg/apache/lucene/store/IndexOutput;
invokespecial org.apache.lucene.store.RateLimitedIndexOutput.<init>:(Lorg/apache/lucene/store/RateLimiter;Lorg/apache/lucene/store/IndexOutput;)V
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/lucene/index/ConcurrentMergeScheduler$1;
0 5 1 name Ljava/lang/String;
0 5 2 context Lorg/apache/lucene/store/IOContext;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
name
context
}
SourceFile: "ConcurrentMergeScheduler.java"
EnclosingMethod: org.apache.lucene.index.ConcurrentMergeScheduler.wrapForMerge:(Lorg/apache/lucene/index/MergePolicy$OneMerge;Lorg/apache/lucene/store/Directory;)Lorg/apache/lucene/store/Directory;
NestHost: org.apache.lucene.index.ConcurrentMergeScheduler
InnerClasses:
org.apache.lucene.index.ConcurrentMergeScheduler$1
public OneMerge = org.apache.lucene.index.MergePolicy$OneMerge of org.apache.lucene.index.MergePolicy
public final Context = org.apache.lucene.store.IOContext$Context of org.apache.lucene.store.IOContext