package com.google.common.graph;
import static com.google.common.graph.GraphConstants.EXPECTED_DEGREE;
import com.google.common.collect.BiMap;
import com.google.common.collect.HashBiMap;
import com.google.common.collect.ImmutableBiMap;
import java.util.Collections;
import java.util.Map;
import java.util.Set;
final class UndirectedNetworkConnections<N, E> extends AbstractUndirectedNetworkConnections<N, E> {
protected UndirectedNetworkConnections(Map<E, N> incidentEdgeMap) {
super(incidentEdgeMap);
}
static <N, E> UndirectedNetworkConnections<N, E> of() {
return new UndirectedNetworkConnections<>(HashBiMap.<E, N>create(EXPECTED_DEGREE));
}
static <N, E> UndirectedNetworkConnections<N, E> ofImmutable(Map<E, N> incidentEdges) {
return new UndirectedNetworkConnections<>(ImmutableBiMap.copyOf(incidentEdges));
}
@Override
public Set<N> adjacentNodes() {
return Collections.unmodifiableSet(((BiMap<E, N>) incidentEdgeMap).values());
}
@Override
public Set<E> edgesConnecting(N node) {
return new EdgesConnecting<E>(((BiMap<E, N>) incidentEdgeMap).inverse(), node);
}
}