Rabbit-R1/switch port/java/sources/okio/AsyncTimeout.java

388 lines
18 KiB
Java
Raw Permalink Normal View History

2024-05-21 21:08:36 +00:00
package okio;
import androidx.exifinterface.media.ExifInterface;
import io.sentry.ProfilingTraceData;
import io.sentry.protocol.TransactionInfo;
import java.io.IOException;
import java.io.InterruptedIOException;
import java.util.concurrent.TimeUnit;
import kotlin.Metadata;
import kotlin.Unit;
import kotlin.jvm.functions.Function0;
import kotlin.jvm.internal.DefaultConstructorMarker;
import kotlin.jvm.internal.InlineMarker;
import kotlin.jvm.internal.Intrinsics;
/* compiled from: AsyncTimeout.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u0000@\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0002\b\u0002\n\u0002\u0010\t\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u0002\n\u0002\b\u0005\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0004\n\u0002\u0018\u0002\n\u0002\b\u0004\b\u0016\u0018\u0000 \u001b2\u00020\u0001:\u0002\u001b\u001cB\u0005¢\u0006\u0002\u0010\u0002J\u0012\u0010\b\u001a\u00020\t2\b\u0010\n\u001a\u0004\u0018\u00010\tH\u0001J\u0006\u0010\u000b\u001a\u00020\fJ\u0006\u0010\r\u001a\u00020\u0004J\u0012\u0010\u000e\u001a\u00020\t2\b\u0010\n\u001a\u0004\u0018\u00010\tH\u0014J\u0010\u0010\u000f\u001a\u00020\u00072\u0006\u0010\u0010\u001a\u00020\u0007H\u0002J\u000e\u0010\u0011\u001a\u00020\u00122\u0006\u0010\u0011\u001a\u00020\u0012J\u000e\u0010\u0013\u001a\u00020\u00142\u0006\u0010\u0013\u001a\u00020\u0014J\b\u0010\u0015\u001a\u00020\fH\u0014J%\u0010\u0016\u001a\u0002H\u0017\"\u0004\b\u0000\u0010\u00172\f\u0010\u0018\u001a\b\u0012\u0004\u0012\u0002H\u00170\u0019H\u0086\\u0001\u0000¢\u0006\u0002\u0010\u001aR\u000e\u0010\u0003\u001a\u00020\u0004X\u0082\u000e¢\u0006\u0002\n\u0000R\u0010\u0010\u0005\u001a\u0004\u0018\u00010\u0000X\u0082\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\u0006\u001a\u00020\u0007X\u0082\u000e¢\u0006\u0002\n\u0000\u0082\u0002\u0007\n\u0005\b\u009920\u0001¨\u0006\u001d"}, d2 = {"Lokio/AsyncTimeout;", "Lokio/Timeout;", "()V", "inQueue", "", "next", "timeoutAt", "", "access$newTimeoutException", "Ljava/io/IOException;", "cause", "enter", "", "exit", "newTimeoutException", "remainingNanos", "now", "sink", "Lokio/Sink;", TransactionInfo.JsonKeys.SOURCE, "Lokio/Source;", "timedOut", "withTimeout", ExifInterface.GPS_DIRECTION_TRUE, "block", "Lkotlin/Function0;", "(Lkotlin/jvm/functions/Function0;)Ljava/lang/Object;", "Companion", "Watchdog", "okio"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public class AsyncTimeout extends Timeout {
/* renamed from: Companion, reason: from kotlin metadata */
public static final Companion INSTANCE = new Companion(null);
private static final long IDLE_TIMEOUT_MILLIS;
private static final long IDLE_TIMEOUT_NANOS;
private static final int TIMEOUT_WRITE_SIZE = 65536;
private static AsyncTimeout head;
private boolean inQueue;
private AsyncTimeout next;
private long timeoutAt;
/* JADX INFO: Access modifiers changed from: private */
public final long remainingNanos(long now) {
return this.timeoutAt - now;
}
protected void timedOut() {
}
public final void enter() {
if (!(!this.inQueue)) {
throw new IllegalStateException("Unbalanced enter/exit".toString());
}
long timeoutNanos = getTimeoutNanos();
boolean hasDeadline = getHasDeadline();
if (timeoutNanos != 0 || hasDeadline) {
this.inQueue = true;
INSTANCE.scheduleTimeout(this, timeoutNanos, hasDeadline);
}
}
public final boolean exit() {
if (!this.inQueue) {
return false;
}
this.inQueue = false;
return INSTANCE.cancelScheduledTimeout(this);
}
public final Sink sink(final Sink sink) {
Intrinsics.checkNotNullParameter(sink, "sink");
return new Sink() { // from class: okio.AsyncTimeout$sink$1
@Override // okio.Sink
/* renamed from: timeout, reason: from getter */
public AsyncTimeout getThis$0() {
return AsyncTimeout.this;
}
@Override // okio.Sink
public void write(Buffer source, long byteCount) {
Intrinsics.checkNotNullParameter(source, "source");
Util.checkOffsetAndCount(source.size(), 0L, byteCount);
while (true) {
long j = 0;
if (byteCount <= 0) {
return;
}
Segment segment = source.head;
Intrinsics.checkNotNull(segment);
while (true) {
if (j >= 65536) {
break;
}
j += segment.limit - segment.pos;
if (j >= byteCount) {
j = byteCount;
break;
} else {
segment = segment.next;
Intrinsics.checkNotNull(segment);
}
}
AsyncTimeout asyncTimeout = AsyncTimeout.this;
asyncTimeout.enter();
try {
sink.write(source, j);
Unit unit = Unit.INSTANCE;
if (asyncTimeout.exit()) {
throw asyncTimeout.access$newTimeoutException(null);
}
byteCount -= j;
} catch (IOException e) {
e = e;
if (asyncTimeout.exit()) {
e = asyncTimeout.access$newTimeoutException(e);
}
throw e;
} finally {
asyncTimeout.exit();
}
}
}
public String toString() {
return "AsyncTimeout.sink(" + sink + ')';
}
@Override // okio.Sink, java.io.Flushable
public void flush() {
AsyncTimeout asyncTimeout = AsyncTimeout.this;
asyncTimeout.enter();
try {
sink.flush();
Unit unit = Unit.INSTANCE;
if (asyncTimeout.exit()) {
throw asyncTimeout.access$newTimeoutException(null);
}
} catch (IOException e) {
e = e;
if (asyncTimeout.exit()) {
e = asyncTimeout.access$newTimeoutException(e);
}
throw e;
} finally {
asyncTimeout.exit();
}
}
@Override // okio.Sink, java.io.Closeable, java.lang.AutoCloseable
public void close() {
AsyncTimeout asyncTimeout = AsyncTimeout.this;
asyncTimeout.enter();
try {
sink.close();
Unit unit = Unit.INSTANCE;
if (asyncTimeout.exit()) {
throw asyncTimeout.access$newTimeoutException(null);
}
} catch (IOException e) {
e = e;
if (asyncTimeout.exit()) {
e = asyncTimeout.access$newTimeoutException(e);
}
throw e;
} finally {
asyncTimeout.exit();
}
}
};
}
public final Source source(final Source source) {
Intrinsics.checkNotNullParameter(source, "source");
return new Source() { // from class: okio.AsyncTimeout$source$1
@Override // okio.Source
/* renamed from: timeout, reason: from getter */
public AsyncTimeout getThis$0() {
return AsyncTimeout.this;
}
public String toString() {
return "AsyncTimeout.source(" + source + ')';
}
@Override // okio.Source
public long read(Buffer sink, long byteCount) {
Intrinsics.checkNotNullParameter(sink, "sink");
AsyncTimeout asyncTimeout = AsyncTimeout.this;
asyncTimeout.enter();
try {
long read = source.read(sink, byteCount);
if (asyncTimeout.exit()) {
throw asyncTimeout.access$newTimeoutException(null);
}
return read;
} catch (IOException e) {
e = e;
if (asyncTimeout.exit()) {
e = asyncTimeout.access$newTimeoutException(e);
}
throw e;
} finally {
asyncTimeout.exit();
}
}
@Override // okio.Source, java.io.Closeable, java.lang.AutoCloseable
public void close() {
AsyncTimeout asyncTimeout = AsyncTimeout.this;
asyncTimeout.enter();
try {
source.close();
Unit unit = Unit.INSTANCE;
if (asyncTimeout.exit()) {
throw asyncTimeout.access$newTimeoutException(null);
}
} catch (IOException e) {
e = e;
if (asyncTimeout.exit()) {
e = asyncTimeout.access$newTimeoutException(e);
}
throw e;
} finally {
asyncTimeout.exit();
}
}
};
}
public final <T> T withTimeout(Function0<? extends T> block) {
Intrinsics.checkNotNullParameter(block, "block");
enter();
try {
try {
T invoke = block.invoke();
InlineMarker.finallyStart(1);
if (exit()) {
throw access$newTimeoutException(null);
}
InlineMarker.finallyEnd(1);
return invoke;
} catch (IOException e) {
e = e;
if (exit()) {
e = access$newTimeoutException(e);
}
throw e;
}
} catch (Throwable th) {
InlineMarker.finallyStart(1);
exit();
InlineMarker.finallyEnd(1);
throw th;
}
}
public final IOException access$newTimeoutException(IOException cause) {
return newTimeoutException(cause);
}
protected IOException newTimeoutException(IOException cause) {
InterruptedIOException interruptedIOException = new InterruptedIOException(ProfilingTraceData.TRUNCATION_REASON_TIMEOUT);
if (cause != null) {
interruptedIOException.initCause(cause);
}
return interruptedIOException;
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: AsyncTimeout.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u0000\u0012\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u0002\n\u0000\b\u0002\u0018\u00002\u00020\u0001B\u0007\b\u0000¢\u0006\u0002\u0010\u0002J\b\u0010\u0003\u001a\u00020\u0004H\u0016¨\u0006\u0005"}, d2 = {"Lokio/AsyncTimeout$Watchdog;", "Ljava/lang/Thread;", "()V", "run", "", "okio"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public static final class Watchdog extends Thread {
public Watchdog() {
super("Okio Watchdog");
setDaemon(true);
}
@Override // java.lang.Thread, java.lang.Runnable
public void run() {
AsyncTimeout awaitTimeout$okio;
while (true) {
try {
synchronized (AsyncTimeout.class) {
awaitTimeout$okio = AsyncTimeout.INSTANCE.awaitTimeout$okio();
if (awaitTimeout$okio == AsyncTimeout.head) {
AsyncTimeout.head = null;
return;
}
Unit unit = Unit.INSTANCE;
}
if (awaitTimeout$okio != null) {
awaitTimeout$okio.timedOut();
}
} catch (InterruptedException unused) {
continue;
}
}
}
}
/* compiled from: AsyncTimeout.kt */
@Metadata(bv = {1, 0, 3}, d1 = {"\u00002\n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0002\b\u0002\n\u0002\u0010\t\n\u0002\b\u0002\n\u0002\u0010\b\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0003\n\u0002\u0010\u000b\n\u0002\b\u0002\n\u0002\u0010\u0002\n\u0002\b\u0003\b\u0086\u0003\u0018\u00002\u00020\u0001B\u0007\b\u0002¢\u0006\u0002\u0010\u0002J\u000f\u0010\n\u001a\u0004\u0018\u00010\tH\u0000¢\u0006\u0002\b\u000bJ\u0010\u0010\f\u001a\u00020\r2\u0006\u0010\u000e\u001a\u00020\tH\u0002J \u0010\u000f\u001a\u00020\u00102\u0006\u0010\u000e\u001a\u00020\t2\u0006\u0010\u0011\u001a\u00020\u00042\u0006\u0010\u0012\u001a\u00020\rH\u0002R\u000e\u0010\u0003\u001a\u00020\u0004X\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0004X\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\u0006\u001a\u00020\u0007X\u0082T¢\u0006\u0002\n\u0000R\u0010\u0010\b\u001a\u0004\u0018\u00010\tX\u0082\u000e¢\u0006\u0002\n\u0000¨\u0006\u0013"}, d2 = {"Lokio/AsyncTimeout$Companion;", "", "()V", "IDLE_TIMEOUT_MILLIS", "", "IDLE_TIMEOUT_NANOS", "TIMEOUT_WRITE_SIZE", "", "head", "Lokio/AsyncTimeout;", "awaitTimeout", "awaitTimeout$okio", "cancelScheduledTimeout", "", "node", "scheduleTimeout", "", "timeoutNanos", "hasDeadline", "okio"}, k = 1, mv = {1, 4, 0})
/* loaded from: classes3.dex */
public static final class Companion {
private Companion() {
}
public /* synthetic */ Companion(DefaultConstructorMarker defaultConstructorMarker) {
this();
}
/* JADX INFO: Access modifiers changed from: private */
public final void scheduleTimeout(AsyncTimeout node, long timeoutNanos, boolean hasDeadline) {
synchronized (AsyncTimeout.class) {
if (AsyncTimeout.head == null) {
AsyncTimeout.head = new AsyncTimeout();
new Watchdog().start();
}
long nanoTime = System.nanoTime();
if (timeoutNanos != 0 && hasDeadline) {
node.timeoutAt = Math.min(timeoutNanos, node.deadlineNanoTime() - nanoTime) + nanoTime;
} else if (timeoutNanos != 0) {
node.timeoutAt = timeoutNanos + nanoTime;
} else if (hasDeadline) {
node.timeoutAt = node.deadlineNanoTime();
} else {
throw new AssertionError();
}
long remainingNanos = node.remainingNanos(nanoTime);
AsyncTimeout asyncTimeout = AsyncTimeout.head;
Intrinsics.checkNotNull(asyncTimeout);
while (asyncTimeout.next != null) {
AsyncTimeout asyncTimeout2 = asyncTimeout.next;
Intrinsics.checkNotNull(asyncTimeout2);
if (remainingNanos < asyncTimeout2.remainingNanos(nanoTime)) {
break;
}
asyncTimeout = asyncTimeout.next;
Intrinsics.checkNotNull(asyncTimeout);
}
node.next = asyncTimeout.next;
asyncTimeout.next = node;
if (asyncTimeout == AsyncTimeout.head) {
AsyncTimeout.class.notify();
}
Unit unit = Unit.INSTANCE;
}
}
/* JADX INFO: Access modifiers changed from: private */
public final boolean cancelScheduledTimeout(AsyncTimeout node) {
synchronized (AsyncTimeout.class) {
for (AsyncTimeout asyncTimeout = AsyncTimeout.head; asyncTimeout != null; asyncTimeout = asyncTimeout.next) {
if (asyncTimeout.next == node) {
asyncTimeout.next = node.next;
node.next = null;
return false;
}
}
return true;
}
}
public final AsyncTimeout awaitTimeout$okio() throws InterruptedException {
AsyncTimeout asyncTimeout = AsyncTimeout.head;
Intrinsics.checkNotNull(asyncTimeout);
AsyncTimeout asyncTimeout2 = asyncTimeout.next;
if (asyncTimeout2 != null) {
long remainingNanos = asyncTimeout2.remainingNanos(System.nanoTime());
if (remainingNanos > 0) {
long j = remainingNanos / 1000000;
AsyncTimeout.class.wait(j, (int) (remainingNanos - (1000000 * j)));
return null;
}
AsyncTimeout asyncTimeout3 = AsyncTimeout.head;
Intrinsics.checkNotNull(asyncTimeout3);
asyncTimeout3.next = asyncTimeout2.next;
asyncTimeout2.next = null;
return asyncTimeout2;
}
long nanoTime = System.nanoTime();
AsyncTimeout.class.wait(AsyncTimeout.IDLE_TIMEOUT_MILLIS);
AsyncTimeout asyncTimeout4 = AsyncTimeout.head;
Intrinsics.checkNotNull(asyncTimeout4);
if (asyncTimeout4.next != null || System.nanoTime() - nanoTime < AsyncTimeout.IDLE_TIMEOUT_NANOS) {
return null;
}
return AsyncTimeout.head;
}
}
static {
long millis = TimeUnit.SECONDS.toMillis(60L);
IDLE_TIMEOUT_MILLIS = millis;
IDLE_TIMEOUT_NANOS = TimeUnit.MILLISECONDS.toNanos(millis);
}
}