CrackMe.apk
Download file
package androidx.lifecycle;
import java.util.ArrayDeque;
import java.util.Queue;
import kotlin.Metadata;
import kotlin.coroutines.CoroutineContext;
import kotlin.jvm.internal.Intrinsics;
import kotlinx.coroutines.Dispatchers;
import kotlinx.coroutines.MainCoroutineDispatcher;
@Metadata(bv = {1, 0, 3}, d1 = {"\u0000.\n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0002\b\u0003\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0007\b\u0000\u0018\u00002\u00020\u0001B\u0005¢\u0006\u0002\u0010\u0002J\b\u0010\n\u001a\u00020\u0004H\u0007J\u0018\u0010\u000b\u001a\u00020\f2\u0006\u0010\r\u001a\u00020\u000e2\u0006\u0010\u000f\u001a\u00020\tH\u0007J\b\u0010\u0010\u001a\u00020\fH\u0007J\u0010\u0010\u0011\u001a\u00020\f2\u0006\u0010\u000f\u001a\u00020\tH\u0003J\b\u0010\u0012\u001a\u00020\fH\u0007J\b\u0010\u0013\u001a\u00020\fH\u0007J\b\u0010\u0014\u001a\u00020\fH\u0007R\u000e\u0010\u0003\u001a\u00020\u0004X\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0004X\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\u0006\u001a\u00020\u0004X\u000e¢\u0006\u0002\n\u0000R\u0014\u0010\u0007\u001a\b\u0012\u0004\u0012\u00020\t0\bX\u0004¢\u0006\u0002\n\u0000¨\u0006\u0015"}, d2 = {"Landroidx/lifecycle/DispatchQueue;", "", "()V", "finished", "", "isDraining", "paused", "queue", "Ljava/util/Queue;", "Ljava/lang/Runnable;", "canRun", "dispatchAndEnqueue", "", "context", "Lkotlin/coroutines/CoroutineContext;", "runnable", "drainQueue", "enqueue", "finish", "pause", "resume", "lifecycle-runtime-ktx_release"}, k = 1, mv = {1, 4, 1})
/* compiled from: DispatchQueue.kt */
public final class DispatchQueue {
private boolean finished;
private boolean isDraining;
private boolean paused = true;
private final Queue<Runnable> queue = new ArrayDeque();
public final void pause() {
this.paused = true;
}
public final void resume() {
if (this.paused) {
if (!this.finished) {
this.paused = false;
drainQueue();
return;
}
throw new IllegalStateException("Cannot resume a finished dispatcher".toString());
}
}
public final void finish() {
this.finished = true;
drainQueue();
}
public final void drainQueue() {
if (!this.isDraining) {
boolean z = false;
z = true;
try {
while (true) {
if (!(this.queue.isEmpty() ^ z)) {
break;
} else if (!canRun()) {
break;
} else {
Runnable poll = this.queue.poll();
if (poll != null) {
poll.run();
}
}
}
this.isDraining = z;
} finally {
this.isDraining = z;
}
}
}
public final boolean canRun() {
return this.finished || !this.paused;
}
public final void dispatchAndEnqueue(CoroutineContext coroutineContext, Runnable runnable) {
Intrinsics.checkNotNullParameter(coroutineContext, "context");
Intrinsics.checkNotNullParameter(runnable, "runnable");
MainCoroutineDispatcher immediate = Dispatchers.getMain().getImmediate();
if (immediate.isDispatchNeeded(coroutineContext) || canRun()) {
immediate.dispatch(coroutineContext, new DispatchQueue$dispatchAndEnqueue$$inlined$with$lambda$1(this, coroutineContext, runnable));
} else {
enqueue(runnable);
}
}
/* access modifiers changed from: private */
public final void enqueue(Runnable runnable) {
if (this.queue.offer(runnable)) {
drainQueue();
return;
}
throw new IllegalStateException("cannot enqueue any more runnables".toString());
}
}
Download file