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

118 lines
3.6 KiB
Java

package com.google.common.base;
@ElementTypesAreNonnullByDefault
/* loaded from: classes2.dex */
public final class Utf8 {
public static int encodedLength(CharSequence charSequence) {
int length = charSequence.length();
int i = 0;
while (i < length && charSequence.charAt(i) < 128) {
i++;
}
int i2 = length;
while (true) {
if (i < length) {
char charAt = charSequence.charAt(i);
if (charAt >= 2048) {
i2 += encodedLengthGeneral(charSequence, i);
break;
}
i2 += (127 - charAt) >>> 31;
i++;
} else {
break;
}
}
if (i2 >= length) {
return i2;
}
throw new IllegalArgumentException(new StringBuilder(54).append("UTF-8 length does not fit in int: ").append(i2 + 4294967296L).toString());
}
private static int encodedLengthGeneral(CharSequence charSequence, int i) {
int length = charSequence.length();
int i2 = 0;
while (i < length) {
char charAt = charSequence.charAt(i);
if (charAt < 2048) {
i2 += (127 - charAt) >>> 31;
} else {
i2 += 2;
if (55296 <= charAt && charAt <= 57343) {
if (Character.codePointAt(charSequence, i) == charAt) {
throw new IllegalArgumentException(unpairedSurrogateMsg(i));
}
i++;
}
}
i++;
}
return i2;
}
public static boolean isWellFormed(byte[] bArr) {
return isWellFormed(bArr, 0, bArr.length);
}
public static boolean isWellFormed(byte[] bArr, int i, int i2) {
int i3 = i2 + i;
Preconditions.checkPositionIndexes(i, i3, bArr.length);
while (i < i3) {
if (bArr[i] < 0) {
return isWellFormedSlowPath(bArr, i, i3);
}
i++;
}
return true;
}
private static boolean isWellFormedSlowPath(byte[] bArr, int i, int i2) {
byte b;
while (i < i2) {
int i3 = i + 1;
byte b2 = bArr[i];
if (b2 < 0) {
if (b2 < -32) {
if (i3 != i2 && b2 >= -62) {
i += 2;
if (bArr[i3] > -65) {
}
}
return false;
}
if (b2 < -16) {
int i4 = i + 2;
if (i4 < i2 && (b = bArr[i3]) <= -65 && ((b2 != -32 || b >= -96) && (b2 != -19 || -96 > b))) {
i += 3;
if (bArr[i4] > -65) {
}
}
return false;
}
if (i + 3 >= i2) {
return false;
}
int i5 = i + 2;
byte b3 = bArr[i3];
if (b3 <= -65 && (((b2 << Ascii.FS) + (b3 + 112)) >> 30) == 0) {
int i6 = i + 3;
if (bArr[i5] <= -65) {
i += 4;
if (bArr[i6] > -65) {
}
}
}
return false;
}
i = i3;
}
return true;
}
private static String unpairedSurrogateMsg(int i) {
return new StringBuilder(39).append("Unpaired surrogate at index ").append(i).toString();
}
private Utf8() {
}
}