abstract class com.google.common.graph.EndpointPairIterator extends com.google.common.collect.AbstractIterator
{
private final com.google.common.graph.BaseGraph graph;
private final java.util.Iterator nodeIterator;
java.lang.Object node;
java.util.Iterator successorIterator;
static com.google.common.graph.EndpointPairIterator of(com.google.common.graph.BaseGraph)
{
com.google.common.graph.BaseGraph v;
com.google.common.graph.EndpointPairIterator$Undirected v;
com.google.common.graph.EndpointPairIterator$Directed v;
com.google.common.graph.EndpointPairIterator v;
boolean v;
v := @parameter: com.google.common.graph.BaseGraph;
v = interfaceinvoke v.<com.google.common.graph.BaseGraph: boolean isDirected()>();
if v == 0 goto label;
v = new com.google.common.graph.EndpointPairIterator$Directed;
v = v;
specialinvoke v.<com.google.common.graph.EndpointPairIterator$Directed: void <init>(com.google.common.graph.BaseGraph)>(v);
goto label;
label:
v = new com.google.common.graph.EndpointPairIterator$Undirected;
v = v;
specialinvoke v.<com.google.common.graph.EndpointPairIterator$Undirected: void <init>(com.google.common.graph.BaseGraph)>(v);
label:
return v;
}
private void <init>(com.google.common.graph.BaseGraph)
{
com.google.common.graph.BaseGraph v;
com.google.common.collect.ImmutableSet v;
java.util.Iterator v;
java.util.Set v;
com.google.common.collect.UnmodifiableIterator v;
com.google.common.graph.EndpointPairIterator v;
v := @this: com.google.common.graph.EndpointPairIterator;
v := @parameter: com.google.common.graph.BaseGraph;
specialinvoke v.<com.google.common.collect.AbstractIterator: void <init>()>();
v.<com.google.common.graph.EndpointPairIterator: java.lang.Object node> = null;
v = staticinvoke <com.google.common.collect.ImmutableSet: com.google.common.collect.ImmutableSet of()>();
v = virtualinvoke v.<com.google.common.collect.ImmutableSet: com.google.common.collect.UnmodifiableIterator iterator()>();
v.<com.google.common.graph.EndpointPairIterator: java.util.Iterator successorIterator> = v;
v.<com.google.common.graph.EndpointPairIterator: com.google.common.graph.BaseGraph graph> = v;
v = interfaceinvoke v.<com.google.common.graph.BaseGraph: java.util.Set nodes()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v.<com.google.common.graph.EndpointPairIterator: java.util.Iterator nodeIterator> = v;
return;
}
final boolean advance()
{
java.util.Iterator v, v, v, v;
java.util.Set v;
com.google.common.graph.EndpointPairIterator v;
com.google.common.graph.BaseGraph v;
java.lang.Object v, v;
boolean v, v, v;
v := @this: com.google.common.graph.EndpointPairIterator;
v = v.<com.google.common.graph.EndpointPairIterator: java.util.Iterator successorIterator>;
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <com.google.common.base.Preconditions: void checkState(boolean)>(v);
v = v.<com.google.common.graph.EndpointPairIterator: java.util.Iterator nodeIterator>;
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v != 0 goto label;
return 0;
label:
v = v.<com.google.common.graph.EndpointPairIterator: java.util.Iterator nodeIterator>;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v.<com.google.common.graph.EndpointPairIterator: java.lang.Object node> = v;
v = v.<com.google.common.graph.EndpointPairIterator: com.google.common.graph.BaseGraph graph>;
v = v.<com.google.common.graph.EndpointPairIterator: java.lang.Object node>;
v = interfaceinvoke v.<com.google.common.graph.BaseGraph: java.util.Set successors(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v.<com.google.common.graph.EndpointPairIterator: java.util.Iterator successorIterator> = v;
return 1;
}
}