abstract class oadd.com.google.common.graph.AbstractDirectedNetworkConnections extends java.lang.Object implements oadd.com.google.common.graph.NetworkConnections
{
protected final java.util.Map inEdgeMap;
protected final java.util.Map outEdgeMap;
private int selfLoopCount;
protected void <init>(java.util.Map, java.util.Map, int)
{
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
java.util.Map v, v;
int v, v, v, v;
java.lang.Object v, v;
boolean v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: int;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map inEdgeMap> = v;
v = staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map outEdgeMap> = v;
v = staticinvoke <oadd.com.google.common.graph.Graphs: int checkNonNegative(int)>(v);
v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: int selfLoopCount> = v;
v = interfaceinvoke v.<java.util.Map: int size()>();
if v > v goto label;
v = interfaceinvoke v.<java.util.Map: int size()>();
if v > v goto label;
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <oadd.com.google.common.base.Preconditions: void checkState(boolean)>(v);
return;
}
public java.util.Set adjacentNodes()
{
oadd.com.google.common.collect.Sets$SetView v;
java.util.Set v, v;
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v = virtualinvoke v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Set predecessors()>();
v = virtualinvoke v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Set successors()>();
v = staticinvoke <oadd.com.google.common.collect.Sets: oadd.com.google.common.collect.Sets$SetView union(java.util.Set,java.util.Set)>(v, v);
return v;
}
public java.util.Set incidentEdges()
{
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
oadd.com.google.common.graph.AbstractDirectedNetworkConnections$1 v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v = new oadd.com.google.common.graph.AbstractDirectedNetworkConnections$1;
specialinvoke v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections$1: void <init>(oadd.com.google.common.graph.AbstractDirectedNetworkConnections)>(v);
return v;
}
public java.util.Set inEdges()
{
java.util.Map v;
java.util.Set v, v;
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map inEdgeMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = staticinvoke <java.util.Collections: java.util.Set unmodifiableSet(java.util.Set)>(v);
return v;
}
public java.util.Set outEdges()
{
java.util.Map v;
java.util.Set v, v;
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map outEdgeMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = staticinvoke <java.util.Collections: java.util.Set unmodifiableSet(java.util.Set)>(v);
return v;
}
public java.lang.Object adjacentNode(java.lang.Object)
{
java.util.Map v;
java.lang.Object v, v, v;
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v := @parameter: java.lang.Object;
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map outEdgeMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
return v;
}
public java.lang.Object removeInEdge(java.lang.Object, boolean)
{
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
java.util.Map v;
int v, v;
java.lang.Object v, v, v;
boolean v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v := @parameter: java.lang.Object;
v := @parameter: boolean;
if v == 0 goto label;
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: int selfLoopCount>;
v = v - 1;
v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: int selfLoopCount> = v;
staticinvoke <oadd.com.google.common.graph.Graphs: int checkNonNegative(int)>(v);
label:
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map inEdgeMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
v = staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
return v;
}
public java.lang.Object removeOutEdge(java.lang.Object)
{
java.util.Map v;
java.lang.Object v, v, v;
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v := @parameter: java.lang.Object;
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map outEdgeMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
v = staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
return v;
}
public void addInEdge(java.lang.Object, java.lang.Object, boolean)
{
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
java.util.Map v;
int v, v;
java.lang.Object v, v, v;
boolean v, v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object;
v := @parameter: boolean;
staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: int selfLoopCount>;
v = v + 1;
v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: int selfLoopCount> = v;
staticinvoke <oadd.com.google.common.graph.Graphs: int checkPositive(int)>(v);
label:
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map inEdgeMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <oadd.com.google.common.base.Preconditions: void checkState(boolean)>(v);
return;
}
public void addOutEdge(java.lang.Object, java.lang.Object)
{
java.util.Map v;
java.lang.Object v, v, v;
oadd.com.google.common.graph.AbstractDirectedNetworkConnections v;
boolean v;
v := @this: oadd.com.google.common.graph.AbstractDirectedNetworkConnections;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object;
staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
v = v.<oadd.com.google.common.graph.AbstractDirectedNetworkConnections: java.util.Map outEdgeMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <oadd.com.google.common.base.Preconditions: void checkState(boolean)>(v);
return;
}
}