package com.google.common.graph; import com.google.common.base.Preconditions; import com.google.common.collect.HashMultiset; import com.google.common.collect.ImmutableMap; import com.google.common.collect.Multiset; import com.google.errorprone.annotations.concurrent.LazyInit; import java.lang.ref.Reference; import java.lang.ref.SoftReference; import java.util.Collections; import java.util.HashMap; import java.util.Map; import java.util.Set; import javax.annotation.CheckForNull; @ElementTypesAreNonnullByDefault /* loaded from: classes3.dex */ final class UndirectedMultiNetworkConnections extends AbstractUndirectedNetworkConnections { @CheckForNull @LazyInit private transient Reference> adjacentNodesReference; private UndirectedMultiNetworkConnections(Map map) { super(map); } /* JADX INFO: Access modifiers changed from: package-private */ public static UndirectedMultiNetworkConnections of() { return new UndirectedMultiNetworkConnections<>(new HashMap(2, 1.0f)); } /* JADX INFO: Access modifiers changed from: package-private */ public static UndirectedMultiNetworkConnections ofImmutable(Map map) { return new UndirectedMultiNetworkConnections<>(ImmutableMap.copyOf((Map) map)); } @Override // com.google.common.graph.NetworkConnections public Set adjacentNodes() { return Collections.unmodifiableSet(adjacentNodesMultiset().elementSet()); } /* JADX INFO: Access modifiers changed from: private */ public Multiset adjacentNodesMultiset() { Multiset multiset = (Multiset) getReference(this.adjacentNodesReference); if (multiset != null) { return multiset; } HashMultiset create = HashMultiset.create(this.incidentEdgeMap.values()); this.adjacentNodesReference = new SoftReference(create); return create; } @Override // com.google.common.graph.NetworkConnections public Set edgesConnecting(final N n) { return new MultiEdgesConnecting(this.incidentEdgeMap, n) { // from class: com.google.common.graph.UndirectedMultiNetworkConnections.1 @Override // java.util.AbstractCollection, java.util.Collection, java.util.Set public int size() { return UndirectedMultiNetworkConnections.this.adjacentNodesMultiset().count(n); } }; } @Override // com.google.common.graph.AbstractUndirectedNetworkConnections, com.google.common.graph.NetworkConnections @CheckForNull public N removeInEdge(E e, boolean z) { if (z) { return null; } return removeOutEdge(e); } @Override // com.google.common.graph.AbstractUndirectedNetworkConnections, com.google.common.graph.NetworkConnections public N removeOutEdge(E e) { N n = (N) super.removeOutEdge(e); Multiset multiset = (Multiset) getReference(this.adjacentNodesReference); if (multiset != null) { Preconditions.checkState(multiset.remove(n)); } return n; } @Override // com.google.common.graph.AbstractUndirectedNetworkConnections, com.google.common.graph.NetworkConnections public void addInEdge(E e, N n, boolean z) { if (z) { return; } addOutEdge(e, n); } @Override // com.google.common.graph.AbstractUndirectedNetworkConnections, com.google.common.graph.NetworkConnections public void addOutEdge(E e, N n) { super.addOutEdge(e, n); Multiset multiset = (Multiset) getReference(this.adjacentNodesReference); if (multiset != null) { Preconditions.checkState(multiset.add(n)); } } @CheckForNull private static T getReference(@CheckForNull Reference reference) { if (reference == null) { return null; } return reference.get(); } }