mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
262 lines
11 KiB
Java
262 lines
11 KiB
Java
|
package com.google.common.hash;
|
||
|
|
||
|
import com.google.common.primitives.UnsignedBytes;
|
||
|
import com.google.errorprone.annotations.Immutable;
|
||
|
import java.io.Serializable;
|
||
|
import java.nio.ByteBuffer;
|
||
|
import java.nio.ByteOrder;
|
||
|
import javax.annotation.CheckForNull;
|
||
|
|
||
|
/* JADX INFO: Access modifiers changed from: package-private */
|
||
|
@Immutable
|
||
|
@ElementTypesAreNonnullByDefault
|
||
|
/* loaded from: classes3.dex */
|
||
|
public final class Murmur3_128HashFunction extends AbstractHashFunction implements Serializable {
|
||
|
private static final long serialVersionUID = 0;
|
||
|
private final int seed;
|
||
|
static final HashFunction MURMUR3_128 = new Murmur3_128HashFunction(0);
|
||
|
static final HashFunction GOOD_FAST_HASH_128 = new Murmur3_128HashFunction(Hashing.GOOD_FAST_HASH_SEED);
|
||
|
|
||
|
@Override // com.google.common.hash.HashFunction
|
||
|
public int bits() {
|
||
|
return 128;
|
||
|
}
|
||
|
|
||
|
/* JADX INFO: Access modifiers changed from: package-private */
|
||
|
public Murmur3_128HashFunction(int i) {
|
||
|
this.seed = i;
|
||
|
}
|
||
|
|
||
|
@Override // com.google.common.hash.HashFunction
|
||
|
public Hasher newHasher() {
|
||
|
return new Murmur3_128Hasher(this.seed);
|
||
|
}
|
||
|
|
||
|
public String toString() {
|
||
|
return new StringBuilder(32).append("Hashing.murmur3_128(").append(this.seed).append(")").toString();
|
||
|
}
|
||
|
|
||
|
public boolean equals(@CheckForNull Object obj) {
|
||
|
return (obj instanceof Murmur3_128HashFunction) && this.seed == ((Murmur3_128HashFunction) obj).seed;
|
||
|
}
|
||
|
|
||
|
public int hashCode() {
|
||
|
return this.seed ^ getClass().hashCode();
|
||
|
}
|
||
|
|
||
|
/* loaded from: classes3.dex */
|
||
|
private static final class Murmur3_128Hasher extends AbstractStreamingHasher {
|
||
|
private static final long C1 = -8663945395140668459L;
|
||
|
private static final long C2 = 5545529020109919103L;
|
||
|
private static final int CHUNK_SIZE = 16;
|
||
|
private long h1;
|
||
|
private long h2;
|
||
|
private int length;
|
||
|
|
||
|
private static long fmix64(long j) {
|
||
|
long j2 = (j ^ (j >>> 33)) * (-49064778989728563L);
|
||
|
long j3 = (j2 ^ (j2 >>> 33)) * (-4265267296055464877L);
|
||
|
return j3 ^ (j3 >>> 33);
|
||
|
}
|
||
|
|
||
|
Murmur3_128Hasher(int i) {
|
||
|
super(16);
|
||
|
long j = i;
|
||
|
this.h1 = j;
|
||
|
this.h2 = j;
|
||
|
this.length = 0;
|
||
|
}
|
||
|
|
||
|
@Override // com.google.common.hash.AbstractStreamingHasher
|
||
|
protected void process(ByteBuffer byteBuffer) {
|
||
|
bmix64(byteBuffer.getLong(), byteBuffer.getLong());
|
||
|
this.length += 16;
|
||
|
}
|
||
|
|
||
|
private void bmix64(long j, long j2) {
|
||
|
long mixK1 = mixK1(j) ^ this.h1;
|
||
|
this.h1 = mixK1;
|
||
|
long rotateLeft = Long.rotateLeft(mixK1, 27);
|
||
|
long j3 = this.h2;
|
||
|
this.h1 = ((rotateLeft + j3) * 5) + 1390208809;
|
||
|
long mixK2 = mixK2(j2) ^ j3;
|
||
|
this.h2 = mixK2;
|
||
|
this.h2 = ((Long.rotateLeft(mixK2, 31) + this.h1) * 5) + 944331445;
|
||
|
}
|
||
|
|
||
|
/* JADX WARN: Can't fix incorrect switch cases order, some code will duplicate */
|
||
|
/* JADX WARN: Failed to find 'out' block for switch in B:2:0x001b. Please report as an issue. */
|
||
|
@Override // com.google.common.hash.AbstractStreamingHasher
|
||
|
protected void processRemaining(ByteBuffer byteBuffer) {
|
||
|
long j;
|
||
|
long j2;
|
||
|
long j3;
|
||
|
long j4;
|
||
|
long j5;
|
||
|
long j6;
|
||
|
long j7;
|
||
|
this.length += byteBuffer.remaining();
|
||
|
long j8 = 0;
|
||
|
switch (byteBuffer.remaining()) {
|
||
|
case 1:
|
||
|
j = 0;
|
||
|
j7 = j ^ UnsignedBytes.toInt(byteBuffer.get(0));
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 2:
|
||
|
j2 = 0;
|
||
|
j = j2 ^ (UnsignedBytes.toInt(byteBuffer.get(1)) << 8);
|
||
|
j7 = j ^ UnsignedBytes.toInt(byteBuffer.get(0));
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 3:
|
||
|
j3 = 0;
|
||
|
j2 = j3 ^ (UnsignedBytes.toInt(byteBuffer.get(2)) << 16);
|
||
|
j = j2 ^ (UnsignedBytes.toInt(byteBuffer.get(1)) << 8);
|
||
|
j7 = j ^ UnsignedBytes.toInt(byteBuffer.get(0));
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 4:
|
||
|
j4 = 0;
|
||
|
j3 = j4 ^ (UnsignedBytes.toInt(byteBuffer.get(3)) << 24);
|
||
|
j2 = j3 ^ (UnsignedBytes.toInt(byteBuffer.get(2)) << 16);
|
||
|
j = j2 ^ (UnsignedBytes.toInt(byteBuffer.get(1)) << 8);
|
||
|
j7 = j ^ UnsignedBytes.toInt(byteBuffer.get(0));
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 5:
|
||
|
j5 = 0;
|
||
|
j4 = j5 ^ (UnsignedBytes.toInt(byteBuffer.get(4)) << 32);
|
||
|
j3 = j4 ^ (UnsignedBytes.toInt(byteBuffer.get(3)) << 24);
|
||
|
j2 = j3 ^ (UnsignedBytes.toInt(byteBuffer.get(2)) << 16);
|
||
|
j = j2 ^ (UnsignedBytes.toInt(byteBuffer.get(1)) << 8);
|
||
|
j7 = j ^ UnsignedBytes.toInt(byteBuffer.get(0));
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 6:
|
||
|
j6 = 0;
|
||
|
j5 = j6 ^ (UnsignedBytes.toInt(byteBuffer.get(5)) << 40);
|
||
|
j4 = j5 ^ (UnsignedBytes.toInt(byteBuffer.get(4)) << 32);
|
||
|
j3 = j4 ^ (UnsignedBytes.toInt(byteBuffer.get(3)) << 24);
|
||
|
j2 = j3 ^ (UnsignedBytes.toInt(byteBuffer.get(2)) << 16);
|
||
|
j = j2 ^ (UnsignedBytes.toInt(byteBuffer.get(1)) << 8);
|
||
|
j7 = j ^ UnsignedBytes.toInt(byteBuffer.get(0));
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 7:
|
||
|
j6 = UnsignedBytes.toInt(byteBuffer.get(6)) << 48;
|
||
|
j5 = j6 ^ (UnsignedBytes.toInt(byteBuffer.get(5)) << 40);
|
||
|
j4 = j5 ^ (UnsignedBytes.toInt(byteBuffer.get(4)) << 32);
|
||
|
j3 = j4 ^ (UnsignedBytes.toInt(byteBuffer.get(3)) << 24);
|
||
|
j2 = j3 ^ (UnsignedBytes.toInt(byteBuffer.get(2)) << 16);
|
||
|
j = j2 ^ (UnsignedBytes.toInt(byteBuffer.get(1)) << 8);
|
||
|
j7 = j ^ UnsignedBytes.toInt(byteBuffer.get(0));
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 8:
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 9:
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(8));
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 10:
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(9)) << 8;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(8));
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 11:
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(10)) << 16;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(9)) << 8;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(8));
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 12:
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(11)) << 24;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(10)) << 16;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(9)) << 8;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(8));
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 13:
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(12)) << 32;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(11)) << 24;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(10)) << 16;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(9)) << 8;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(8));
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 14:
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(13)) << 40;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(12)) << 32;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(11)) << 24;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(10)) << 16;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(9)) << 8;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(8));
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
case 15:
|
||
|
j8 = UnsignedBytes.toInt(byteBuffer.get(14)) << 48;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(13)) << 40;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(12)) << 32;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(11)) << 24;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(10)) << 16;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(9)) << 8;
|
||
|
j8 ^= UnsignedBytes.toInt(byteBuffer.get(8));
|
||
|
j7 = byteBuffer.getLong();
|
||
|
this.h1 = mixK1(j7) ^ this.h1;
|
||
|
this.h2 ^= mixK2(j8);
|
||
|
return;
|
||
|
default:
|
||
|
throw new AssertionError("Should never get here.");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@Override // com.google.common.hash.AbstractStreamingHasher
|
||
|
protected HashCode makeHash() {
|
||
|
long j = this.h1;
|
||
|
int i = this.length;
|
||
|
long j2 = j ^ i;
|
||
|
long j3 = this.h2 ^ i;
|
||
|
long j4 = j2 + j3;
|
||
|
this.h1 = j4;
|
||
|
this.h2 = j3 + j4;
|
||
|
this.h1 = fmix64(j4);
|
||
|
long fmix64 = fmix64(this.h2);
|
||
|
long j5 = this.h1 + fmix64;
|
||
|
this.h1 = j5;
|
||
|
this.h2 = fmix64 + j5;
|
||
|
return HashCode.fromBytesNoCopy(ByteBuffer.wrap(new byte[16]).order(ByteOrder.LITTLE_ENDIAN).putLong(this.h1).putLong(this.h2).array());
|
||
|
}
|
||
|
|
||
|
private static long mixK1(long j) {
|
||
|
return Long.rotateLeft(j * C1, 31) * C2;
|
||
|
}
|
||
|
|
||
|
private static long mixK2(long j) {
|
||
|
return Long.rotateLeft(j * C2, 33) * C1;
|
||
|
}
|
||
|
}
|
||
|
}
|