mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
347 lines
12 KiB
Java
347 lines
12 KiB
Java
package com.google.common.hash;
|
|
|
|
import com.google.common.base.Preconditions;
|
|
import com.google.errorprone.annotations.Immutable;
|
|
import java.security.Key;
|
|
import java.util.ArrayList;
|
|
import java.util.Arrays;
|
|
import java.util.Collections;
|
|
import java.util.Iterator;
|
|
import java.util.zip.Adler32;
|
|
import java.util.zip.CRC32;
|
|
import java.util.zip.Checksum;
|
|
import javax.annotation.CheckForNull;
|
|
import javax.crypto.spec.SecretKeySpec;
|
|
|
|
@ElementTypesAreNonnullByDefault
|
|
/* loaded from: classes3.dex */
|
|
public final class Hashing {
|
|
static final int GOOD_FAST_HASH_SEED = (int) System.currentTimeMillis();
|
|
|
|
public static HashFunction goodFastHash(int i) {
|
|
int checkPositiveAndMakeMultipleOf32 = checkPositiveAndMakeMultipleOf32(i);
|
|
if (checkPositiveAndMakeMultipleOf32 == 32) {
|
|
return Murmur3_32HashFunction.GOOD_FAST_HASH_32;
|
|
}
|
|
if (checkPositiveAndMakeMultipleOf32 <= 128) {
|
|
return Murmur3_128HashFunction.GOOD_FAST_HASH_128;
|
|
}
|
|
int i2 = (checkPositiveAndMakeMultipleOf32 + 127) / 128;
|
|
HashFunction[] hashFunctionArr = new HashFunction[i2];
|
|
hashFunctionArr[0] = Murmur3_128HashFunction.GOOD_FAST_HASH_128;
|
|
int i3 = GOOD_FAST_HASH_SEED;
|
|
for (int i4 = 1; i4 < i2; i4++) {
|
|
i3 += 1500450271;
|
|
hashFunctionArr[i4] = murmur3_128(i3);
|
|
}
|
|
return new ConcatenatedHashFunction(hashFunctionArr);
|
|
}
|
|
|
|
@Deprecated
|
|
public static HashFunction murmur3_32(int i) {
|
|
return new Murmur3_32HashFunction(i, false);
|
|
}
|
|
|
|
@Deprecated
|
|
public static HashFunction murmur3_32() {
|
|
return Murmur3_32HashFunction.MURMUR3_32;
|
|
}
|
|
|
|
public static HashFunction murmur3_32_fixed(int i) {
|
|
return new Murmur3_32HashFunction(i, true);
|
|
}
|
|
|
|
public static HashFunction murmur3_32_fixed() {
|
|
return Murmur3_32HashFunction.MURMUR3_32_FIXED;
|
|
}
|
|
|
|
public static HashFunction murmur3_128(int i) {
|
|
return new Murmur3_128HashFunction(i);
|
|
}
|
|
|
|
public static HashFunction murmur3_128() {
|
|
return Murmur3_128HashFunction.MURMUR3_128;
|
|
}
|
|
|
|
public static HashFunction sipHash24() {
|
|
return SipHashFunction.SIP_HASH_24;
|
|
}
|
|
|
|
public static HashFunction sipHash24(long j, long j2) {
|
|
return new SipHashFunction(2, 4, j, j2);
|
|
}
|
|
|
|
@Deprecated
|
|
public static HashFunction md5() {
|
|
return Md5Holder.MD5;
|
|
}
|
|
|
|
/* loaded from: classes3.dex */
|
|
private static class Md5Holder {
|
|
static final HashFunction MD5 = new MessageDigestHashFunction("MD5", "Hashing.md5()");
|
|
|
|
private Md5Holder() {
|
|
}
|
|
}
|
|
|
|
@Deprecated
|
|
public static HashFunction sha1() {
|
|
return Sha1Holder.SHA_1;
|
|
}
|
|
|
|
/* loaded from: classes3.dex */
|
|
private static class Sha1Holder {
|
|
static final HashFunction SHA_1 = new MessageDigestHashFunction("SHA-1", "Hashing.sha1()");
|
|
|
|
private Sha1Holder() {
|
|
}
|
|
}
|
|
|
|
public static HashFunction sha256() {
|
|
return Sha256Holder.SHA_256;
|
|
}
|
|
|
|
/* loaded from: classes3.dex */
|
|
private static class Sha256Holder {
|
|
static final HashFunction SHA_256 = new MessageDigestHashFunction("SHA-256", "Hashing.sha256()");
|
|
|
|
private Sha256Holder() {
|
|
}
|
|
}
|
|
|
|
public static HashFunction sha384() {
|
|
return Sha384Holder.SHA_384;
|
|
}
|
|
|
|
/* loaded from: classes3.dex */
|
|
private static class Sha384Holder {
|
|
static final HashFunction SHA_384 = new MessageDigestHashFunction("SHA-384", "Hashing.sha384()");
|
|
|
|
private Sha384Holder() {
|
|
}
|
|
}
|
|
|
|
public static HashFunction sha512() {
|
|
return Sha512Holder.SHA_512;
|
|
}
|
|
|
|
/* loaded from: classes3.dex */
|
|
private static class Sha512Holder {
|
|
static final HashFunction SHA_512 = new MessageDigestHashFunction("SHA-512", "Hashing.sha512()");
|
|
|
|
private Sha512Holder() {
|
|
}
|
|
}
|
|
|
|
public static HashFunction hmacMd5(Key key) {
|
|
return new MacHashFunction("HmacMD5", key, hmacToString("hmacMd5", key));
|
|
}
|
|
|
|
public static HashFunction hmacMd5(byte[] bArr) {
|
|
return hmacMd5(new SecretKeySpec((byte[]) Preconditions.checkNotNull(bArr), "HmacMD5"));
|
|
}
|
|
|
|
public static HashFunction hmacSha1(Key key) {
|
|
return new MacHashFunction("HmacSHA1", key, hmacToString("hmacSha1", key));
|
|
}
|
|
|
|
public static HashFunction hmacSha1(byte[] bArr) {
|
|
return hmacSha1(new SecretKeySpec((byte[]) Preconditions.checkNotNull(bArr), "HmacSHA1"));
|
|
}
|
|
|
|
public static HashFunction hmacSha256(Key key) {
|
|
return new MacHashFunction("HmacSHA256", key, hmacToString("hmacSha256", key));
|
|
}
|
|
|
|
public static HashFunction hmacSha256(byte[] bArr) {
|
|
return hmacSha256(new SecretKeySpec((byte[]) Preconditions.checkNotNull(bArr), "HmacSHA256"));
|
|
}
|
|
|
|
public static HashFunction hmacSha512(Key key) {
|
|
return new MacHashFunction("HmacSHA512", key, hmacToString("hmacSha512", key));
|
|
}
|
|
|
|
public static HashFunction hmacSha512(byte[] bArr) {
|
|
return hmacSha512(new SecretKeySpec((byte[]) Preconditions.checkNotNull(bArr), "HmacSHA512"));
|
|
}
|
|
|
|
private static String hmacToString(String str, Key key) {
|
|
return String.format("Hashing.%s(Key[algorithm=%s, format=%s])", str, key.getAlgorithm(), key.getFormat());
|
|
}
|
|
|
|
public static HashFunction crc32c() {
|
|
return Crc32cHashFunction.CRC_32_C;
|
|
}
|
|
|
|
public static HashFunction crc32() {
|
|
return ChecksumType.CRC_32.hashFunction;
|
|
}
|
|
|
|
public static HashFunction adler32() {
|
|
return ChecksumType.ADLER_32.hashFunction;
|
|
}
|
|
|
|
@Immutable
|
|
/* loaded from: classes3.dex */
|
|
enum ChecksumType implements ImmutableSupplier<Checksum> {
|
|
CRC_32("Hashing.crc32()") { // from class: com.google.common.hash.Hashing.ChecksumType.1
|
|
@Override // com.google.common.base.Supplier
|
|
public Checksum get() {
|
|
return new CRC32();
|
|
}
|
|
},
|
|
ADLER_32("Hashing.adler32()") { // from class: com.google.common.hash.Hashing.ChecksumType.2
|
|
@Override // com.google.common.base.Supplier
|
|
public Checksum get() {
|
|
return new Adler32();
|
|
}
|
|
};
|
|
|
|
public final HashFunction hashFunction;
|
|
|
|
ChecksumType(String str) {
|
|
this.hashFunction = new ChecksumHashFunction(this, 32, str);
|
|
}
|
|
}
|
|
|
|
public static HashFunction farmHashFingerprint64() {
|
|
return FarmHashFingerprint64.FARMHASH_FINGERPRINT_64;
|
|
}
|
|
|
|
public static HashFunction fingerprint2011() {
|
|
return Fingerprint2011.FINGERPRINT_2011;
|
|
}
|
|
|
|
public static int consistentHash(HashCode hashCode, int i) {
|
|
return consistentHash(hashCode.padToLong(), i);
|
|
}
|
|
|
|
public static int consistentHash(long j, int i) {
|
|
int i2 = 0;
|
|
Preconditions.checkArgument(i > 0, "buckets must be positive: %s", i);
|
|
LinearCongruentialGenerator linearCongruentialGenerator = new LinearCongruentialGenerator(j);
|
|
while (true) {
|
|
int nextDouble = (int) ((i2 + 1) / linearCongruentialGenerator.nextDouble());
|
|
if (nextDouble < 0 || nextDouble >= i) {
|
|
break;
|
|
}
|
|
i2 = nextDouble;
|
|
}
|
|
return i2;
|
|
}
|
|
|
|
public static HashCode combineOrdered(Iterable<HashCode> iterable) {
|
|
Iterator<HashCode> it = iterable.iterator();
|
|
Preconditions.checkArgument(it.hasNext(), "Must be at least 1 hash code to combine.");
|
|
int bits = it.next().bits() / 8;
|
|
byte[] bArr = new byte[bits];
|
|
Iterator<HashCode> it2 = iterable.iterator();
|
|
while (it2.hasNext()) {
|
|
byte[] asBytes = it2.next().asBytes();
|
|
Preconditions.checkArgument(asBytes.length == bits, "All hashcodes must have the same bit length.");
|
|
for (int i = 0; i < asBytes.length; i++) {
|
|
bArr[i] = (byte) ((bArr[i] * 37) ^ asBytes[i]);
|
|
}
|
|
}
|
|
return HashCode.fromBytesNoCopy(bArr);
|
|
}
|
|
|
|
public static HashCode combineUnordered(Iterable<HashCode> iterable) {
|
|
Iterator<HashCode> it = iterable.iterator();
|
|
Preconditions.checkArgument(it.hasNext(), "Must be at least 1 hash code to combine.");
|
|
int bits = it.next().bits() / 8;
|
|
byte[] bArr = new byte[bits];
|
|
Iterator<HashCode> it2 = iterable.iterator();
|
|
while (it2.hasNext()) {
|
|
byte[] asBytes = it2.next().asBytes();
|
|
Preconditions.checkArgument(asBytes.length == bits, "All hashcodes must have the same bit length.");
|
|
for (int i = 0; i < asBytes.length; i++) {
|
|
bArr[i] = (byte) (bArr[i] + asBytes[i]);
|
|
}
|
|
}
|
|
return HashCode.fromBytesNoCopy(bArr);
|
|
}
|
|
|
|
static int checkPositiveAndMakeMultipleOf32(int i) {
|
|
Preconditions.checkArgument(i > 0, "Number of bits must be positive");
|
|
return (i + 31) & (-32);
|
|
}
|
|
|
|
public static HashFunction concatenating(HashFunction hashFunction, HashFunction hashFunction2, HashFunction... hashFunctionArr) {
|
|
ArrayList arrayList = new ArrayList();
|
|
arrayList.add(hashFunction);
|
|
arrayList.add(hashFunction2);
|
|
Collections.addAll(arrayList, hashFunctionArr);
|
|
return new ConcatenatedHashFunction((HashFunction[]) arrayList.toArray(new HashFunction[0]));
|
|
}
|
|
|
|
public static HashFunction concatenating(Iterable<HashFunction> iterable) {
|
|
Preconditions.checkNotNull(iterable);
|
|
ArrayList arrayList = new ArrayList();
|
|
Iterator<HashFunction> it = iterable.iterator();
|
|
while (it.hasNext()) {
|
|
arrayList.add(it.next());
|
|
}
|
|
Preconditions.checkArgument(!arrayList.isEmpty(), "number of hash functions (%s) must be > 0", arrayList.size());
|
|
return new ConcatenatedHashFunction((HashFunction[]) arrayList.toArray(new HashFunction[0]));
|
|
}
|
|
|
|
/* loaded from: classes3.dex */
|
|
private static final class ConcatenatedHashFunction extends AbstractCompositeHashFunction {
|
|
private ConcatenatedHashFunction(HashFunction... hashFunctionArr) {
|
|
super(hashFunctionArr);
|
|
for (HashFunction hashFunction : hashFunctionArr) {
|
|
Preconditions.checkArgument(hashFunction.bits() % 8 == 0, "the number of bits (%s) in hashFunction (%s) must be divisible by 8", hashFunction.bits(), (Object) hashFunction);
|
|
}
|
|
}
|
|
|
|
@Override // com.google.common.hash.AbstractCompositeHashFunction
|
|
HashCode makeHash(Hasher[] hasherArr) {
|
|
byte[] bArr = new byte[bits() / 8];
|
|
int i = 0;
|
|
for (Hasher hasher : hasherArr) {
|
|
HashCode hash = hasher.hash();
|
|
i += hash.writeBytesTo(bArr, i, hash.bits() / 8);
|
|
}
|
|
return HashCode.fromBytesNoCopy(bArr);
|
|
}
|
|
|
|
@Override // com.google.common.hash.HashFunction
|
|
public int bits() {
|
|
int i = 0;
|
|
for (HashFunction hashFunction : this.functions) {
|
|
i += hashFunction.bits();
|
|
}
|
|
return i;
|
|
}
|
|
|
|
public boolean equals(@CheckForNull Object obj) {
|
|
if (obj instanceof ConcatenatedHashFunction) {
|
|
return Arrays.equals(this.functions, ((ConcatenatedHashFunction) obj).functions);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
public int hashCode() {
|
|
return Arrays.hashCode(this.functions);
|
|
}
|
|
}
|
|
|
|
/* JADX INFO: Access modifiers changed from: private */
|
|
/* loaded from: classes3.dex */
|
|
public static final class LinearCongruentialGenerator {
|
|
private long state;
|
|
|
|
public double nextDouble() {
|
|
this.state = (this.state * 2862933555777941757L) + 1;
|
|
return (((int) (r2 >>> 33)) + 1) / 2.147483648E9d;
|
|
}
|
|
|
|
public LinearCongruentialGenerator(long j) {
|
|
this.state = j;
|
|
}
|
|
}
|
|
|
|
private Hashing() {
|
|
}
|
|
}
|