Files
Daniel Elliott c080f0d97f Add Discord community version (64-bit only)
- Added realracing3-community.apk (71.57 MB)
- Removed 32-bit support (armeabi-v7a)
- Only includes arm64-v8a libraries
- Decompiled source code included
- Added README-community.md with analysis
2026-02-18 15:48:36 -08:00

228 lines
8.8 KiB
Java

package androidx.profileinstaller;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.annotation.RequiresApi;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.nio.charset.StandardCharsets;
import java.util.zip.Deflater;
import java.util.zip.DeflaterOutputStream;
@RequiresApi(19)
/* loaded from: classes.dex */
class Encoding {
static final int SIZEOF_BYTE = 8;
static final int UINT_16_SIZE = 2;
static final int UINT_32_SIZE = 4;
static final int UINT_8_SIZE = 1;
private Encoding() {
}
public static int utf8Length(@NonNull String str) {
return str.getBytes(StandardCharsets.UTF_8).length;
}
public static void writeUInt(@NonNull OutputStream outputStream, long j, int i) throws IOException {
byte[] bArr = new byte[i];
for (int i2 = 0; i2 < i; i2++) {
bArr[i2] = (byte) ((j >> (i2 * 8)) & 255);
}
outputStream.write(bArr);
}
public static void writeUInt8(@NonNull OutputStream outputStream, int i) throws IOException {
writeUInt(outputStream, i, 1);
}
public static void writeUInt16(@NonNull OutputStream outputStream, int i) throws IOException {
writeUInt(outputStream, i, 2);
}
public static void writeUInt32(@NonNull OutputStream outputStream, long j) throws IOException {
writeUInt(outputStream, j, 4);
}
public static void writeString(@NonNull OutputStream outputStream, @NonNull String str) throws IOException {
outputStream.write(str.getBytes(StandardCharsets.UTF_8));
}
public static int bitsToBytes(int i) {
return ((i + 7) & (-8)) / 8;
}
@NonNull
public static byte[] read(@NonNull InputStream inputStream, int i) throws IOException {
byte[] bArr = new byte[i];
int i2 = 0;
while (i2 < i) {
int read = inputStream.read(bArr, i2, i - i2);
if (read < 0) {
throw error("Not enough bytes to read: " + i);
}
i2 += read;
}
return bArr;
}
public static long readUInt(@NonNull InputStream inputStream, int i) throws IOException {
byte[] read = read(inputStream, i);
long j = 0;
for (int i2 = 0; i2 < i; i2++) {
j += (read[i2] & 255) << (i2 * 8);
}
return j;
}
public static int readUInt8(@NonNull InputStream inputStream) throws IOException {
return (int) readUInt(inputStream, 1);
}
public static int readUInt16(@NonNull InputStream inputStream) throws IOException {
return (int) readUInt(inputStream, 2);
}
public static long readUInt32(@NonNull InputStream inputStream) throws IOException {
return readUInt(inputStream, 4);
}
@NonNull
public static String readString(InputStream inputStream, int i) throws IOException {
return new String(read(inputStream, i), StandardCharsets.UTF_8);
}
/* JADX WARN: Code restructure failed: missing block: B:27:0x005b, code lost:
if (r0.finished() == false) goto L27;
*/
/* JADX WARN: Code restructure failed: missing block: B:29:0x0060, code lost:
return r1;
*/
/* JADX WARN: Code restructure failed: missing block: B:31:0x0067, code lost:
throw error("Inflater did not finish");
*/
@androidx.annotation.NonNull
/*
Code decompiled incorrectly, please refer to instructions dump.
To view partially-correct add '--show-bad-code' argument
*/
public static byte[] readCompressed(@androidx.annotation.NonNull java.io.InputStream r8, int r9, int r10) throws java.io.IOException {
/*
java.util.zip.Inflater r0 = new java.util.zip.Inflater
r0.<init>()
byte[] r1 = new byte[r10] // Catch: java.lang.Throwable -> L2e
r2 = 2048(0x800, float:2.87E-42)
byte[] r2 = new byte[r2] // Catch: java.lang.Throwable -> L2e
r3 = 0
r4 = r3
r5 = r4
Le:
boolean r6 = r0.finished() // Catch: java.lang.Throwable -> L2e
if (r6 != 0) goto L55
boolean r6 = r0.needsDictionary() // Catch: java.lang.Throwable -> L2e
if (r6 != 0) goto L55
if (r4 >= r9) goto L55
int r6 = r8.read(r2) // Catch: java.lang.Throwable -> L2e
if (r6 < 0) goto L3a
r0.setInput(r2, r3, r6) // Catch: java.lang.Throwable -> L2e
int r7 = r10 - r5
int r7 = r0.inflate(r1, r5, r7) // Catch: java.lang.Throwable -> L2e java.util.zip.DataFormatException -> L30
int r5 = r5 + r7
int r4 = r4 + r6
goto Le
L2e:
r8 = move-exception
goto L86
L30:
r8 = move-exception
java.lang.String r8 = r8.getMessage() // Catch: java.lang.Throwable -> L2e
java.lang.RuntimeException r8 = error(r8) // Catch: java.lang.Throwable -> L2e
throw r8 // Catch: java.lang.Throwable -> L2e
L3a:
java.lang.StringBuilder r8 = new java.lang.StringBuilder // Catch: java.lang.Throwable -> L2e
r8.<init>() // Catch: java.lang.Throwable -> L2e
java.lang.String r10 = "Invalid zip data. Stream ended after $totalBytesRead bytes. Expected "
r8.append(r10) // Catch: java.lang.Throwable -> L2e
r8.append(r9) // Catch: java.lang.Throwable -> L2e
java.lang.String r9 = " bytes"
r8.append(r9) // Catch: java.lang.Throwable -> L2e
java.lang.String r8 = r8.toString() // Catch: java.lang.Throwable -> L2e
java.lang.RuntimeException r8 = error(r8) // Catch: java.lang.Throwable -> L2e
throw r8 // Catch: java.lang.Throwable -> L2e
L55:
if (r4 != r9) goto L68
boolean r8 = r0.finished() // Catch: java.lang.Throwable -> L2e
if (r8 == 0) goto L61
r0.end()
return r1
L61:
java.lang.String r8 = "Inflater did not finish"
java.lang.RuntimeException r8 = error(r8) // Catch: java.lang.Throwable -> L2e
throw r8 // Catch: java.lang.Throwable -> L2e
L68:
java.lang.StringBuilder r8 = new java.lang.StringBuilder // Catch: java.lang.Throwable -> L2e
r8.<init>() // Catch: java.lang.Throwable -> L2e
java.lang.String r10 = "Didn't read enough bytes during decompression. expected="
r8.append(r10) // Catch: java.lang.Throwable -> L2e
r8.append(r9) // Catch: java.lang.Throwable -> L2e
java.lang.String r9 = " actual="
r8.append(r9) // Catch: java.lang.Throwable -> L2e
r8.append(r4) // Catch: java.lang.Throwable -> L2e
java.lang.String r8 = r8.toString() // Catch: java.lang.Throwable -> L2e
java.lang.RuntimeException r8 = error(r8) // Catch: java.lang.Throwable -> L2e
throw r8 // Catch: java.lang.Throwable -> L2e
L86:
r0.end()
throw r8
*/
throw new UnsupportedOperationException("Method not decompiled: androidx.profileinstaller.Encoding.readCompressed(java.io.InputStream, int, int):byte[]");
}
public static void writeCompressed(@NonNull OutputStream outputStream, byte[] bArr) throws IOException {
writeUInt32(outputStream, bArr.length);
byte[] compress = compress(bArr);
writeUInt32(outputStream, compress.length);
outputStream.write(compress);
}
public static byte[] compress(@NonNull byte[] bArr) throws IOException {
Deflater deflater = new Deflater(1);
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
try {
DeflaterOutputStream deflaterOutputStream = new DeflaterOutputStream(byteArrayOutputStream, deflater);
try {
deflaterOutputStream.write(bArr);
deflaterOutputStream.close();
deflater.end();
return byteArrayOutputStream.toByteArray();
} finally {
}
} catch (Throwable th) {
deflater.end();
throw th;
}
}
public static void writeAll(@NonNull InputStream inputStream, @NonNull OutputStream outputStream) throws IOException {
byte[] bArr = new byte[512];
while (true) {
int read = inputStream.read(bArr);
if (read <= 0) {
return;
} else {
outputStream.write(bArr, 0, read);
}
}
}
@NonNull
public static RuntimeException error(@Nullable String str) {
return new IllegalStateException(str);
}
}