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,215 @@
package androidx.work.impl;
import android.text.TextUtils;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.annotation.RestrictTo;
import androidx.lifecycle.LiveData;
import androidx.work.ArrayCreatingInputMerger;
import androidx.work.ExistingWorkPolicy;
import androidx.work.ListenableWorker;
import androidx.work.Logger;
import androidx.work.OneTimeWorkRequest;
import androidx.work.Operation;
import androidx.work.OperationKt;
import androidx.work.WorkContinuation;
import androidx.work.WorkInfo;
import androidx.work.WorkRequest;
import androidx.work.impl.utils.EnqueueRunnable;
import androidx.work.impl.utils.StatusRunnable;
import androidx.work.impl.workers.CombineContinuationsWorker;
import com.google.common.util.concurrent.ListenableFuture;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Set;
import kotlin.Unit;
import kotlin.jvm.functions.Function0;
@RestrictTo({RestrictTo.Scope.LIBRARY_GROUP})
/* loaded from: classes.dex */
public class WorkContinuationImpl extends WorkContinuation {
private static final String TAG = Logger.tagWithPrefix("WorkContinuationImpl");
private final List<String> mAllIds;
private boolean mEnqueued;
private final ExistingWorkPolicy mExistingWorkPolicy;
private final List<String> mIds;
private final String mName;
private Operation mOperation;
private final List<WorkContinuationImpl> mParents;
private final List<? extends WorkRequest> mWork;
private final WorkManagerImpl mWorkManagerImpl;
@NonNull
public List<String> getAllIds() {
return this.mAllIds;
}
@NonNull
public ExistingWorkPolicy getExistingWorkPolicy() {
return this.mExistingWorkPolicy;
}
@NonNull
public List<String> getIds() {
return this.mIds;
}
@Nullable
public String getName() {
return this.mName;
}
@Nullable
public List<WorkContinuationImpl> getParents() {
return this.mParents;
}
@NonNull
public List<? extends WorkRequest> getWork() {
return this.mWork;
}
@NonNull
public WorkManagerImpl getWorkManagerImpl() {
return this.mWorkManagerImpl;
}
public boolean isEnqueued() {
return this.mEnqueued;
}
public void markEnqueued() {
this.mEnqueued = true;
}
public WorkContinuationImpl(@NonNull WorkManagerImpl workManagerImpl, @NonNull List<? extends WorkRequest> list) {
this(workManagerImpl, null, ExistingWorkPolicy.KEEP, list, null);
}
public WorkContinuationImpl(@NonNull WorkManagerImpl workManagerImpl, @Nullable String str, @NonNull ExistingWorkPolicy existingWorkPolicy, @NonNull List<? extends WorkRequest> list) {
this(workManagerImpl, str, existingWorkPolicy, list, null);
}
public WorkContinuationImpl(@NonNull WorkManagerImpl workManagerImpl, @Nullable String str, @NonNull ExistingWorkPolicy existingWorkPolicy, @NonNull List<? extends WorkRequest> list, @Nullable List<WorkContinuationImpl> list2) {
this.mWorkManagerImpl = workManagerImpl;
this.mName = str;
this.mExistingWorkPolicy = existingWorkPolicy;
this.mWork = list;
this.mParents = list2;
this.mIds = new ArrayList(list.size());
this.mAllIds = new ArrayList();
if (list2 != null) {
Iterator<WorkContinuationImpl> it = list2.iterator();
while (it.hasNext()) {
this.mAllIds.addAll(it.next().mAllIds);
}
}
for (int i = 0; i < list.size(); i++) {
if (existingWorkPolicy == ExistingWorkPolicy.REPLACE && list.get(i).getWorkSpec().getNextScheduleTimeOverride() != Long.MAX_VALUE) {
throw new IllegalArgumentException("Next Schedule Time Override must be used with ExistingPeriodicWorkPolicyUPDATE (preferably) or KEEP");
}
String stringId = list.get(i).getStringId();
this.mIds.add(stringId);
this.mAllIds.add(stringId);
}
}
@Override // androidx.work.WorkContinuation
@NonNull
public WorkContinuation then(@NonNull List<OneTimeWorkRequest> list) {
return list.isEmpty() ? this : new WorkContinuationImpl(this.mWorkManagerImpl, this.mName, ExistingWorkPolicy.KEEP, list, Collections.singletonList(this));
}
@Override // androidx.work.WorkContinuation
@NonNull
public LiveData<List<WorkInfo>> getWorkInfosLiveData() {
return this.mWorkManagerImpl.getWorkInfosById(this.mAllIds);
}
@Override // androidx.work.WorkContinuation
@NonNull
public ListenableFuture getWorkInfos() {
return StatusRunnable.forStringIds(this.mWorkManagerImpl.getWorkDatabase(), this.mWorkManagerImpl.getWorkTaskExecutor(), this.mAllIds);
}
@Override // androidx.work.WorkContinuation
@NonNull
public Operation enqueue() {
if (!this.mEnqueued) {
this.mOperation = OperationKt.launchOperation(this.mWorkManagerImpl.getConfiguration().getTracer(), "EnqueueRunnable_" + getExistingWorkPolicy().name(), this.mWorkManagerImpl.getWorkTaskExecutor().getSerialTaskExecutor(), new Function0() { // from class: androidx.work.impl.WorkContinuationImpl$$ExternalSyntheticLambda0
@Override // kotlin.jvm.functions.Function0
public final Object invoke() {
Unit lambda$enqueue$0;
lambda$enqueue$0 = WorkContinuationImpl.this.lambda$enqueue$0();
return lambda$enqueue$0;
}
});
} else {
Logger.get().warning(TAG, "Already enqueued work ids (" + TextUtils.join(", ", this.mIds) + ")");
}
return this.mOperation;
}
/* JADX INFO: Access modifiers changed from: private */
public /* synthetic */ Unit lambda$enqueue$0() {
EnqueueRunnable.enqueue(this);
return Unit.INSTANCE;
}
@Override // androidx.work.WorkContinuation
@NonNull
public WorkContinuation combineInternal(@NonNull List<WorkContinuation> list) {
OneTimeWorkRequest build = new OneTimeWorkRequest.Builder((Class<? extends ListenableWorker>) CombineContinuationsWorker.class).setInputMerger(ArrayCreatingInputMerger.class).build();
ArrayList arrayList = new ArrayList(list.size());
Iterator<WorkContinuation> it = list.iterator();
while (it.hasNext()) {
arrayList.add((WorkContinuationImpl) it.next());
}
return new WorkContinuationImpl(this.mWorkManagerImpl, null, ExistingWorkPolicy.KEEP, Collections.singletonList(build), arrayList);
}
@RestrictTo({RestrictTo.Scope.LIBRARY_GROUP})
public boolean hasCycles() {
return hasCycles(this, new HashSet());
}
@RestrictTo({RestrictTo.Scope.LIBRARY_GROUP})
private static boolean hasCycles(@NonNull WorkContinuationImpl workContinuationImpl, @NonNull Set<String> set) {
set.addAll(workContinuationImpl.getIds());
Set<String> prerequisitesFor = prerequisitesFor(workContinuationImpl);
Iterator<String> it = set.iterator();
while (it.hasNext()) {
if (prerequisitesFor.contains(it.next())) {
return true;
}
}
List<WorkContinuationImpl> parents = workContinuationImpl.getParents();
if (parents != null && !parents.isEmpty()) {
Iterator<WorkContinuationImpl> it2 = parents.iterator();
while (it2.hasNext()) {
if (hasCycles(it2.next(), set)) {
return true;
}
}
}
set.removeAll(workContinuationImpl.getIds());
return false;
}
@NonNull
@RestrictTo({RestrictTo.Scope.LIBRARY_GROUP})
public static Set<String> prerequisitesFor(@NonNull WorkContinuationImpl workContinuationImpl) {
HashSet hashSet = new HashSet();
List<WorkContinuationImpl> parents = workContinuationImpl.getParents();
if (parents != null && !parents.isEmpty()) {
Iterator<WorkContinuationImpl> it = parents.iterator();
while (it.hasNext()) {
hashSet.addAll(it.next().getIds());
}
}
return hashSet;
}
}