Rabbit-R1/android (non root)/java/sources/com/google/common/hash/Murmur3_32HashFunction.java
2024-05-21 17:08:36 -04:00

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);
}
}
}