Rabbit-R1/switch port/java/sources/com/google/common/collect/RegularImmutableMap.java
2024-05-21 17:08:36 -04:00

437 lines
18 KiB
Java

package com.google.common.collect;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableMap;
import java.util.AbstractMap;
import java.util.Arrays;
import java.util.Map;
import java.util.Objects;
import javax.annotation.CheckForNull;
import kotlin.UShort;
/* JADX INFO: Access modifiers changed from: package-private */
@ElementTypesAreNonnullByDefault
/* loaded from: classes3.dex */
public final class RegularImmutableMap<K, V> extends ImmutableMap<K, V> {
private static final byte ABSENT = -1;
private static final int BYTE_MASK = 255;
private static final int BYTE_MAX_SIZE = 128;
static final ImmutableMap<Object, Object> EMPTY = new RegularImmutableMap(null, new Object[0], 0);
private static final int SHORT_MASK = 65535;
private static final int SHORT_MAX_SIZE = 32768;
private static final long serialVersionUID = 0;
final transient Object[] alternatingKeysAndValues;
@CheckForNull
private final transient Object hashTable;
private final transient int size;
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.collect.ImmutableMap
public boolean isPartialView() {
return false;
}
@Override // java.util.Map
public int size() {
return this.size;
}
/* JADX INFO: Access modifiers changed from: package-private */
public static <K, V> RegularImmutableMap<K, V> create(int i, Object[] objArr) {
return create(i, objArr, null);
}
/* JADX INFO: Access modifiers changed from: package-private */
public static <K, V> RegularImmutableMap<K, V> create(int i, Object[] objArr, ImmutableMap.Builder<K, V> builder) {
if (i == 0) {
return (RegularImmutableMap) EMPTY;
}
if (i == 1) {
CollectPreconditions.checkEntryNotNull(Objects.requireNonNull(objArr[0]), Objects.requireNonNull(objArr[1]));
return new RegularImmutableMap<>(null, objArr, 1);
}
Preconditions.checkPositionIndex(i, objArr.length >> 1);
Object createHashTable = createHashTable(objArr, i, ImmutableSet.chooseTableSize(i), 0);
if (createHashTable instanceof Object[]) {
Object[] objArr2 = (Object[]) createHashTable;
ImmutableMap.Builder.DuplicateKey duplicateKey = (ImmutableMap.Builder.DuplicateKey) objArr2[2];
if (builder == null) {
throw duplicateKey.exception();
}
builder.duplicateKey = duplicateKey;
Object obj = objArr2[0];
int intValue = ((Integer) objArr2[1]).intValue();
objArr = Arrays.copyOf(objArr, intValue * 2);
createHashTable = obj;
i = intValue;
}
return new RegularImmutableMap<>(createHashTable, objArr, i);
}
@CheckForNull
private static Object createHashTable(Object[] objArr, int i, int i2, int i3) {
ImmutableMap.Builder.DuplicateKey duplicateKey = null;
if (i == 1) {
CollectPreconditions.checkEntryNotNull(Objects.requireNonNull(objArr[i3]), Objects.requireNonNull(objArr[i3 ^ 1]));
return null;
}
int i4 = i2 - 1;
int i5 = 0;
if (i2 <= 128) {
byte[] bArr = new byte[i2];
Arrays.fill(bArr, (byte) -1);
int i6 = 0;
while (i5 < i) {
int i7 = (i5 * 2) + i3;
int i8 = (i6 * 2) + i3;
Object requireNonNull = Objects.requireNonNull(objArr[i7]);
Object requireNonNull2 = Objects.requireNonNull(objArr[i7 ^ 1]);
CollectPreconditions.checkEntryNotNull(requireNonNull, requireNonNull2);
int smear = Hashing.smear(requireNonNull.hashCode());
while (true) {
int i9 = smear & i4;
int i10 = bArr[i9] & 255;
if (i10 == 255) {
bArr[i9] = (byte) i8;
if (i6 < i5) {
objArr[i8] = requireNonNull;
objArr[i8 ^ 1] = requireNonNull2;
}
i6++;
} else {
if (requireNonNull.equals(objArr[i10])) {
int i11 = i10 ^ 1;
duplicateKey = new ImmutableMap.Builder.DuplicateKey(requireNonNull, requireNonNull2, Objects.requireNonNull(objArr[i11]));
objArr[i11] = requireNonNull2;
break;
}
smear = i9 + 1;
}
}
i5++;
}
return i6 == i ? bArr : new Object[]{bArr, Integer.valueOf(i6), duplicateKey};
}
if (i2 <= 32768) {
short[] sArr = new short[i2];
Arrays.fill(sArr, (short) -1);
int i12 = 0;
while (i5 < i) {
int i13 = (i5 * 2) + i3;
int i14 = (i12 * 2) + i3;
Object requireNonNull3 = Objects.requireNonNull(objArr[i13]);
Object requireNonNull4 = Objects.requireNonNull(objArr[i13 ^ 1]);
CollectPreconditions.checkEntryNotNull(requireNonNull3, requireNonNull4);
int smear2 = Hashing.smear(requireNonNull3.hashCode());
while (true) {
int i15 = smear2 & i4;
int i16 = sArr[i15] & UShort.MAX_VALUE;
if (i16 == 65535) {
sArr[i15] = (short) i14;
if (i12 < i5) {
objArr[i14] = requireNonNull3;
objArr[i14 ^ 1] = requireNonNull4;
}
i12++;
} else {
if (requireNonNull3.equals(objArr[i16])) {
int i17 = i16 ^ 1;
duplicateKey = new ImmutableMap.Builder.DuplicateKey(requireNonNull3, requireNonNull4, Objects.requireNonNull(objArr[i17]));
objArr[i17] = requireNonNull4;
break;
}
smear2 = i15 + 1;
}
}
i5++;
}
return i12 == i ? sArr : new Object[]{sArr, Integer.valueOf(i12), duplicateKey};
}
int[] iArr = new int[i2];
Arrays.fill(iArr, -1);
int i18 = 0;
while (i5 < i) {
int i19 = (i5 * 2) + i3;
int i20 = (i18 * 2) + i3;
Object requireNonNull5 = Objects.requireNonNull(objArr[i19]);
Object requireNonNull6 = Objects.requireNonNull(objArr[i19 ^ 1]);
CollectPreconditions.checkEntryNotNull(requireNonNull5, requireNonNull6);
int smear3 = Hashing.smear(requireNonNull5.hashCode());
while (true) {
int i21 = smear3 & i4;
int i22 = iArr[i21];
if (i22 == -1) {
iArr[i21] = i20;
if (i18 < i5) {
objArr[i20] = requireNonNull5;
objArr[i20 ^ 1] = requireNonNull6;
}
i18++;
} else {
if (requireNonNull5.equals(objArr[i22])) {
int i23 = i22 ^ 1;
duplicateKey = new ImmutableMap.Builder.DuplicateKey(requireNonNull5, requireNonNull6, Objects.requireNonNull(objArr[i23]));
objArr[i23] = requireNonNull6;
break;
}
smear3 = i21 + 1;
}
}
i5++;
}
return i18 == i ? iArr : new Object[]{iArr, Integer.valueOf(i18), duplicateKey};
}
/* JADX INFO: Access modifiers changed from: package-private */
@CheckForNull
public static Object createHashTableOrThrow(Object[] objArr, int i, int i2, int i3) {
Object createHashTable = createHashTable(objArr, i, i2, i3);
if (createHashTable instanceof Object[]) {
throw ((ImmutableMap.Builder.DuplicateKey) ((Object[]) createHashTable)[2]).exception();
}
return createHashTable;
}
private RegularImmutableMap(@CheckForNull Object obj, Object[] objArr, int i) {
this.hashTable = obj;
this.alternatingKeysAndValues = objArr;
this.size = i;
}
@Override // com.google.common.collect.ImmutableMap, java.util.Map
@CheckForNull
public V get(@CheckForNull Object obj) {
V v = (V) get(this.hashTable, this.alternatingKeysAndValues, this.size, 0, obj);
if (v == null) {
return null;
}
return v;
}
/* JADX INFO: Access modifiers changed from: package-private */
@CheckForNull
public static Object get(@CheckForNull Object obj, Object[] objArr, int i, int i2, @CheckForNull Object obj2) {
if (obj2 == null) {
return null;
}
if (i == 1) {
if (Objects.requireNonNull(objArr[i2]).equals(obj2)) {
return Objects.requireNonNull(objArr[i2 ^ 1]);
}
return null;
}
if (obj == null) {
return null;
}
if (obj instanceof byte[]) {
byte[] bArr = (byte[]) obj;
int length = bArr.length - 1;
int smear = Hashing.smear(obj2.hashCode());
while (true) {
int i3 = smear & length;
int i4 = bArr[i3] & 255;
if (i4 == 255) {
return null;
}
if (obj2.equals(objArr[i4])) {
return objArr[i4 ^ 1];
}
smear = i3 + 1;
}
} else if (obj instanceof short[]) {
short[] sArr = (short[]) obj;
int length2 = sArr.length - 1;
int smear2 = Hashing.smear(obj2.hashCode());
while (true) {
int i5 = smear2 & length2;
int i6 = sArr[i5] & UShort.MAX_VALUE;
if (i6 == 65535) {
return null;
}
if (obj2.equals(objArr[i6])) {
return objArr[i6 ^ 1];
}
smear2 = i5 + 1;
}
} else {
int[] iArr = (int[]) obj;
int length3 = iArr.length - 1;
int smear3 = Hashing.smear(obj2.hashCode());
while (true) {
int i7 = smear3 & length3;
int i8 = iArr[i7];
if (i8 == -1) {
return null;
}
if (obj2.equals(objArr[i8])) {
return objArr[i8 ^ 1];
}
smear3 = i7 + 1;
}
}
}
@Override // com.google.common.collect.ImmutableMap
ImmutableSet<Map.Entry<K, V>> createEntrySet() {
return new EntrySet(this, this.alternatingKeysAndValues, 0, this.size);
}
/* JADX INFO: Access modifiers changed from: package-private */
/* loaded from: classes3.dex */
public static class EntrySet<K, V> extends ImmutableSet<Map.Entry<K, V>> {
private final transient Object[] alternatingKeysAndValues;
private final transient int keyOffset;
private final transient ImmutableMap<K, V> map;
private final transient int size;
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.collect.ImmutableCollection
public boolean isPartialView() {
return true;
}
@Override // java.util.AbstractCollection, java.util.Collection, java.util.Set
public int size() {
return this.size;
}
/* JADX INFO: Access modifiers changed from: package-private */
public EntrySet(ImmutableMap<K, V> immutableMap, Object[] objArr, int i, int i2) {
this.map = immutableMap;
this.alternatingKeysAndValues = objArr;
this.keyOffset = i;
this.size = i2;
}
@Override // com.google.common.collect.ImmutableSet, com.google.common.collect.ImmutableCollection, java.util.AbstractCollection, java.util.Collection, java.lang.Iterable, java.util.Set, java.util.NavigableSet, com.google.common.collect.SortedIterable
public UnmodifiableIterator<Map.Entry<K, V>> iterator() {
return asList().iterator();
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.collect.ImmutableCollection
public int copyIntoArray(Object[] objArr, int i) {
return asList().copyIntoArray(objArr, i);
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.collect.ImmutableSet
public ImmutableList<Map.Entry<K, V>> createAsList() {
return new ImmutableList<Map.Entry<K, V>>() { // from class: com.google.common.collect.RegularImmutableMap.EntrySet.1
@Override // com.google.common.collect.ImmutableCollection
public boolean isPartialView() {
return true;
}
@Override // java.util.List
public Map.Entry<K, V> get(int i) {
Preconditions.checkElementIndex(i, EntrySet.this.size);
int i2 = i * 2;
return new AbstractMap.SimpleImmutableEntry(Objects.requireNonNull(EntrySet.this.alternatingKeysAndValues[EntrySet.this.keyOffset + i2]), Objects.requireNonNull(EntrySet.this.alternatingKeysAndValues[i2 + (EntrySet.this.keyOffset ^ 1)]));
}
@Override // java.util.AbstractCollection, java.util.Collection, java.util.List
public int size() {
return EntrySet.this.size;
}
};
}
@Override // com.google.common.collect.ImmutableCollection, java.util.AbstractCollection, java.util.Collection, java.util.Set
public boolean contains(@CheckForNull Object obj) {
if (!(obj instanceof Map.Entry)) {
return false;
}
Map.Entry entry = (Map.Entry) obj;
Object key = entry.getKey();
Object value = entry.getValue();
return value != null && value.equals(this.map.get(key));
}
}
@Override // com.google.common.collect.ImmutableMap
ImmutableSet<K> createKeySet() {
return new KeySet(this, new KeysOrValuesAsList(this.alternatingKeysAndValues, 0, this.size));
}
/* loaded from: classes3.dex */
static final class KeysOrValuesAsList extends ImmutableList<Object> {
private final transient Object[] alternatingKeysAndValues;
private final transient int offset;
private final transient int size;
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.collect.ImmutableCollection
public boolean isPartialView() {
return true;
}
@Override // java.util.AbstractCollection, java.util.Collection, java.util.List
public int size() {
return this.size;
}
/* JADX INFO: Access modifiers changed from: package-private */
public KeysOrValuesAsList(Object[] objArr, int i, int i2) {
this.alternatingKeysAndValues = objArr;
this.offset = i;
this.size = i2;
}
@Override // java.util.List
public Object get(int i) {
Preconditions.checkElementIndex(i, this.size);
return Objects.requireNonNull(this.alternatingKeysAndValues[(i * 2) + this.offset]);
}
}
/* loaded from: classes3.dex */
static final class KeySet<K> extends ImmutableSet<K> {
private final transient ImmutableList<K> list;
private final transient ImmutableMap<K, ?> map;
@Override // com.google.common.collect.ImmutableSet, com.google.common.collect.ImmutableCollection
public ImmutableList<K> asList() {
return this.list;
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.collect.ImmutableCollection
public boolean isPartialView() {
return true;
}
/* JADX INFO: Access modifiers changed from: package-private */
public KeySet(ImmutableMap<K, ?> immutableMap, ImmutableList<K> immutableList) {
this.map = immutableMap;
this.list = immutableList;
}
@Override // com.google.common.collect.ImmutableSet, com.google.common.collect.ImmutableCollection, java.util.AbstractCollection, java.util.Collection, java.lang.Iterable, java.util.Set, java.util.NavigableSet, com.google.common.collect.SortedIterable
public UnmodifiableIterator<K> iterator() {
return asList().iterator();
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.collect.ImmutableCollection
public int copyIntoArray(Object[] objArr, int i) {
return asList().copyIntoArray(objArr, i);
}
@Override // com.google.common.collect.ImmutableCollection, java.util.AbstractCollection, java.util.Collection, java.util.Set
public boolean contains(@CheckForNull Object obj) {
return this.map.get(obj) != null;
}
@Override // java.util.AbstractCollection, java.util.Collection, java.util.Set
public int size() {
return this.map.size();
}
}
@Override // com.google.common.collect.ImmutableMap
ImmutableCollection<V> createValues() {
return new KeysOrValuesAsList(this.alternatingKeysAndValues, 1, this.size);
}
}