package com.google.common.collect; import com.google.common.base.Objects; import com.google.common.base.Preconditions; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; import java.util.Collection; import java.util.Iterator; import java.util.Map; import java.util.Set; import javax.annotation.CheckForNull; /* JADX INFO: Access modifiers changed from: package-private */ @ElementTypesAreNonnullByDefault /* loaded from: classes3.dex */ public abstract class AbstractBiMap extends ForwardingMap implements BiMap, Serializable { private static final long serialVersionUID = 0; private transient Map delegate; @CheckForNull private transient Set> entrySet; transient AbstractBiMap inverse; @CheckForNull private transient Set keySet; @CheckForNull private transient Set valueSet; @ParametricNullness K checkKey(@ParametricNullness K k) { return k; } @ParametricNullness V checkValue(@ParametricNullness V v) { return v; } /* JADX INFO: Access modifiers changed from: protected */ @Override // com.google.common.collect.ForwardingMap, com.google.common.collect.ForwardingObject public Map delegate() { return this.delegate; } @Override // com.google.common.collect.BiMap public BiMap inverse() { return this.inverse; } void setInverse(AbstractBiMap abstractBiMap) { this.inverse = abstractBiMap; } /* JADX INFO: Access modifiers changed from: package-private */ public AbstractBiMap(Map map, Map map2) { setDelegates(map, map2); } private AbstractBiMap(Map map, AbstractBiMap abstractBiMap) { this.delegate = map; this.inverse = abstractBiMap; } /* JADX INFO: Access modifiers changed from: package-private */ public void setDelegates(Map map, Map map2) { Preconditions.checkState(this.delegate == null); Preconditions.checkState(this.inverse == null); Preconditions.checkArgument(map.isEmpty()); Preconditions.checkArgument(map2.isEmpty()); Preconditions.checkArgument(map != map2); this.delegate = map; this.inverse = makeInverse(map2); } AbstractBiMap makeInverse(Map map) { return new Inverse(map, this); } @Override // com.google.common.collect.ForwardingMap, java.util.Map public boolean containsValue(@CheckForNull Object obj) { return this.inverse.containsKey(obj); } @Override // com.google.common.collect.ForwardingMap, java.util.Map, com.google.common.collect.BiMap @CheckForNull public V put(@ParametricNullness K k, @ParametricNullness V v) { return putInBothMaps(k, v, false); } @Override // com.google.common.collect.BiMap @CheckForNull public V forcePut(@ParametricNullness K k, @ParametricNullness V v) { return putInBothMaps(k, v, true); } @CheckForNull private V putInBothMaps(@ParametricNullness K k, @ParametricNullness V v, boolean z) { checkKey(k); checkValue(v); boolean containsKey = containsKey(k); if (containsKey && Objects.equal(v, get(k))) { return v; } if (z) { inverse().remove(v); } else { Preconditions.checkArgument(!containsValue(v), "value already present: %s", v); } V put = this.delegate.put(k, v); updateInverseMap(k, containsKey, put, v); return put; } /* JADX INFO: Access modifiers changed from: private */ /* JADX WARN: Multi-variable type inference failed */ public void updateInverseMap(@ParametricNullness K k, boolean z, @CheckForNull V v, @ParametricNullness V v2) { if (z) { removeFromInverseMap(NullnessCasts.uncheckedCastNullableTToT(v)); } this.inverse.delegate.put(v2, k); } @Override // com.google.common.collect.ForwardingMap, java.util.Map @CheckForNull public V remove(@CheckForNull Object obj) { if (containsKey(obj)) { return removeFromBothMaps(obj); } return null; } /* JADX INFO: Access modifiers changed from: private */ @ParametricNullness public V removeFromBothMaps(@CheckForNull Object obj) { V v = (V) NullnessCasts.uncheckedCastNullableTToT(this.delegate.remove(obj)); removeFromInverseMap(v); return v; } /* JADX INFO: Access modifiers changed from: private */ public void removeFromInverseMap(@ParametricNullness V v) { this.inverse.delegate.remove(v); } @Override // com.google.common.collect.ForwardingMap, java.util.Map, com.google.common.collect.BiMap public void putAll(Map map) { for (Map.Entry entry : map.entrySet()) { put(entry.getKey(), entry.getValue()); } } @Override // com.google.common.collect.ForwardingMap, java.util.Map public void clear() { this.delegate.clear(); this.inverse.delegate.clear(); } @Override // com.google.common.collect.ForwardingMap, java.util.Map public Set keySet() { Set set = this.keySet; if (set != null) { return set; } KeySet keySet = new KeySet(); this.keySet = keySet; return keySet; } /* JADX INFO: Access modifiers changed from: private */ /* loaded from: classes3.dex */ public class KeySet extends ForwardingSet { private KeySet() { } /* JADX INFO: Access modifiers changed from: protected */ @Override // com.google.common.collect.ForwardingSet, com.google.common.collect.ForwardingCollection, com.google.common.collect.ForwardingObject public Set delegate() { return AbstractBiMap.this.delegate.keySet(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public void clear() { AbstractBiMap.this.clear(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean remove(@CheckForNull Object obj) { if (!contains(obj)) { return false; } AbstractBiMap.this.removeFromBothMaps(obj); return true; } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean removeAll(Collection collection) { return standardRemoveAll(collection); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean retainAll(Collection collection) { return standardRetainAll(collection); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.lang.Iterable, java.util.Set public Iterator iterator() { return Maps.keyIterator(AbstractBiMap.this.entrySet().iterator()); } } @Override // com.google.common.collect.ForwardingMap, java.util.Map, com.google.common.collect.BiMap public Set values() { Set set = this.valueSet; if (set != null) { return set; } ValueSet valueSet = new ValueSet(); this.valueSet = valueSet; return valueSet; } /* JADX INFO: Access modifiers changed from: private */ /* loaded from: classes3.dex */ public class ValueSet extends ForwardingSet { final Set valuesDelegate; /* JADX INFO: Access modifiers changed from: protected */ @Override // com.google.common.collect.ForwardingSet, com.google.common.collect.ForwardingCollection, com.google.common.collect.ForwardingObject public Set delegate() { return this.valuesDelegate; } private ValueSet() { this.valuesDelegate = AbstractBiMap.this.inverse.keySet(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.lang.Iterable, java.util.Set public Iterator iterator() { return Maps.valueIterator(AbstractBiMap.this.entrySet().iterator()); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public Object[] toArray() { return standardToArray(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public T[] toArray(T[] tArr) { return (T[]) standardToArray(tArr); } @Override // com.google.common.collect.ForwardingObject public String toString() { return standardToString(); } } @Override // com.google.common.collect.ForwardingMap, java.util.Map public Set> entrySet() { Set> set = this.entrySet; if (set != null) { return set; } EntrySet entrySet = new EntrySet(); this.entrySet = entrySet; return entrySet; } /* JADX INFO: Access modifiers changed from: package-private */ /* loaded from: classes3.dex */ public class BiMapEntry extends ForwardingMapEntry { private final Map.Entry delegate; /* JADX INFO: Access modifiers changed from: protected */ @Override // com.google.common.collect.ForwardingMapEntry, com.google.common.collect.ForwardingObject public Map.Entry delegate() { return this.delegate; } BiMapEntry(Map.Entry entry) { this.delegate = entry; } @Override // com.google.common.collect.ForwardingMapEntry, java.util.Map.Entry public V setValue(V v) { AbstractBiMap.this.checkValue(v); Preconditions.checkState(AbstractBiMap.this.entrySet().contains(this), "entry no longer in map"); if (Objects.equal(v, getValue())) { return v; } Preconditions.checkArgument(!AbstractBiMap.this.containsValue(v), "value already present: %s", v); V value = this.delegate.setValue(v); Preconditions.checkState(Objects.equal(v, AbstractBiMap.this.get(getKey())), "entry no longer in map"); AbstractBiMap.this.updateInverseMap(getKey(), true, value, v); return value; } } Iterator> entrySetIterator() { final Iterator> it = this.delegate.entrySet().iterator(); return new Iterator>() { // from class: com.google.common.collect.AbstractBiMap.1 @CheckForNull Map.Entry entry; @Override // java.util.Iterator public boolean hasNext() { return it.hasNext(); } @Override // java.util.Iterator public Map.Entry next() { this.entry = (Map.Entry) it.next(); return new BiMapEntry(this.entry); } @Override // java.util.Iterator public void remove() { Map.Entry entry = this.entry; if (entry == null) { throw new IllegalStateException("no calls to next() since the last call to remove()"); } V value = entry.getValue(); it.remove(); AbstractBiMap.this.removeFromInverseMap(value); this.entry = null; } }; } /* JADX INFO: Access modifiers changed from: private */ /* loaded from: classes3.dex */ public class EntrySet extends ForwardingSet> { final Set> esDelegate; /* JADX INFO: Access modifiers changed from: protected */ @Override // com.google.common.collect.ForwardingSet, com.google.common.collect.ForwardingCollection, com.google.common.collect.ForwardingObject public Set> delegate() { return this.esDelegate; } private EntrySet() { this.esDelegate = AbstractBiMap.this.delegate.entrySet(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public void clear() { AbstractBiMap.this.clear(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean remove(@CheckForNull Object obj) { if (!this.esDelegate.contains(obj) || !(obj instanceof Map.Entry)) { return false; } Map.Entry entry = (Map.Entry) obj; ((AbstractBiMap) AbstractBiMap.this.inverse).delegate.remove(entry.getValue()); this.esDelegate.remove(entry); return true; } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.lang.Iterable, java.util.Set public Iterator> iterator() { return AbstractBiMap.this.entrySetIterator(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public Object[] toArray() { return standardToArray(); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public T[] toArray(T[] tArr) { return (T[]) standardToArray(tArr); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean contains(@CheckForNull Object obj) { return Maps.containsEntryImpl(delegate(), obj); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean containsAll(Collection collection) { return standardContainsAll(collection); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean removeAll(Collection collection) { return standardRemoveAll(collection); } @Override // com.google.common.collect.ForwardingCollection, java.util.Collection, java.util.Set public boolean retainAll(Collection collection) { return standardRetainAll(collection); } } /* JADX INFO: Access modifiers changed from: package-private */ /* loaded from: classes3.dex */ public static class Inverse extends AbstractBiMap { private static final long serialVersionUID = 0; @Override // com.google.common.collect.AbstractBiMap, com.google.common.collect.ForwardingMap, com.google.common.collect.ForwardingObject protected /* bridge */ /* synthetic */ Object delegate() { return super.delegate(); } @Override // com.google.common.collect.AbstractBiMap, com.google.common.collect.ForwardingMap, java.util.Map, com.google.common.collect.BiMap public /* bridge */ /* synthetic */ Collection values() { return super.values(); } Inverse(Map map, AbstractBiMap abstractBiMap) { super(map, abstractBiMap); } @Override // com.google.common.collect.AbstractBiMap @ParametricNullness K checkKey(@ParametricNullness K k) { return this.inverse.checkValue(k); } @Override // com.google.common.collect.AbstractBiMap @ParametricNullness V checkValue(@ParametricNullness V v) { return this.inverse.checkKey(v); } private void writeObject(ObjectOutputStream objectOutputStream) throws IOException { objectOutputStream.defaultWriteObject(); objectOutputStream.writeObject(inverse()); } private void readObject(ObjectInputStream objectInputStream) throws IOException, ClassNotFoundException { objectInputStream.defaultReadObject(); setInverse((AbstractBiMap) objectInputStream.readObject()); } Object readResolve() { return inverse().inverse(); } } }