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
This commit is contained in:
2026-02-18 15:48:36 -08:00
parent c19eb3d7ff
commit c080f0d97f
26930 changed files with 2529574 additions and 0 deletions

View File

@@ -0,0 +1,188 @@
package androidx.concurrent.futures;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import com.google.common.util.concurrent.ListenableFuture;
import com.ironsource.v8;
import java.lang.ref.WeakReference;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Executor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
/* loaded from: classes.dex */
public final class CallbackToFutureAdapter {
public interface Resolver<T> {
@Nullable
Object attachCompleter(@NonNull Completer<T> completer) throws Exception;
}
private CallbackToFutureAdapter() {
}
@NonNull
public static <T> ListenableFuture getFuture(@NonNull Resolver<T> resolver) {
Completer<T> completer = new Completer<>();
SafeFuture<T> safeFuture = new SafeFuture<>(completer);
completer.future = safeFuture;
completer.tag = resolver.getClass();
try {
Object attachCompleter = resolver.attachCompleter(completer);
if (attachCompleter != null) {
completer.tag = attachCompleter;
}
} catch (Exception e) {
safeFuture.setException(e);
}
return safeFuture;
}
public static final class SafeFuture<T> implements ListenableFuture {
final WeakReference<Completer<T>> completerWeakReference;
private final AbstractResolvableFuture<T> delegate = new AbstractResolvableFuture<T>() { // from class: androidx.concurrent.futures.CallbackToFutureAdapter.SafeFuture.1
@Override // androidx.concurrent.futures.AbstractResolvableFuture
public String pendingToString() {
Completer<T> completer = SafeFuture.this.completerWeakReference.get();
if (completer == null) {
return "Completer object has been garbage collected, future will fail soon";
}
return "tag=[" + completer.tag + v8.i.e;
}
};
public SafeFuture(Completer<T> completer) {
this.completerWeakReference = new WeakReference<>(completer);
}
@Override // java.util.concurrent.Future
public boolean cancel(boolean z) {
Completer<T> completer = this.completerWeakReference.get();
boolean cancel = this.delegate.cancel(z);
if (cancel && completer != null) {
completer.fireCancellationListeners();
}
return cancel;
}
public boolean cancelWithoutNotifyingCompleter(boolean z) {
return this.delegate.cancel(z);
}
public boolean set(T t) {
return this.delegate.set(t);
}
public boolean setException(Throwable th) {
return this.delegate.setException(th);
}
@Override // java.util.concurrent.Future
public boolean isCancelled() {
return this.delegate.isCancelled();
}
@Override // java.util.concurrent.Future
public boolean isDone() {
return this.delegate.isDone();
}
@Override // java.util.concurrent.Future
public T get() throws InterruptedException, ExecutionException {
return this.delegate.get();
}
@Override // java.util.concurrent.Future
public T get(long j, @NonNull TimeUnit timeUnit) throws InterruptedException, ExecutionException, TimeoutException {
return this.delegate.get(j, timeUnit);
}
@Override // com.google.common.util.concurrent.ListenableFuture
public void addListener(@NonNull Runnable runnable, @NonNull Executor executor) {
this.delegate.addListener(runnable, executor);
}
public String toString() {
return this.delegate.toString();
}
}
public static final class Completer<T> {
private boolean attemptedSetting;
private ResolvableFuture<Void> cancellationFuture = ResolvableFuture.create();
SafeFuture<T> future;
Object tag;
private void setCompletedNormally() {
this.tag = null;
this.future = null;
this.cancellationFuture = null;
}
public boolean set(T t) {
this.attemptedSetting = true;
SafeFuture<T> safeFuture = this.future;
boolean z = safeFuture != null && safeFuture.set(t);
if (z) {
setCompletedNormally();
}
return z;
}
public boolean setException(@NonNull Throwable th) {
this.attemptedSetting = true;
SafeFuture<T> safeFuture = this.future;
boolean z = safeFuture != null && safeFuture.setException(th);
if (z) {
setCompletedNormally();
}
return z;
}
public boolean setCancelled() {
this.attemptedSetting = true;
SafeFuture<T> safeFuture = this.future;
boolean z = safeFuture != null && safeFuture.cancelWithoutNotifyingCompleter(true);
if (z) {
setCompletedNormally();
}
return z;
}
public void addCancellationListener(@NonNull Runnable runnable, @NonNull Executor executor) {
ResolvableFuture<Void> resolvableFuture = this.cancellationFuture;
if (resolvableFuture != null) {
resolvableFuture.addListener(runnable, executor);
}
}
public void fireCancellationListeners() {
this.tag = null;
this.future = null;
this.cancellationFuture.set(null);
}
public void finalize() {
ResolvableFuture<Void> resolvableFuture;
SafeFuture<T> safeFuture = this.future;
if (safeFuture != null && !safeFuture.isDone()) {
safeFuture.setException(new FutureGarbageCollectedException("The completer object was garbage collected - this future would otherwise never complete. The tag was: " + this.tag));
}
if (this.attemptedSetting || (resolvableFuture = this.cancellationFuture) == null) {
return;
}
resolvableFuture.set(null);
}
}
public static final class FutureGarbageCollectedException extends Throwable {
public FutureGarbageCollectedException(String str) {
super(str);
}
@Override // java.lang.Throwable
public synchronized Throwable fillInStackTrace() {
return this;
}
}
}