final class org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator extends java.lang.Object implements java.util.Iterator
{
private final org.apache.activemq.store.kahadb.disk.page.Transaction tx;
private final java.lang.Object endKey;
org.apache.activemq.store.kahadb.disk.index.BTreeNode current;
int nextIndex;
java.util.Map$Entry nextEntry;
static final boolean $assertionsDisabled;
final org.apache.activemq.store.kahadb.disk.index.BTreeNode this$0;
private void <init>(org.apache.activemq.store.kahadb.disk.index.BTreeNode, org.apache.activemq.store.kahadb.disk.page.Transaction, org.apache.activemq.store.kahadb.disk.index.BTreeNode, int, java.lang.Object)
{
org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator v;
org.apache.activemq.store.kahadb.disk.index.BTreeNode v, v;
java.lang.Long v;
int v;
java.lang.Object v;
org.apache.activemq.store.kahadb.disk.page.Transaction v;
boolean v;
v := @this: org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator;
v := @parameter: org.apache.activemq.store.kahadb.disk.index.BTreeNode;
v := @parameter: org.apache.activemq.store.kahadb.disk.page.Transaction;
v := @parameter: org.apache.activemq.store.kahadb.disk.index.BTreeNode;
v := @parameter: int;
v := @parameter: java.lang.Object;
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode this$0> = v;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.page.Transaction tx> = v;
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current> = v;
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex> = v;
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.lang.Object endKey> = v;
if v == null goto label;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(0L);
v = virtualinvoke v.<java.lang.Object: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
staticinvoke <java.lang.Thread: void dumpStack()>();
label:
return;
}
private synchronized void findNextPage()
{
org.apache.activemq.store.kahadb.disk.index.BTreeIndex v;
byte v;
boolean v, v, v;
java.lang.Object[] v, v, v, v;
long v, v;
java.lang.AssertionError v;
org.apache.activemq.store.kahadb.disk.index.BTreeNode v, v, v, v, v, v, v, v, v, v, v;
int v, v, v, v, v, v, v;
java.util.Map$Entry v;
org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator v;
java.io.IOException v;
java.lang.Object v, v, v, v, v;
org.apache.activemq.store.kahadb.disk.index.BTreeNode$KeyValueEntry v;
org.apache.activemq.store.kahadb.disk.page.Transaction v;
v := @this: org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.util.Map$Entry nextEntry>;
if v == null goto label;
return;
label:
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: java.lang.Object[] keys>;
v = lengthof v;
if v < v goto label;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: long next>;
v = v cmp 0L;
if v < 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode this$0>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: org.apache.activemq.store.kahadb.disk.index.BTreeIndex index>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.page.Transaction tx>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: long next>;
v = virtualinvoke v.<org.apache.activemq.store.kahadb.disk.index.BTreeIndex: org.apache.activemq.store.kahadb.disk.index.BTreeNode loadNode(org.apache.activemq.store.kahadb.disk.page.Transaction,long,org.apache.activemq.store.kahadb.disk.index.BTreeNode)>(v, v, null);
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current> = v;
v = <org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: boolean $assertionsDisabled>;
if v != 0 goto label;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
v = specialinvoke v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: boolean isBranch()>();
if v == 0 goto label;
v = new java.lang.AssertionError;
specialinvoke v.<java.lang.AssertionError: void <init>(java.lang.Object)>("Should have linked to the next leaf node.");
throw v;
label:
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex> = 0;
goto label;
label:
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.lang.Object endKey>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: java.lang.Object[] keys>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex>;
v = v[v];
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.lang.Object endKey>;
v = virtualinvoke v.<java.lang.Object: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
label:
v = new org.apache.activemq.store.kahadb.disk.index.BTreeNode$KeyValueEntry;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode this$0>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: java.lang.Object[] keys>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex>;
v = v[v];
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: org.apache.activemq.store.kahadb.disk.index.BTreeNode current>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode: java.lang.Object[] values>;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex>;
v = v[v];
specialinvoke v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$KeyValueEntry: void <init>(org.apache.activemq.store.kahadb.disk.index.BTreeNode,java.lang.Object,java.lang.Object)>(v, v, v);
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.util.Map$Entry nextEntry> = v;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex>;
v = v + 1;
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: int nextIndex> = v;
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.io.IOException from label to label with label;
}
public boolean hasNext()
{
java.util.Map$Entry v;
org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator v;
boolean v;
v := @this: org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: void findNextPage()>();
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.util.Map$Entry nextEntry>;
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public java.util.Map$Entry next()
{
java.util.Map$Entry v, v;
org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator v;
java.util.NoSuchElementException v;
v := @this: org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator;
specialinvoke v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: void findNextPage()>();
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.util.Map$Entry nextEntry>;
if v == null goto label;
v = v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.util.Map$Entry nextEntry>;
v.<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: java.util.Map$Entry nextEntry> = null;
return v;
label:
v = new java.util.NoSuchElementException;
specialinvoke v.<java.util.NoSuchElementException: void <init>()>();
throw v;
}
public void remove()
{
java.lang.UnsupportedOperationException v;
org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator v;
v := @this: org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator;
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>()>();
throw v;
}
static void <clinit>()
{
java.lang.Class v;
boolean v, v;
v = class "Lorg/apache/activemq/store/kahadb/disk/index/BTreeNode;";
v = virtualinvoke v.<java.lang.Class: boolean desiredAssertionStatus()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
<org.apache.activemq.store.kahadb.disk.index.BTreeNode$BTreeIterator: boolean $assertionsDisabled> = v;
return;
}
}