Rabbit-R1/original r1/java/sources/kotlin/collections/builders/MapBuilder.java

916 lines
47 KiB
Java
Raw Normal View History

2024-05-21 16:08:36 -05:00
package kotlin.collections.builders;
import androidx.exifinterface.media.ExifInterface;
import androidx.media3.exoplayer.upstream.CmcdHeadersFactory;
import io.sentry.SentryEnvelopeItemHeader;
import io.sentry.protocol.OperatingSystem;
import java.io.NotSerializableException;
import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.ConcurrentModificationException;
import java.util.Iterator;
import java.util.Map;
import java.util.NoSuchElementException;
import java.util.Set;
import kotlin.Metadata;
import kotlin.collections.AbstractList;
import kotlin.collections.ArraysKt;
import kotlin.jvm.internal.DefaultConstructorMarker;
import kotlin.jvm.internal.Intrinsics;
import kotlin.jvm.internal.markers.KMutableIterator;
import kotlin.jvm.internal.markers.KMutableMap;
import kotlin.ranges.IntRange;
import kotlin.ranges.RangesKt;
/* compiled from: MapBuilder.kt */
@Metadata(d1 = {"\u0000¨\u0001\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010%\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\b\n\u0002\b\u0002\n\u0002\u0010\u0011\n\u0002\b\u0002\n\u0002\u0010\u0015\n\u0002\b\b\n\u0002\u0010#\n\u0002\u0010'\n\u0002\b\u0003\n\u0002\u0018\u0002\n\u0002\b\u0004\n\u0002\u0010\u000b\n\u0002\b\u0007\n\u0002\u0018\u0002\n\u0002\b\u0004\n\u0002\u0010\u001f\n\u0002\b\u0003\n\u0002\u0018\u0002\n\u0002\b\u0007\n\u0002\u0010$\n\u0000\n\u0002\u0010\u0002\n\u0002\b\u0005\n\u0002\u0010\u001e\n\u0002\b\u0003\n\u0002\u0010&\n\u0002\b\f\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u0000\n\u0002\b\b\n\u0002\u0018\u0002\n\u0002\b\u001b\n\u0002\u0010\u000e\n\u0000\n\u0002\u0018\u0002\n\u0002\b\t\b\u0000\u0018\u0000 \u0080\u0001*\u0004\b\u0000\u0010\u0001*\u0004\b\u0001\u0010\u00022\u000e\u0012\u0004\u0012\u0002H\u0001\u0012\u0004\u0012\u0002H\u00020\u00032\u00060\u0004j\u0002`\u0005:\f\u0080\u0001\u0081\u0001\u0082\u0001\u0083\u0001\u0084\u0001\u0085\u0001B\u0007\b\u0016¢\u0006\u0002\u0010\u0006B\u000f\b\u0016\u0012\u0006\u0010\u0007\u001a\u00020\\u0006\u0002\u0010\tBE\b\u0002\u0012\f\u0010\n\u001a\b\u0012\u0004\u0012\u00028\u00000\u000b\u0012\u000e\u0010\f\u001a\n\u0012\u0004\u0012\u00028\u0001\u0018\u00010\u000b\u0012\u0006\u0010\r\u001a\u00020\u000e\u0012\u0006\u0010\u000f\u001a\u00020\u000e\u0012\u0006\u0010\u0010\u001a\u00020\b\u0012\u0006\u0010\u0011\u001a\u00020\\u0006\u0002\u0010\u0012J\u0017\u00103\u001a\u00020\b2\u0006\u00104\u001a\u00028\u0000H\u0000¢\u0006\u0004\b5\u00106J\u0013\u00107\u001a\b\u0012\u0004\u0012\u00028\u00010\u000bH\u0002¢\u0006\u0002\u00108J\u0012\u00109\u001a\u000e\u0012\u0004\u0012\u00028\u0000\u0012\u0004\u0012\u00028\u00010:J\r\u0010;\u001a\u00020<H\u0000¢\u0006\u0002\b=J\b\u0010>\u001a\u00020<H\u0016J\b\u0010?\u001a\u00020<H\u0002J\u0019\u0010@\u001a\u00020!2\n\u0010A\u001a\u0006\u0012\u0002\b\u00030BH\u0000¢\u0006\u0002\bCJ!\u0010D\u001a\u00020!2\u0012\u0010E\u001a\u000e\u0012\u0004\u0012\u00028\u0000\u0012\u0004\u0012\u00028\u00010FH\u0000¢\u0006\u0002\bGJ\u0015\u0010H\u001a\u00020!2\u0006\u00104\u001a\u00028\u0000H\u0016¢\u0006\u0002\u0010IJ\u0015\u0010J\u001a\u00020!2\u0006\u0010K\u001a\u00028\u0001H\u0016¢\u0006\u0002\u0010IJ\u0018\u0010L\u001a\u00020!2\u000e\u0010M\u001a\n\u0012\u0002\b\u0003\u0012\u0002\b\u00030:H\u0002J\u0010\u0010N\u001a\u00020<2\u0006\u0010O\u001a\u00020\bH\u0002J\u0010\u0010P\u001a\u00020<2\u0006\u0010Q\u001a\u00020\bH\u0002J\u0019\u0010R\u001a\u000e\u0012\u0004\u0012\u00028\u0000\u0012\u0004\u0012\u00028\u00010SH\u0000¢\u0006\u0002\bTJ\u0013\u0010U\u001a\u00020!2\b\u0010M\u001a\u0004\u0018\u00010VH\u0096\u0002J\u0015\u0010W\u001a\u00020\b2\u0006\u00104\u001a\u00028\u0000H\u0002¢\u0006\u0002\u00106J\u0015\u0010X\u001a\u00020\b2\u0006\u0010K\u001a\u00028\u0001H\u0002¢\u0006\u0002\u00106J\u0018\u0010Y\u001a\u0004\u0018\u00018\u00012\u0006\u00104\u001a\u00028\u0000H\u0096\u0002¢\u0006\u0002\u0010ZJ\u0015\u0010[\u001a\u00020\b2\u0006\u00104\u001a\u00028\u0000H\u0002¢\u0006\u0002\u00106J\b\u0010\\\u001a\u00020\bH\u0016J\b\u0010]\u001a\u00020!H\u0016J\u0019\u0010^\u001a\u000e\u0012\u0004\u0012\u00028\u0000\u0012\u0004\u0012\u00028\u00010_H\u0000¢\u0006\u0002\b`J\u001f\u0010a\u001a\u0004\u0018\u00018\u00012\u0006\u00104\u001a\u00028\u00002\u0006\u0010K\u001a\u00028\u0001H\u0016¢\u0006\u0002\u0010bJ\u001e\u0010c\u001a\u00020<2\u0014\u0010d\u001a\u0010\u0012\u0006\b\u0001\u0012\u00028\u0000\u0012\u0004\u0012\u00028\u00010:H\u0016J\"\u0010e\u001a\u00020!2\u0018\u0010d\u001a\u0014\u0012\u0010\u0012\u000e\u0012\u0004\u0012\u00028\u0000\u0012\u0004\u0012\u00028\u00010F0BH\u0002J\u001c\u0010f\u001a\u00020!2\u0012\u0010E\u001a\u000e\u0012\u0004\u0012\u00028\u0000\u0012\u0004\u0012\u00028\u00010FH\u0002J\u0010\u0010g\u001a\u00020!2\u0006\u0010h\u001a\u00020\bH\u0002J\b\u0010i\u001a\u00020<H\u0002J\u0010\u0010j\u001a\u00020<2\u0006\u0010k\u001a\u00020\bH\u0002J\u0017\u0010l\u001a\u0004\u0018\u00018\u00012\u0006\u00104\u001a\u00028\u0000H\u0016¢\u0006\u0002\u0010ZJ!\u0010m\u001a\u00020!2\u0012\u0010E\u001a\u00
/* loaded from: classes3.dex */
public final class MapBuilder<K, V> implements Map<K, V>, Serializable, KMutableMap {
/* renamed from: Companion, reason: from kotlin metadata */
public static final Companion INSTANCE = new Companion(null);
private static final MapBuilder Empty;
private static final int INITIAL_CAPACITY = 8;
private static final int INITIAL_MAX_PROBE_DISTANCE = 2;
private static final int MAGIC = -1640531527;
private static final int TOMBSTONE = -1;
private MapBuilderEntries<K, V> entriesView;
private int[] hashArray;
private int hashShift;
private boolean isReadOnly;
private K[] keysArray;
private MapBuilderKeys<K> keysView;
private int length;
private int maxProbeDistance;
private int modCount;
private int[] presenceArray;
private int size;
private V[] valuesArray;
private MapBuilderValues<V> valuesView;
private final void registerModification() {
this.modCount++;
}
public int getSize() {
return this.size;
}
/* renamed from: isReadOnly$kotlin_stdlib, reason: from getter */
public final boolean getIsReadOnly() {
return this.isReadOnly;
}
private MapBuilder(K[] kArr, V[] vArr, int[] iArr, int[] iArr2, int i, int i2) {
this.keysArray = kArr;
this.valuesArray = vArr;
this.presenceArray = iArr;
this.hashArray = iArr2;
this.maxProbeDistance = i;
this.length = i2;
this.hashShift = INSTANCE.computeShift(getHashSize());
}
@Override // java.util.Map
public final /* bridge */ Set<Map.Entry<K, V>> entrySet() {
return getEntries();
}
@Override // java.util.Map
public final /* bridge */ Set<K> keySet() {
return getKeys();
}
@Override // java.util.Map
public final /* bridge */ int size() {
return getSize();
}
@Override // java.util.Map
public final /* bridge */ Collection<V> values() {
return getValues();
}
public MapBuilder() {
this(8);
}
public MapBuilder(int i) {
this(ListBuilderKt.arrayOfUninitializedElements(i), null, new int[i], new int[INSTANCE.computeHashSize(i)], 2, 0);
}
public final Map<K, V> build() {
checkIsMutable$kotlin_stdlib();
this.isReadOnly = true;
if (size() <= 0) {
this = Empty;
Intrinsics.checkNotNull(this, "null cannot be cast to non-null type kotlin.collections.Map<K of kotlin.collections.builders.MapBuilder, V of kotlin.collections.builders.MapBuilder>");
}
return this;
}
private final Object writeReplace() {
if (this.isReadOnly) {
return new SerializedMap(this);
}
throw new NotSerializableException("The map cannot be serialized while it is being built.");
}
@Override // java.util.Map
public boolean isEmpty() {
return size() == 0;
}
/* JADX WARN: Multi-variable type inference failed */
@Override // java.util.Map
public boolean containsKey(Object key) {
return findKey(key) >= 0;
}
/* JADX WARN: Multi-variable type inference failed */
@Override // java.util.Map
public boolean containsValue(Object value) {
return findValue(value) >= 0;
}
/* JADX WARN: Multi-variable type inference failed */
@Override // java.util.Map
public V get(Object key) {
int findKey = findKey(key);
if (findKey < 0) {
return null;
}
V[] vArr = this.valuesArray;
Intrinsics.checkNotNull(vArr);
return vArr[findKey];
}
@Override // java.util.Map
public V put(K key, V value) {
checkIsMutable$kotlin_stdlib();
int addKey$kotlin_stdlib = addKey$kotlin_stdlib(key);
V[] allocateValuesArray = allocateValuesArray();
if (addKey$kotlin_stdlib < 0) {
int i = (-addKey$kotlin_stdlib) - 1;
V v = allocateValuesArray[i];
allocateValuesArray[i] = value;
return v;
}
allocateValuesArray[addKey$kotlin_stdlib] = value;
return null;
}
@Override // java.util.Map
public void putAll(Map<? extends K, ? extends V> from) {
Intrinsics.checkNotNullParameter(from, "from");
checkIsMutable$kotlin_stdlib();
putAllEntries(from.entrySet());
}
/* JADX WARN: Multi-variable type inference failed */
@Override // java.util.Map
public V remove(Object key) {
int removeKey$kotlin_stdlib = removeKey$kotlin_stdlib(key);
if (removeKey$kotlin_stdlib < 0) {
return null;
}
V[] vArr = this.valuesArray;
Intrinsics.checkNotNull(vArr);
V v = vArr[removeKey$kotlin_stdlib];
ListBuilderKt.resetAt(vArr, removeKey$kotlin_stdlib);
return v;
}
/* JADX WARN: Type inference failed for: r0v1, types: [kotlin.collections.IntIterator] */
@Override // java.util.Map
public void clear() {
checkIsMutable$kotlin_stdlib();
?? it = new IntRange(0, this.length - 1).iterator();
while (it.hasNext()) {
int nextInt = it.nextInt();
int[] iArr = this.presenceArray;
int i = iArr[nextInt];
if (i >= 0) {
this.hashArray[i] = 0;
iArr[nextInt] = -1;
}
}
ListBuilderKt.resetRange(this.keysArray, 0, this.length);
V[] vArr = this.valuesArray;
if (vArr != null) {
ListBuilderKt.resetRange(vArr, 0, this.length);
}
this.size = 0;
this.length = 0;
registerModification();
}
public Set<K> getKeys() {
MapBuilderKeys<K> mapBuilderKeys = this.keysView;
if (mapBuilderKeys == null) {
MapBuilderKeys<K> mapBuilderKeys2 = new MapBuilderKeys<>(this);
this.keysView = mapBuilderKeys2;
return mapBuilderKeys2;
}
return mapBuilderKeys;
}
public Collection<V> getValues() {
MapBuilderValues<V> mapBuilderValues = this.valuesView;
if (mapBuilderValues == null) {
MapBuilderValues<V> mapBuilderValues2 = new MapBuilderValues<>(this);
this.valuesView = mapBuilderValues2;
return mapBuilderValues2;
}
return mapBuilderValues;
}
public Set<Map.Entry<K, V>> getEntries() {
MapBuilderEntries<K, V> mapBuilderEntries = this.entriesView;
if (mapBuilderEntries == null) {
MapBuilderEntries<K, V> mapBuilderEntries2 = new MapBuilderEntries<>(this);
this.entriesView = mapBuilderEntries2;
return mapBuilderEntries2;
}
return mapBuilderEntries;
}
@Override // java.util.Map
public boolean equals(Object other) {
return other == this || ((other instanceof Map) && contentEquals((Map) other));
}
@Override // java.util.Map
public int hashCode() {
EntriesItr<K, V> entriesIterator$kotlin_stdlib = entriesIterator$kotlin_stdlib();
int i = 0;
while (entriesIterator$kotlin_stdlib.hasNext()) {
i += entriesIterator$kotlin_stdlib.nextHashCode$kotlin_stdlib();
}
return i;
}
public String toString() {
StringBuilder sb = new StringBuilder((size() * 3) + 2);
sb.append("{");
EntriesItr<K, V> entriesIterator$kotlin_stdlib = entriesIterator$kotlin_stdlib();
int i = 0;
while (entriesIterator$kotlin_stdlib.hasNext()) {
if (i > 0) {
sb.append(", ");
}
entriesIterator$kotlin_stdlib.nextAppendString(sb);
i++;
}
sb.append("}");
String sb2 = sb.toString();
Intrinsics.checkNotNullExpressionValue(sb2, "toString(...)");
return sb2;
}
public final int getCapacity$kotlin_stdlib() {
return this.keysArray.length;
}
private final int getHashSize() {
return this.hashArray.length;
}
public final void checkIsMutable$kotlin_stdlib() {
if (this.isReadOnly) {
throw new UnsupportedOperationException();
}
}
private final void ensureExtraCapacity(int n) {
if (shouldCompact(n)) {
rehash(getHashSize());
} else {
ensureCapacity(this.length + n);
}
}
private final boolean shouldCompact(int extraCapacity) {
int capacity$kotlin_stdlib = getCapacity$kotlin_stdlib();
int i = this.length;
int i2 = capacity$kotlin_stdlib - i;
int size = i - size();
return i2 < extraCapacity && i2 + size >= extraCapacity && size >= getCapacity$kotlin_stdlib() / 4;
}
private final void ensureCapacity(int minCapacity) {
if (minCapacity < 0) {
throw new OutOfMemoryError();
}
if (minCapacity > getCapacity$kotlin_stdlib()) {
int newCapacity$kotlin_stdlib = AbstractList.INSTANCE.newCapacity$kotlin_stdlib(getCapacity$kotlin_stdlib(), minCapacity);
this.keysArray = (K[]) ListBuilderKt.copyOfUninitializedElements(this.keysArray, newCapacity$kotlin_stdlib);
V[] vArr = this.valuesArray;
this.valuesArray = vArr != null ? (V[]) ListBuilderKt.copyOfUninitializedElements(vArr, newCapacity$kotlin_stdlib) : null;
int[] copyOf = Arrays.copyOf(this.presenceArray, newCapacity$kotlin_stdlib);
Intrinsics.checkNotNullExpressionValue(copyOf, "copyOf(...)");
this.presenceArray = copyOf;
int computeHashSize = INSTANCE.computeHashSize(newCapacity$kotlin_stdlib);
if (computeHashSize > getHashSize()) {
rehash(computeHashSize);
}
}
}
/* JADX INFO: Access modifiers changed from: private */
public final V[] allocateValuesArray() {
V[] vArr = this.valuesArray;
if (vArr != null) {
return vArr;
}
V[] vArr2 = (V[]) ListBuilderKt.arrayOfUninitializedElements(getCapacity$kotlin_stdlib());
this.valuesArray = vArr2;
return vArr2;
}
private final int hash(K key) {
return ((key != null ? key.hashCode() : 0) * MAGIC) >>> this.hashShift;
}
private final void compact() {
int i;
V[] vArr = this.valuesArray;
int i2 = 0;
int i3 = 0;
while (true) {
i = this.length;
if (i2 >= i) {
break;
}
if (this.presenceArray[i2] >= 0) {
K[] kArr = this.keysArray;
kArr[i3] = kArr[i2];
if (vArr != null) {
vArr[i3] = vArr[i2];
}
i3++;
}
i2++;
}
ListBuilderKt.resetRange(this.keysArray, i3, i);
if (vArr != null) {
ListBuilderKt.resetRange(vArr, i3, this.length);
}
this.length = i3;
}
private final void rehash(int newHashSize) {
registerModification();
if (this.length > size()) {
compact();
}
int i = 0;
if (newHashSize != getHashSize()) {
this.hashArray = new int[newHashSize];
this.hashShift = INSTANCE.computeShift(newHashSize);
} else {
ArraysKt.fill(this.hashArray, 0, 0, getHashSize());
}
while (i < this.length) {
int i2 = i + 1;
if (!putRehash(i)) {
throw new IllegalStateException("This cannot happen with fixed magic multiplier and grow-only hash array. Have object hashCodes changed?");
}
i = i2;
}
}
private final boolean putRehash(int i) {
int hash = hash(this.keysArray[i]);
int i2 = this.maxProbeDistance;
while (true) {
int[] iArr = this.hashArray;
if (iArr[hash] == 0) {
iArr[hash] = i + 1;
this.presenceArray[i] = hash;
return true;
}
i2--;
if (i2 < 0) {
return false;
}
hash = hash == 0 ? getHashSize() - 1 : hash - 1;
}
}
private final int findKey(K key) {
int hash = hash(key);
int i = this.maxProbeDistance;
while (true) {
int i2 = this.hashArray[hash];
if (i2 == 0) {
return -1;
}
if (i2 > 0) {
int i3 = i2 - 1;
if (Intrinsics.areEqual(this.keysArray[i3], key)) {
return i3;
}
}
i--;
if (i < 0) {
return -1;
}
hash = hash == 0 ? getHashSize() - 1 : hash - 1;
}
}
private final int findValue(V value) {
int i = this.length;
while (true) {
i--;
if (i < 0) {
return -1;
}
if (this.presenceArray[i] >= 0) {
V[] vArr = this.valuesArray;
Intrinsics.checkNotNull(vArr);
if (Intrinsics.areEqual(vArr[i], value)) {
return i;
}
}
}
}
public final int addKey$kotlin_stdlib(K key) {
checkIsMutable$kotlin_stdlib();
while (true) {
int hash = hash(key);
int coerceAtMost = RangesKt.coerceAtMost(this.maxProbeDistance * 2, getHashSize() / 2);
int i = 0;
while (true) {
int i2 = this.hashArray[hash];
if (i2 <= 0) {
if (this.length >= getCapacity$kotlin_stdlib()) {
ensureExtraCapacity(1);
} else {
int i3 = this.length;
int i4 = i3 + 1;
this.length = i4;
this.keysArray[i3] = key;
this.presenceArray[i3] = hash;
this.hashArray[hash] = i4;
this.size = size() + 1;
registerModification();
if (i > this.maxProbeDistance) {
this.maxProbeDistance = i;
}
return i3;
}
} else {
if (Intrinsics.areEqual(this.keysArray[i2 - 1], key)) {
return -i2;
}
i++;
if (i > coerceAtMost) {
rehash(getHashSize() * 2);
break;
}
hash = hash == 0 ? getHashSize() - 1 : hash - 1;
}
}
}
}
public final int removeKey$kotlin_stdlib(K key) {
checkIsMutable$kotlin_stdlib();
int findKey = findKey(key);
if (findKey < 0) {
return -1;
}
removeKeyAt(findKey);
return findKey;
}
/* JADX INFO: Access modifiers changed from: private */
public final void removeKeyAt(int index) {
ListBuilderKt.resetAt(this.keysArray, index);
removeHashAt(this.presenceArray[index]);
this.presenceArray[index] = -1;
this.size = size() - 1;
registerModification();
}
private final void removeHashAt(int removedHash) {
int coerceAtMost = RangesKt.coerceAtMost(this.maxProbeDistance * 2, getHashSize() / 2);
int i = 0;
int i2 = removedHash;
do {
removedHash = removedHash == 0 ? getHashSize() - 1 : removedHash - 1;
i++;
if (i > this.maxProbeDistance) {
this.hashArray[i2] = 0;
return;
}
int[] iArr = this.hashArray;
int i3 = iArr[removedHash];
if (i3 == 0) {
iArr[i2] = 0;
return;
}
if (i3 < 0) {
iArr[i2] = -1;
} else {
int i4 = i3 - 1;
if (((hash(this.keysArray[i4]) - removedHash) & (getHashSize() - 1)) >= i) {
this.hashArray[i2] = i3;
this.presenceArray[i4] = i2;
}
coerceAtMost--;
}
i2 = removedHash;
i = 0;
coerceAtMost--;
} while (coerceAtMost >= 0);
this.hashArray[i2] = -1;
}
public final boolean containsEntry$kotlin_stdlib(Map.Entry<? extends K, ? extends V> entry) {
Intrinsics.checkNotNullParameter(entry, "entry");
int findKey = findKey(entry.getKey());
if (findKey < 0) {
return false;
}
V[] vArr = this.valuesArray;
Intrinsics.checkNotNull(vArr);
return Intrinsics.areEqual(vArr[findKey], entry.getValue());
}
private final boolean contentEquals(Map<?, ?> other) {
return size() == other.size() && containsAllEntries$kotlin_stdlib(other.entrySet());
}
public final boolean containsAllEntries$kotlin_stdlib(Collection<?> m) {
Intrinsics.checkNotNullParameter(m, "m");
for (Object obj : m) {
if (obj != null) {
try {
if (!containsEntry$kotlin_stdlib((Map.Entry) obj)) {
}
} catch (ClassCastException unused) {
}
}
return false;
}
return true;
}
private final boolean putEntry(Map.Entry<? extends K, ? extends V> entry) {
int addKey$kotlin_stdlib = addKey$kotlin_stdlib(entry.getKey());
V[] allocateValuesArray = allocateValuesArray();
if (addKey$kotlin_stdlib >= 0) {
allocateValuesArray[addKey$kotlin_stdlib] = entry.getValue();
return true;
}
int i = (-addKey$kotlin_stdlib) - 1;
if (Intrinsics.areEqual(entry.getValue(), allocateValuesArray[i])) {
return false;
}
allocateValuesArray[i] = entry.getValue();
return true;
}
private final boolean putAllEntries(Collection<? extends Map.Entry<? extends K, ? extends V>> from) {
boolean z = false;
if (from.isEmpty()) {
return false;
}
ensureExtraCapacity(from.size());
Iterator<? extends Map.Entry<? extends K, ? extends V>> it = from.iterator();
while (it.hasNext()) {
if (putEntry(it.next())) {
z = true;
}
}
return z;
}
public final boolean removeEntry$kotlin_stdlib(Map.Entry<? extends K, ? extends V> entry) {
Intrinsics.checkNotNullParameter(entry, "entry");
checkIsMutable$kotlin_stdlib();
int findKey = findKey(entry.getKey());
if (findKey < 0) {
return false;
}
V[] vArr = this.valuesArray;
Intrinsics.checkNotNull(vArr);
if (!Intrinsics.areEqual(vArr[findKey], entry.getValue())) {
return false;
}
removeKeyAt(findKey);
return true;
}
public final boolean removeValue$kotlin_stdlib(V element) {
checkIsMutable$kotlin_stdlib();
int findValue = findValue(element);
if (findValue < 0) {
return false;
}
removeKeyAt(findValue);
return true;
}
public final KeysItr<K, V> keysIterator$kotlin_stdlib() {
return new KeysItr<>(this);
}
public final ValuesItr<K, V> valuesIterator$kotlin_stdlib() {
return new ValuesItr<>(this);
}
public final EntriesItr<K, V> entriesIterator$kotlin_stdlib() {
return new EntriesItr<>(this);
}
/* compiled from: MapBuilder.kt */
@Metadata(d1 = {"\u0000 \n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\u0010\u0001\n\u0002\b\u0003\n\u0002\u0010\b\n\u0002\b\b\b\u0080\u0003\u0018\u00002\u00020\u0001B\u0007\b\u0002¢\u0006\u0002\u0010\u0002J\u0010\u0010\r\u001a\u00020\t2\u0006\u0010\u000e\u001a\u00020\tH\u0002J\u0010\u0010\u000f\u001a\u00020\t2\u0006\u0010\u0010\u001a\u00020\tH\u0002R \u0010\u0003\u001a\u000e\u0012\u0004\u0012\u00020\u0005\u0012\u0004\u0012\u00020\u00050\u0004X\u0080\u0004¢\u0006\b\n\u0000\u001a\u0004\b\u0006\u0010\u0007R\u000e\u0010\b\u001a\u00020\tX\u0082T¢\u0006\u0002\n\u0000R\u000e\u0010\n\u001a\u00020\tX\u0082T¢\u0006\u0002\n\u0000R\u000e\u0010\u000b\u001a\u00020\tX\u0082T¢\u0006\u0002\n\u0000R\u000e\u0010\f\u001a\u00020\tX\u0082T¢\u0006\u0002\n\u0000¨\u0006\u0011"}, d2 = {"Lkotlin/collections/builders/MapBuilder$Companion;", "", "()V", "Empty", "Lkotlin/collections/builders/MapBuilder;", "", "getEmpty$kotlin_stdlib", "()Lkotlin/collections/builders/MapBuilder;", "INITIAL_CAPACITY", "", "INITIAL_MAX_PROBE_DISTANCE", "MAGIC", "TOMBSTONE", "computeHashSize", "capacity", "computeShift", "hashSize", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static final class Companion {
public /* synthetic */ Companion(DefaultConstructorMarker defaultConstructorMarker) {
this();
}
private Companion() {
}
public final MapBuilder getEmpty$kotlin_stdlib() {
return MapBuilder.Empty;
}
/* JADX INFO: Access modifiers changed from: private */
public final int computeHashSize(int capacity) {
return Integer.highestOneBit(RangesKt.coerceAtLeast(capacity, 1) * 3);
}
/* JADX INFO: Access modifiers changed from: private */
public final int computeShift(int hashSize) {
return Integer.numberOfLeadingZeros(hashSize) + 1;
}
}
static {
MapBuilder mapBuilder = new MapBuilder(0);
mapBuilder.isReadOnly = true;
Empty = mapBuilder;
}
/* compiled from: MapBuilder.kt */
@Metadata(d1 = {"\u0000.\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u0000\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\b\n\u0002\b\u000b\n\u0002\u0010\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0002\b\u0004\b\u0010\u0018\u0000*\u0004\b\u0002\u0010\u0001*\u0004\b\u0003\u0010\u00022\u00020\u0003B\u0019\u0012\u0012\u0010\u0004\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\u0005¢\u0006\u0002\u0010\u0006J\r\u0010\u0013\u001a\u00020\u0014H\u0000¢\u0006\u0002\b\u0015J\u0006\u0010\u0016\u001a\u00020\u0017J\r\u0010\u0018\u001a\u00020\u0014H\u0000¢\u0006\u0002\b\u0019J\u0006\u0010\u001a\u001a\u00020\u0014R\u000e\u0010\u0007\u001a\u00020\bX\u0082\u000e¢\u0006\u0002\n\u0000R\u001a\u0010\t\u001a\u00020\bX\u0080\u000e¢\u0006\u000e\n\u0000\u001a\u0004\b\n\u0010\u000b\"\u0004\b\f\u0010\rR\u001a\u0010\u000e\u001a\u00020\bX\u0080\u000e¢\u0006\u000e\n\u0000\u001a\u0004\b\u000f\u0010\u000b\"\u0004\b\u0010\u0010\rR \u0010\u0004\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\u0005X\u0080\u0004¢\u0006\b\n\u0000\u001a\u0004\b\u0011\u0010\u0012¨\u0006\u001b"}, d2 = {"Lkotlin/collections/builders/MapBuilder$Itr;", "K", ExifInterface.GPS_MEASUREMENT_INTERRUPTED, "", "map", "Lkotlin/collections/builders/MapBuilder;", "(Lkotlin/collections/builders/MapBuilder;)V", "expectedModCount", "", "index", "getIndex$kotlin_stdlib", "()I", "setIndex$kotlin_stdlib", "(I)V", "lastIndex", "getLastIndex$kotlin_stdlib", "setLastIndex$kotlin_stdlib", "getMap$kotlin_stdlib", "()Lkotlin/collections/builders/MapBuilder;", "checkForComodification", "", "checkForComodification$kotlin_stdlib", "hasNext", "", "initNext", "initNext$kotlin_stdlib", "remove", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static class Itr<K, V> {
private int expectedModCount;
private int index;
private int lastIndex;
private final MapBuilder<K, V> map;
/* renamed from: getIndex$kotlin_stdlib, reason: from getter */
public final int getIndex() {
return this.index;
}
/* renamed from: getLastIndex$kotlin_stdlib, reason: from getter */
public final int getLastIndex() {
return this.lastIndex;
}
public final MapBuilder<K, V> getMap$kotlin_stdlib() {
return this.map;
}
public final void setIndex$kotlin_stdlib(int i) {
this.index = i;
}
public final void setLastIndex$kotlin_stdlib(int i) {
this.lastIndex = i;
}
public Itr(MapBuilder<K, V> map) {
Intrinsics.checkNotNullParameter(map, "map");
this.map = map;
this.lastIndex = -1;
this.expectedModCount = ((MapBuilder) map).modCount;
initNext$kotlin_stdlib();
}
public final void initNext$kotlin_stdlib() {
while (this.index < ((MapBuilder) this.map).length) {
int[] iArr = ((MapBuilder) this.map).presenceArray;
int i = this.index;
if (iArr[i] >= 0) {
return;
} else {
this.index = i + 1;
}
}
}
public final boolean hasNext() {
return this.index < ((MapBuilder) this.map).length;
}
public final void remove() {
checkForComodification$kotlin_stdlib();
if (this.lastIndex == -1) {
throw new IllegalStateException("Call next() before removing element from the iterator.".toString());
}
this.map.checkIsMutable$kotlin_stdlib();
this.map.removeKeyAt(this.lastIndex);
this.lastIndex = -1;
this.expectedModCount = ((MapBuilder) this.map).modCount;
}
public final void checkForComodification$kotlin_stdlib() {
if (((MapBuilder) this.map).modCount != this.expectedModCount) {
throw new ConcurrentModificationException();
}
}
}
/* compiled from: MapBuilder.kt */
@Metadata(d1 = {"\u0000\u001a\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\u0010)\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0004\b\u0000\u0018\u0000*\u0004\b\u0002\u0010\u0001*\u0004\b\u0003\u0010\u00022\u000e\u0012\u0004\u0012\u0002H\u0001\u0012\u0004\u0012\u0002H\u00020\u00032\b\u0012\u0004\u0012\u0002H\u00010\u0004B\u0019\u0012\u0012\u0010\u0005\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\u0006¢\u0006\u0002\u0010\u0007J\u000e\u0010\b\u001a\u00028\u0002H\u0096\u0002¢\u0006\u0002\u0010\\u0006\n"}, d2 = {"Lkotlin/collections/builders/MapBuilder$KeysItr;", "K", ExifInterface.GPS_MEASUREMENT_INTERRUPTED, "Lkotlin/collections/builders/MapBuilder$Itr;", "", "map", "Lkotlin/collections/builders/MapBuilder;", "(Lkotlin/collections/builders/MapBuilder;)V", "next", "()Ljava/lang/Object;", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static final class KeysItr<K, V> extends Itr<K, V> implements Iterator<K>, KMutableIterator {
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public KeysItr(MapBuilder<K, V> map) {
super(map);
Intrinsics.checkNotNullParameter(map, "map");
}
@Override // java.util.Iterator
public K next() {
checkForComodification$kotlin_stdlib();
if (getIndex() >= ((MapBuilder) getMap$kotlin_stdlib()).length) {
throw new NoSuchElementException();
}
int index$kotlin_stdlib = getIndex();
setIndex$kotlin_stdlib(index$kotlin_stdlib + 1);
setLastIndex$kotlin_stdlib(index$kotlin_stdlib);
K k = (K) ((MapBuilder) getMap$kotlin_stdlib()).keysArray[getLastIndex()];
initNext$kotlin_stdlib();
return k;
}
}
/* compiled from: MapBuilder.kt */
@Metadata(d1 = {"\u0000\u001a\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\u0010)\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0004\b\u0000\u0018\u0000*\u0004\b\u0002\u0010\u0001*\u0004\b\u0003\u0010\u00022\u000e\u0012\u0004\u0012\u0002H\u0001\u0012\u0004\u0012\u0002H\u00020\u00032\b\u0012\u0004\u0012\u0002H\u00020\u0004B\u0019\u0012\u0012\u0010\u0005\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\u0006¢\u0006\u0002\u0010\u0007J\u000e\u0010\b\u001a\u00028\u0003H\u0096\u0002¢\u0006\u0002\u0010\\u0006\n"}, d2 = {"Lkotlin/collections/builders/MapBuilder$ValuesItr;", "K", ExifInterface.GPS_MEASUREMENT_INTERRUPTED, "Lkotlin/collections/builders/MapBuilder$Itr;", "", "map", "Lkotlin/collections/builders/MapBuilder;", "(Lkotlin/collections/builders/MapBuilder;)V", "next", "()Ljava/lang/Object;", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static final class ValuesItr<K, V> extends Itr<K, V> implements Iterator<V>, KMutableIterator {
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public ValuesItr(MapBuilder<K, V> map) {
super(map);
Intrinsics.checkNotNullParameter(map, "map");
}
@Override // java.util.Iterator
public V next() {
checkForComodification$kotlin_stdlib();
if (getIndex() >= ((MapBuilder) getMap$kotlin_stdlib()).length) {
throw new NoSuchElementException();
}
int index$kotlin_stdlib = getIndex();
setIndex$kotlin_stdlib(index$kotlin_stdlib + 1);
setLastIndex$kotlin_stdlib(index$kotlin_stdlib);
Object[] objArr = ((MapBuilder) getMap$kotlin_stdlib()).valuesArray;
Intrinsics.checkNotNull(objArr);
V v = (V) objArr[getLastIndex()];
initNext$kotlin_stdlib();
return v;
}
}
/* compiled from: MapBuilder.kt */
@Metadata(d1 = {"\u0000<\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\u0010)\n\u0002\u0010'\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\b\n\u0002\b\u0002\b\u0000\u0018\u0000*\u0004\b\u0002\u0010\u0001*\u0004\b\u0003\u0010\u00022\u000e\u0012\u0004\u0012\u0002H\u0001\u0012\u0004\u0012\u0002H\u00020\u00032\u0014\u0012\u0010\u0012\u000e\u0012\u0004\u0012\u0002H\u0001\u0012\u0004\u0012\u0002H\u00020\u00050\u0004B\u0019\u0012\u0012\u0010\u0006\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\u0007¢\u0006\u0002\u0010\bJ\u0015\u0010\t\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\nH\u0096\u0002J\u0012\u0010\u000b\u001a\u00020\f2\n\u0010\r\u001a\u00060\u000ej\u0002`\u000fJ\r\u0010\u0010\u001a\u00020\u0011H\u0000¢\u0006\u0002\b\u0012¨\u0006\u0013"}, d2 = {"Lkotlin/collections/builders/MapBuilder$EntriesItr;", "K", ExifInterface.GPS_MEASUREMENT_INTERRUPTED, "Lkotlin/collections/builders/MapBuilder$Itr;", "", "", "map", "Lkotlin/collections/builders/MapBuilder;", "(Lkotlin/collections/builders/MapBuilder;)V", "next", "Lkotlin/collections/builders/MapBuilder$EntryRef;", "nextAppendString", "", "sb", "Ljava/lang/StringBuilder;", "Lkotlin/text/StringBuilder;", "nextHashCode", "", "nextHashCode$kotlin_stdlib", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static final class EntriesItr<K, V> extends Itr<K, V> implements Iterator<Map.Entry<K, V>>, KMutableIterator {
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public EntriesItr(MapBuilder<K, V> map) {
super(map);
Intrinsics.checkNotNullParameter(map, "map");
}
@Override // java.util.Iterator
public EntryRef<K, V> next() {
checkForComodification$kotlin_stdlib();
if (getIndex() >= ((MapBuilder) getMap$kotlin_stdlib()).length) {
throw new NoSuchElementException();
}
int index$kotlin_stdlib = getIndex();
setIndex$kotlin_stdlib(index$kotlin_stdlib + 1);
setLastIndex$kotlin_stdlib(index$kotlin_stdlib);
EntryRef<K, V> entryRef = new EntryRef<>(getMap$kotlin_stdlib(), getLastIndex());
initNext$kotlin_stdlib();
return entryRef;
}
public final int nextHashCode$kotlin_stdlib() {
if (getIndex() >= ((MapBuilder) getMap$kotlin_stdlib()).length) {
throw new NoSuchElementException();
}
int index$kotlin_stdlib = getIndex();
setIndex$kotlin_stdlib(index$kotlin_stdlib + 1);
setLastIndex$kotlin_stdlib(index$kotlin_stdlib);
Object obj = ((MapBuilder) getMap$kotlin_stdlib()).keysArray[getLastIndex()];
int hashCode = obj != null ? obj.hashCode() : 0;
Object[] objArr = ((MapBuilder) getMap$kotlin_stdlib()).valuesArray;
Intrinsics.checkNotNull(objArr);
Object obj2 = objArr[getLastIndex()];
int hashCode2 = hashCode ^ (obj2 != null ? obj2.hashCode() : 0);
initNext$kotlin_stdlib();
return hashCode2;
}
public final void nextAppendString(StringBuilder sb) {
Intrinsics.checkNotNullParameter(sb, "sb");
if (getIndex() >= ((MapBuilder) getMap$kotlin_stdlib()).length) {
throw new NoSuchElementException();
}
int index$kotlin_stdlib = getIndex();
setIndex$kotlin_stdlib(index$kotlin_stdlib + 1);
setLastIndex$kotlin_stdlib(index$kotlin_stdlib);
Object obj = ((MapBuilder) getMap$kotlin_stdlib()).keysArray[getLastIndex()];
if (obj == getMap$kotlin_stdlib()) {
sb.append("(this Map)");
} else {
sb.append(obj);
}
sb.append('=');
Object[] objArr = ((MapBuilder) getMap$kotlin_stdlib()).valuesArray;
Intrinsics.checkNotNull(objArr);
Object obj2 = objArr[getLastIndex()];
if (obj2 == getMap$kotlin_stdlib()) {
sb.append("(this Map)");
} else {
sb.append(obj2);
}
initNext$kotlin_stdlib();
}
}
/* compiled from: MapBuilder.kt */
@Metadata(d1 = {"\u00000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010'\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\b\n\u0002\b\u0007\n\u0002\u0010\u000b\n\u0000\n\u0002\u0010\u0000\n\u0002\b\u0005\n\u0002\u0010\u000e\n\u0000\b\u0000\u0018\u0000*\u0004\b\u0002\u0010\u0001*\u0004\b\u0003\u0010\u00022\u000e\u0012\u0004\u0012\u0002H\u0001\u0012\u0004\u0012\u0002H\u00020\u0003B!\u0012\u0012\u0010\u0004\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\u0005\u0012\u0006\u0010\u0006\u001a\u00020\u0007¢\u0006\u0002\u0010\bJ\u0013\u0010\u000e\u001a\u00020\u000f2\b\u0010\u0010\u001a\u0004\u0018\u00010\u0011H\u0096\u0002J\b\u0010\u0012\u001a\u00020\u0007H\u0016J\u0015\u0010\u0013\u001a\u00028\u00032\u0006\u0010\u0014\u001a\u00028\u0003H\u0016¢\u0006\u0002\u0010\u0015J\b\u0010\u0016\u001a\u00020\u0017H\u0016R\u000e\u0010\u0006\u001a\u00020\u0007X\u0082\u0004¢\u0006\u0002\n\u0000R\u0014\u0010\t\u001a\u00028\u00028VX\u0096\u0004¢\u0006\u0006\u001a\u0004\b\n\u0010\u000bR\u001a\u0010\u0004\u001a\u000e\u0012\u0004\u0012\u00028\u0002\u0012\u0004\u0012\u00028\u00030\u0005X\u0082\u0004¢\u0006\u0002\n\u0000R\u0014\u0010\f\u001a\u00028\u00038VX\u0096\u0004¢\u0006\u0006\u001a\u0004\b\r\u0010\u000b¨\u0006\u0018"}, d2 = {"Lkotlin/collections/builders/MapBuilder$EntryRef;", "K", ExifInterface.GPS_MEASUREMENT_INTERRUPTED, "", "map", "Lkotlin/collections/builders/MapBuilder;", "index", "", "(Lkotlin/collections/builders/MapBuilder;I)V", "key", "getKey", "()Ljava/lang/Object;", "value", "getValue", "equals", "", "other", "", "hashCode", "setValue", "newValue", "(Ljava/lang/Object;)Ljava/lang/Object;", "toString", "", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static final class EntryRef<K, V> implements Map.Entry<K, V>, KMutableMap.Entry {
private final int index;
private final MapBuilder<K, V> map;
public EntryRef(MapBuilder<K, V> map, int i) {
Intrinsics.checkNotNullParameter(map, "map");
this.map = map;
this.index = i;
}
@Override // java.util.Map.Entry
public K getKey() {
return (K) ((MapBuilder) this.map).keysArray[this.index];
}
@Override // java.util.Map.Entry
public V getValue() {
Object[] objArr = ((MapBuilder) this.map).valuesArray;
Intrinsics.checkNotNull(objArr);
return (V) objArr[this.index];
}
@Override // java.util.Map.Entry
public V setValue(V newValue) {
this.map.checkIsMutable$kotlin_stdlib();
Object[] allocateValuesArray = this.map.allocateValuesArray();
int i = this.index;
V v = (V) allocateValuesArray[i];
allocateValuesArray[i] = newValue;
return v;
}
@Override // java.util.Map.Entry
public boolean equals(Object other) {
if (other instanceof Map.Entry) {
Map.Entry entry = (Map.Entry) other;
if (Intrinsics.areEqual(entry.getKey(), getKey()) && Intrinsics.areEqual(entry.getValue(), getValue())) {
return true;
}
}
return false;
}
@Override // java.util.Map.Entry
public int hashCode() {
K key = getKey();
int hashCode = key != null ? key.hashCode() : 0;
V value = getValue();
return hashCode ^ (value != null ? value.hashCode() : 0);
}
public String toString() {
return new StringBuilder().append(getKey()).append('=').append(getValue()).toString();
}
}
}