mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
349 lines
13 KiB
Java
349 lines
13 KiB
Java
package com.google.common.hash;
|
|
|
|
import com.google.common.base.Charsets;
|
|
import com.google.common.base.Preconditions;
|
|
import com.google.common.primitives.Ints;
|
|
import com.google.common.primitives.UnsignedBytes;
|
|
import com.google.errorprone.annotations.Immutable;
|
|
import io.flutter.embedding.android.KeyboardMap;
|
|
import java.io.Serializable;
|
|
import java.nio.ByteBuffer;
|
|
import java.nio.ByteOrder;
|
|
import java.nio.charset.Charset;
|
|
import javax.annotation.CheckForNull;
|
|
|
|
/* JADX INFO: Access modifiers changed from: package-private */
|
|
@Immutable
|
|
@ElementTypesAreNonnullByDefault
|
|
/* loaded from: classes3.dex */
|
|
public final class Murmur3_32HashFunction extends AbstractHashFunction implements Serializable {
|
|
private static final int C1 = -862048943;
|
|
private static final int C2 = 461845907;
|
|
private static final int CHUNK_SIZE = 4;
|
|
private static final long serialVersionUID = 0;
|
|
private final int seed;
|
|
private final boolean supplementaryPlaneFix;
|
|
static final HashFunction MURMUR3_32 = new Murmur3_32HashFunction(0, false);
|
|
static final HashFunction MURMUR3_32_FIXED = new Murmur3_32HashFunction(0, true);
|
|
static final HashFunction GOOD_FAST_HASH_32 = new Murmur3_32HashFunction(Hashing.GOOD_FAST_HASH_SEED, true);
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static long charToThreeUtf8Bytes(char c) {
|
|
return (c >>> '\f') | 224 | ((((c >>> 6) & 63) | 128) << 8) | (((c & '?') | 128) << 16);
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static long charToTwoUtf8Bytes(char c) {
|
|
return (c >>> 6) | 192 | (((c & '?') | 128) << 8);
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static long codePointToFourUtf8Bytes(int i) {
|
|
return (i >>> 18) | 240 | ((((i >>> 12) & 63) | 128) << 8) | ((((i >>> 6) & 63) | 128) << 16) | (((i & 63) | 128) << 24);
|
|
}
|
|
|
|
@Override // com.google.common.hash.HashFunction
|
|
public int bits() {
|
|
return 32;
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: package-private */
|
|
public Murmur3_32HashFunction(int i, boolean z) {
|
|
this.seed = i;
|
|
this.supplementaryPlaneFix = z;
|
|
}
|
|
|
|
@Override // com.google.common.hash.HashFunction
|
|
public Hasher newHasher() {
|
|
return new Murmur3_32Hasher(this.seed);
|
|
}
|
|
|
|
public String toString() {
|
|
return new StringBuilder(31).append("Hashing.murmur3_32(").append(this.seed).append(")").toString();
|
|
}
|
|
|
|
public boolean equals(@CheckForNull Object obj) {
|
|
if (!(obj instanceof Murmur3_32HashFunction)) {
|
|
return false;
|
|
}
|
|
Murmur3_32HashFunction murmur3_32HashFunction = (Murmur3_32HashFunction) obj;
|
|
return this.seed == murmur3_32HashFunction.seed && this.supplementaryPlaneFix == murmur3_32HashFunction.supplementaryPlaneFix;
|
|
}
|
|
|
|
public int hashCode() {
|
|
return this.seed ^ getClass().hashCode();
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHashFunction, com.google.common.hash.HashFunction
|
|
public HashCode hashInt(int i) {
|
|
return fmix(mixH1(this.seed, mixK1(i)), 4);
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHashFunction, com.google.common.hash.HashFunction
|
|
public HashCode hashLong(long j) {
|
|
return fmix(mixH1(mixH1(this.seed, mixK1((int) j)), mixK1((int) (j >>> 32))), 8);
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHashFunction, com.google.common.hash.HashFunction
|
|
public HashCode hashUnencodedChars(CharSequence charSequence) {
|
|
int i = this.seed;
|
|
for (int i2 = 1; i2 < charSequence.length(); i2 += 2) {
|
|
i = mixH1(i, mixK1(charSequence.charAt(i2 - 1) | (charSequence.charAt(i2) << 16)));
|
|
}
|
|
if ((charSequence.length() & 1) == 1) {
|
|
i ^= mixK1(charSequence.charAt(charSequence.length() - 1));
|
|
}
|
|
return fmix(i, charSequence.length() * 2);
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHashFunction, com.google.common.hash.HashFunction
|
|
public HashCode hashString(CharSequence charSequence, Charset charset) {
|
|
if (Charsets.UTF_8.equals(charset)) {
|
|
int length = charSequence.length();
|
|
int i = this.seed;
|
|
int i2 = 0;
|
|
int i3 = 0;
|
|
int i4 = 0;
|
|
while (true) {
|
|
int i5 = i3 + 4;
|
|
if (i5 > length) {
|
|
break;
|
|
}
|
|
char charAt = charSequence.charAt(i3);
|
|
char charAt2 = charSequence.charAt(i3 + 1);
|
|
char charAt3 = charSequence.charAt(i3 + 2);
|
|
char charAt4 = charSequence.charAt(i3 + 3);
|
|
if (charAt >= 128 || charAt2 >= 128 || charAt3 >= 128 || charAt4 >= 128) {
|
|
break;
|
|
}
|
|
i = mixH1(i, mixK1((charAt2 << '\b') | charAt | (charAt3 << 16) | (charAt4 << 24)));
|
|
i4 += 4;
|
|
i3 = i5;
|
|
}
|
|
long j = 0;
|
|
while (i3 < length) {
|
|
char charAt5 = charSequence.charAt(i3);
|
|
if (charAt5 < 128) {
|
|
j |= charAt5 << i2;
|
|
i2 += 8;
|
|
i4++;
|
|
} else if (charAt5 < 2048) {
|
|
j |= charToTwoUtf8Bytes(charAt5) << i2;
|
|
i2 += 16;
|
|
i4 += 2;
|
|
} else if (charAt5 < 55296 || charAt5 > 57343) {
|
|
j |= charToThreeUtf8Bytes(charAt5) << i2;
|
|
i2 += 24;
|
|
i4 += 3;
|
|
} else {
|
|
int codePointAt = Character.codePointAt(charSequence, i3);
|
|
if (codePointAt == charAt5) {
|
|
return hashBytes(charSequence.toString().getBytes(charset));
|
|
}
|
|
i3++;
|
|
j |= codePointToFourUtf8Bytes(codePointAt) << i2;
|
|
if (this.supplementaryPlaneFix) {
|
|
i2 += 32;
|
|
}
|
|
i4 += 4;
|
|
}
|
|
if (i2 >= 32) {
|
|
i = mixH1(i, mixK1((int) j));
|
|
j >>>= 32;
|
|
i2 -= 32;
|
|
}
|
|
i3++;
|
|
}
|
|
return fmix(mixK1((int) j) ^ i, i4);
|
|
}
|
|
return hashBytes(charSequence.toString().getBytes(charset));
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHashFunction, com.google.common.hash.HashFunction
|
|
public HashCode hashBytes(byte[] bArr, int i, int i2) {
|
|
Preconditions.checkPositionIndexes(i, i + i2, bArr.length);
|
|
int i3 = this.seed;
|
|
int i4 = 0;
|
|
int i5 = 0;
|
|
while (true) {
|
|
int i6 = i5 + 4;
|
|
if (i6 > i2) {
|
|
break;
|
|
}
|
|
i3 = mixH1(i3, mixK1(getIntLittleEndian(bArr, i5 + i)));
|
|
i5 = i6;
|
|
}
|
|
int i7 = i5;
|
|
int i8 = 0;
|
|
while (i7 < i2) {
|
|
i4 ^= UnsignedBytes.toInt(bArr[i + i7]) << i8;
|
|
i7++;
|
|
i8 += 8;
|
|
}
|
|
return fmix(i3 ^ mixK1(i4), i2);
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static int getIntLittleEndian(byte[] bArr, int i) {
|
|
return Ints.fromBytes(bArr[i + 3], bArr[i + 2], bArr[i + 1], bArr[i]);
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static int mixK1(int i) {
|
|
return Integer.rotateLeft(i * C1, 15) * C2;
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static int mixH1(int i, int i2) {
|
|
return (Integer.rotateLeft(i ^ i2, 13) * 5) - 430675100;
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
public static HashCode fmix(int i, int i2) {
|
|
int i3 = i ^ i2;
|
|
int i4 = (i3 ^ (i3 >>> 16)) * (-2048144789);
|
|
int i5 = (i4 ^ (i4 >>> 13)) * (-1028477387);
|
|
return HashCode.fromInt(i5 ^ (i5 >>> 16));
|
|
}
|
|
|
|
/* loaded from: classes3.dex */
|
|
private static final class Murmur3_32Hasher extends AbstractHasher {
|
|
private long buffer;
|
|
private int h1;
|
|
private int shift;
|
|
private int length = 0;
|
|
private boolean isDone = false;
|
|
|
|
Murmur3_32Hasher(int i) {
|
|
this.h1 = i;
|
|
}
|
|
|
|
private void update(int i, long j) {
|
|
long j2 = this.buffer;
|
|
long j3 = j & KeyboardMap.kValueMask;
|
|
int i2 = this.shift;
|
|
long j4 = (j3 << i2) | j2;
|
|
this.buffer = j4;
|
|
int i3 = i2 + (i * 8);
|
|
this.shift = i3;
|
|
this.length += i;
|
|
if (i3 >= 32) {
|
|
this.h1 = Murmur3_32HashFunction.mixH1(this.h1, Murmur3_32HashFunction.mixK1((int) j4));
|
|
this.buffer >>>= 32;
|
|
this.shift -= 32;
|
|
}
|
|
}
|
|
|
|
@Override // com.google.common.hash.Hasher, com.google.common.hash.PrimitiveSink
|
|
public Hasher putByte(byte b) {
|
|
update(1, b & 255);
|
|
return this;
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHasher, com.google.common.hash.Hasher, com.google.common.hash.PrimitiveSink
|
|
public Hasher putBytes(byte[] bArr, int i, int i2) {
|
|
Preconditions.checkPositionIndexes(i, i + i2, bArr.length);
|
|
int i3 = 0;
|
|
while (true) {
|
|
int i4 = i3 + 4;
|
|
if (i4 > i2) {
|
|
break;
|
|
}
|
|
update(4, Murmur3_32HashFunction.getIntLittleEndian(bArr, i3 + i));
|
|
i3 = i4;
|
|
}
|
|
while (i3 < i2) {
|
|
putByte(bArr[i + i3]);
|
|
i3++;
|
|
}
|
|
return this;
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHasher, com.google.common.hash.Hasher, com.google.common.hash.PrimitiveSink
|
|
public Hasher putBytes(ByteBuffer byteBuffer) {
|
|
ByteOrder order = byteBuffer.order();
|
|
byteBuffer.order(ByteOrder.LITTLE_ENDIAN);
|
|
while (byteBuffer.remaining() >= 4) {
|
|
putInt(byteBuffer.getInt());
|
|
}
|
|
while (byteBuffer.hasRemaining()) {
|
|
putByte(byteBuffer.get());
|
|
}
|
|
byteBuffer.order(order);
|
|
return this;
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHasher, com.google.common.hash.Hasher, com.google.common.hash.PrimitiveSink
|
|
public Hasher putInt(int i) {
|
|
update(4, i);
|
|
return this;
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHasher, com.google.common.hash.Hasher, com.google.common.hash.PrimitiveSink
|
|
public Hasher putLong(long j) {
|
|
update(4, (int) j);
|
|
update(4, j >>> 32);
|
|
return this;
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHasher, com.google.common.hash.Hasher, com.google.common.hash.PrimitiveSink
|
|
public Hasher putChar(char c) {
|
|
update(2, c);
|
|
return this;
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractHasher, com.google.common.hash.Hasher, com.google.common.hash.PrimitiveSink
|
|
public Hasher putString(CharSequence charSequence, Charset charset) {
|
|
if (Charsets.UTF_8.equals(charset)) {
|
|
int length = charSequence.length();
|
|
int i = 0;
|
|
while (true) {
|
|
int i2 = i + 4;
|
|
if (i2 > length) {
|
|
break;
|
|
}
|
|
char charAt = charSequence.charAt(i);
|
|
char charAt2 = charSequence.charAt(i + 1);
|
|
char charAt3 = charSequence.charAt(i + 2);
|
|
char charAt4 = charSequence.charAt(i + 3);
|
|
if (charAt >= 128 || charAt2 >= 128 || charAt3 >= 128 || charAt4 >= 128) {
|
|
break;
|
|
}
|
|
update(4, (charAt2 << '\b') | charAt | (charAt3 << 16) | (charAt4 << 24));
|
|
i = i2;
|
|
}
|
|
while (i < length) {
|
|
char charAt5 = charSequence.charAt(i);
|
|
if (charAt5 < 128) {
|
|
update(1, charAt5);
|
|
} else if (charAt5 < 2048) {
|
|
update(2, Murmur3_32HashFunction.charToTwoUtf8Bytes(charAt5));
|
|
} else if (charAt5 < 55296 || charAt5 > 57343) {
|
|
update(3, Murmur3_32HashFunction.charToThreeUtf8Bytes(charAt5));
|
|
} else {
|
|
int codePointAt = Character.codePointAt(charSequence, i);
|
|
if (codePointAt != charAt5) {
|
|
i++;
|
|
update(4, Murmur3_32HashFunction.codePointToFourUtf8Bytes(codePointAt));
|
|
} else {
|
|
putBytes(charSequence.subSequence(i, length).toString().getBytes(charset));
|
|
return this;
|
|
}
|
|
}
|
|
i++;
|
|
}
|
|
return this;
|
|
}
|
|
return super.putString(charSequence, charset);
|
|
}
|
|
|
|
@Override // com.google.common.hash.Hasher
|
|
public HashCode hash() {
|
|
Preconditions.checkState(!this.isDone);
|
|
this.isDone = true;
|
|
int mixK1 = this.h1 ^ Murmur3_32HashFunction.mixK1((int) this.buffer);
|
|
this.h1 = mixK1;
|
|
return Murmur3_32HashFunction.fmix(mixK1, this.length);
|
|
}
|
|
}
|
|
}
|