RealWebSocket.smali
.class public final Lokhttp3/internal/ws/RealWebSocket;
.super Ljava/lang/Object;
.source "RealWebSocket.kt"
# interfaces
.implements Lokhttp3/WebSocket;
.implements Lokhttp3/internal/ws/WebSocketReader$FrameCallback;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lokhttp3/internal/ws/RealWebSocket$Message;,
Lokhttp3/internal/ws/RealWebSocket$Close;,
Lokhttp3/internal/ws/RealWebSocket$Streams;,
Lokhttp3/internal/ws/RealWebSocket$WriterTask;,
Lokhttp3/internal/ws/RealWebSocket$Companion;
}
.end annotation
.annotation system Ldalvik/annotation/SourceDebugExtension;
value = "SMAP\nRealWebSocket.kt\nKotlin\n*S Kotlin\n*F\n+ 1 RealWebSocket.kt\nokhttp3/internal/ws/RealWebSocket\n+ 2 TaskQueue.kt\nokhttp3/internal/concurrent/TaskQueue\n+ 3 Util.kt\nokhttp3/internal/Util\n*L\n1#1,570:1\n83#2,4:571\n92#2,10:579\n537#3,4:575\n*E\n*S KotlinDebug\n*F\n+ 1 RealWebSocket.kt\nokhttp3/internal/ws/RealWebSocket\n*L\n215#1,4:571\n426#1,10:579\n396#1,4:575\n*E\n"
.end annotation
.annotation runtime Lkotlin/Metadata;
bv = {
0x1,
0x0,
0x3
}
d1 = {
"\u0000\u00b0\u0001\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\t\n\u0002\u0008\u0002\n\u0002\u0010\u000b\n\u0000\n\u0002\u0018\u0002\n\u0002\u0008\u0003\n\u0002\u0010\u000e\n\u0002\u0008\u0003\n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0008\n\u0002\u0008\u0005\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0002\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0002\u0008\u0003\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\u0008\u0007\n\u0002\u0018\u0002\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0008\u001b\u0018\u0000 \\2\u00020\u00012\u00020\u0002:\u0005[\\]^_B-\u0012\u0006\u0010\u0003\u001a\u00020\u0004\u0012\u0006\u0010\u0005\u001a\u00020\u0006\u0012\u0006\u0010\u0007\u001a\u00020\u0008\u0012\u0006\u0010\t\u001a\u00020\n\u0012\u0006\u0010\u000b\u001a\u00020\u000c\u00a2\u0006\u0002\u0010\rJ\u0016\u0010/\u001a\u0002002\u0006\u00101\u001a\u00020\u000c2\u0006\u00102\u001a\u000203J\u0008\u00104\u001a\u000200H\u0016J\u001f\u00105\u001a\u0002002\u0006\u00106\u001a\u0002072\u0008\u00108\u001a\u0004\u0018\u000109H\u0000\u00a2\u0006\u0002\u0008:J\u001a\u0010;\u001a\u00020\u000f2\u0006\u0010<\u001a\u00020\"2\u0008\u0010=\u001a\u0004\u0018\u00010\u0015H\u0016J \u0010;\u001a\u00020\u000f2\u0006\u0010<\u001a\u00020\"2\u0008\u0010=\u001a\u0004\u0018\u00010\u00152\u0006\u0010>\u001a\u00020\u000cJ\u000e\u0010?\u001a\u0002002\u0006\u0010@\u001a\u00020AJ\u001c\u0010B\u001a\u0002002\n\u0010C\u001a\u00060Dj\u0002`E2\u0008\u00106\u001a\u0004\u0018\u000107J\u0016\u0010F\u001a\u0002002\u0006\u0010\u001b\u001a\u00020\u00152\u0006\u0010\'\u001a\u00020(J\u0006\u0010G\u001a\u000200J\u0018\u0010H\u001a\u0002002\u0006\u0010<\u001a\u00020\"2\u0006\u0010=\u001a\u00020\u0015H\u0016J\u0010\u0010I\u001a\u0002002\u0006\u0010J\u001a\u00020\u0015H\u0016J\u0010\u0010I\u001a\u0002002\u0006\u0010K\u001a\u00020\u001dH\u0016J\u0010\u0010L\u001a\u0002002\u0006\u0010M\u001a\u00020\u001dH\u0016J\u0010\u0010N\u001a\u0002002\u0006\u0010M\u001a\u00020\u001dH\u0016J\u000e\u0010O\u001a\u00020\u000f2\u0006\u0010M\u001a\u00020\u001dJ\u0006\u0010P\u001a\u00020\u000fJ\u0008\u0010\u001e\u001a\u00020\u000cH\u0016J\u0006\u0010$\u001a\u00020\"J\u0006\u0010%\u001a\u00020\"J\u0008\u0010Q\u001a\u00020\u0006H\u0016J\u0008\u0010R\u001a\u000200H\u0002J\u0010\u0010S\u001a\u00020\u000f2\u0006\u0010J\u001a\u00020\u0015H\u0016J\u0010\u0010S\u001a\u00020\u000f2\u0006\u0010K\u001a\u00020\u001dH\u0016J\u0018\u0010S\u001a\u00020\u000f2\u0006\u0010T\u001a\u00020\u001d2\u0006\u0010U\u001a\u00020\"H\u0002J\u0006\u0010&\u001a\u00020\"J\u0006\u0010V\u001a\u000200J\r\u0010W\u001a\u00020\u000fH\u0000\u00a2\u0006\u0002\u0008XJ\r\u0010Y\u001a\u000200H\u0000\u00a2\u0006\u0002\u0008ZR\u000e\u0010\u000e\u001a\u00020\u000fX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010\u0010\u001a\u0004\u0018\u00010\u0011X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0012\u001a\u00020\u000fX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0013\u001a\u00020\u000fX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0014\u001a\u00020\u0015X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0014\u0010\u0007\u001a\u00020\u0008X\u0080\u0004\u00a2\u0006\u0008\n\u0000\u001a\u0004\u0008\u0016\u0010\u0017R\u0014\u0010\u0018\u001a\u0008\u0012\u0004\u0012\u00020\u001a0\u0019X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0010\u0010\u001b\u001a\u0004\u0018\u00010\u0015X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u000b\u001a\u00020\u000cX\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0014\u0010\u001c\u001a\u0008\u0012\u0004\u0012\u00020\u001d0\u0019X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u001e\u001a\u00020\u000cX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\t\u001a\u00020\nX\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0010\u0010\u001f\u001a\u0004\u0018\u00010 X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010!\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010#\u001a\u0004\u0018\u00010\u0015X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010$\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010%\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010&\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010\'\u001a\u0004\u0018\u00010(X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010)\u001a\u00020*X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010+\u001a\u0004\u0018\u00010,X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010-\u001a\u0004\u0018\u00010.X\u0082\u000e\u00a2\u0006\u0002\n\u0000\u00a8\u0006`"
}
d2 = {
"Lokhttp3/internal/ws/RealWebSocket;",
"Lokhttp3/WebSocket;",
"Lokhttp3/internal/ws/WebSocketReader$FrameCallback;",
"taskRunner",
"Lokhttp3/internal/concurrent/TaskRunner;",
"originalRequest",
"Lokhttp3/Request;",
"listener",
"Lokhttp3/WebSocketListener;",
"random",
"Ljava/util/Random;",
"pingIntervalMillis",
"",
"(Lokhttp3/internal/concurrent/TaskRunner;Lokhttp3/Request;Lokhttp3/WebSocketListener;Ljava/util/Random;J)V",
"awaitingPong",
"",
"call",
"Lokhttp3/Call;",
"enqueuedClose",
"failed",
"key",
"",
"getListener$okhttp",
"()Lokhttp3/WebSocketListener;",
"messageAndCloseQueue",
"Ljava/util/ArrayDeque;",
"",
"name",
"pongQueue",
"Lokio/ByteString;",
"queueSize",
"reader",
"Lokhttp3/internal/ws/WebSocketReader;",
"receivedCloseCode",
"",
"receivedCloseReason",
"receivedPingCount",
"receivedPongCount",
"sentPingCount",
"streams",
"Lokhttp3/internal/ws/RealWebSocket$Streams;",
"taskQueue",
"Lokhttp3/internal/concurrent/TaskQueue;",
"writer",
"Lokhttp3/internal/ws/WebSocketWriter;",
"writerTask",
"Lokhttp3/internal/concurrent/Task;",
"awaitTermination",
"",
"timeout",
"timeUnit",
"Ljava/util/concurrent/TimeUnit;",
"cancel",
"checkUpgradeSuccess",
"response",
"Lokhttp3/Response;",
"exchange",
"Lokhttp3/internal/connection/Exchange;",
"checkUpgradeSuccess$okhttp",
"close",
"code",
"reason",
"cancelAfterCloseMillis",
"connect",
"client",
"Lokhttp3/OkHttpClient;",
"failWebSocket",
"e",
"Ljava/lang/Exception;",
"Lkotlin/Exception;",
"initReaderAndWriter",
"loopReader",
"onReadClose",
"onReadMessage",
"text",
"bytes",
"onReadPing",
"payload",
"onReadPong",
"pong",
"processNextFrame",
"request",
"runWriter",
"send",
"data",
"formatOpcode",
"tearDown",
"writeOneFrame",
"writeOneFrame$okhttp",
"writePingFrame",
"writePingFrame$okhttp",
"Close",
"Companion",
"Message",
"Streams",
"WriterTask",
"okhttp"
}
k = 0x1
mv = {
0x1,
0x1,
0x10
}
.end annotation
# static fields
.field private static final CANCEL_AFTER_CLOSE_MILLIS:J = 0xea60L
.field public static final Companion:Lokhttp3/internal/ws/RealWebSocket$Companion;
.field private static final MAX_QUEUE_SIZE:J = 0x1000000L
.field private static final ONLY_HTTP1:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lokhttp3/Protocol;",
">;"
}
.end annotation
.end field
# instance fields
.field private awaitingPong:Z
.field private call:Lokhttp3/Call;
.field private enqueuedClose:Z
.field private failed:Z
.field private final key:Ljava/lang/String;
.field private final listener:Lokhttp3/WebSocketListener;
.field private final messageAndCloseQueue:Ljava/util/ArrayDeque;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayDeque<",
"Ljava/lang/Object;",
">;"
}
.end annotation
.end field
.field private name:Ljava/lang/String;
.field private final originalRequest:Lokhttp3/Request;
.field private final pingIntervalMillis:J
.field private final pongQueue:Ljava/util/ArrayDeque;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayDeque<",
"Lokio/ByteString;",
">;"
}
.end annotation
.end field
.field private queueSize:J
.field private final random:Ljava/util/Random;
.field private reader:Lokhttp3/internal/ws/WebSocketReader;
.field private receivedCloseCode:I
.field private receivedCloseReason:Ljava/lang/String;
.field private receivedPingCount:I
.field private receivedPongCount:I
.field private sentPingCount:I
.field private streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.field private taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
.field private writer:Lokhttp3/internal/ws/WebSocketWriter;
.field private writerTask:Lokhttp3/internal/concurrent/Task;
# direct methods
.method static constructor <clinit>()V
.registers 2
new-instance v0, Lokhttp3/internal/ws/RealWebSocket$Companion;
const/4 v1, 0x0
invoke-direct {v0, v1}, Lokhttp3/internal/ws/RealWebSocket$Companion;-><init>(Lkotlin/jvm/internal/DefaultConstructorMarker;)V
sput-object v0, Lokhttp3/internal/ws/RealWebSocket;->Companion:Lokhttp3/internal/ws/RealWebSocket$Companion;
.line 555
sget-object v0, Lokhttp3/Protocol;->HTTP_1_1:Lokhttp3/Protocol;
invoke-static {v0}, Lkotlin/collections/CollectionsKt;->listOf(Ljava/lang/Object;)Ljava/util/List;
move-result-object v0
sput-object v0, Lokhttp3/internal/ws/RealWebSocket;->ONLY_HTTP1:Ljava/util/List;
return-void
.end method
.method public constructor <init>(Lokhttp3/internal/concurrent/TaskRunner;Lokhttp3/Request;Lokhttp3/WebSocketListener;Ljava/util/Random;J)V
.registers 13
const-string v0, "taskRunner"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "originalRequest"
invoke-static {p2, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "listener"
invoke-static {p3, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "random"
invoke-static {p4, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 53
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request;
iput-object p3, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
iput-object p4, p0, Lokhttp3/internal/ws/RealWebSocket;->random:Ljava/util/Random;
iput-wide p5, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
.line 78
invoke-virtual {p1}, Lokhttp3/internal/concurrent/TaskRunner;->newQueue()Lokhttp3/internal/concurrent/TaskQueue;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
.line 91
new-instance p1, Ljava/util/ArrayDeque;
invoke-direct {p1}, Ljava/util/ArrayDeque;-><init>()V
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque;
.line 94
new-instance p1, Ljava/util/ArrayDeque;
invoke-direct {p1}, Ljava/util/ArrayDeque;-><init>()V
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
const/4 p1, -0x1
.line 103
iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
.line 124
iget-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request;
invoke-virtual {p1}, Lokhttp3/Request;->method()Ljava/lang/String;
move-result-object p1
const-string p2, "GET"
invoke-static {p2, p1}, Lkotlin/jvm/internal/Intrinsics;->areEqual(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_5e
.line 128
sget-object v0, Lokio/ByteString;->Companion:Lokio/ByteString$Companion;
const/16 p1, 0x10
new-array v1, p1, [B
iget-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->random:Ljava/util/Random;
invoke-virtual {p1, v1}, Ljava/util/Random;->nextBytes([B)V
const/4 v2, 0x0
const/4 v3, 0x0
const/4 v4, 0x3
const/4 v5, 0x0
invoke-static/range {v0 .. v5}, Lokio/ByteString$Companion;->of$default(Lokio/ByteString$Companion;[BIIILjava/lang/Object;)Lokio/ByteString;
move-result-object p1
invoke-virtual {p1}, Lokio/ByteString;->base64()Ljava/lang/String;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String;
return-void
.line 125
:cond_5e
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string p2, "Request must be GET: "
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request;
invoke-virtual {p2}, Lokhttp3/Request;->method()Ljava/lang/String;
move-result-object p2
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 124
new-instance p2, Ljava/lang/IllegalArgumentException;
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
check-cast p2, Ljava/lang/Throwable;
throw p2
.end method
.method public static final synthetic access$getName$p(Lokhttp3/internal/ws/RealWebSocket;)Ljava/lang/String;
.registers 1
.line 53
iget-object p0, p0, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String;
return-object p0
.end method
.method public static final synthetic access$setName$p(Lokhttp3/internal/ws/RealWebSocket;Ljava/lang/String;)V
.registers 2
.line 53
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String;
return-void
.end method
.method private final runWriter()V
.registers 8
.line 575
sget-boolean v0, Lokhttp3/internal/Util;->assertionsEnabled:Z
if-eqz v0, :cond_39
invoke-static {p0}, Ljava/lang/Thread;->holdsLock(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_b
goto :goto_39
.line 576
:cond_b
new-instance v0, Ljava/lang/AssertionError;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Thread "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
const-string v3, "Thread.currentThread()"
invoke-static {v2, v3}, Lkotlin/jvm/internal/Intrinsics;->checkExpressionValueIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " MUST hold lock on "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
check-cast v0, Ljava/lang/Throwable;
throw v0
.line 398
:cond_39
:goto_39
iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->writerTask:Lokhttp3/internal/concurrent/Task;
if-eqz v2, :cond_46
.line 400
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
const-wide/16 v3, 0x0
const/4 v5, 0x2
const/4 v6, 0x0
invoke-static/range {v1 .. v6}, Lokhttp3/internal/concurrent/TaskQueue;->schedule$default(Lokhttp3/internal/concurrent/TaskQueue;Lokhttp3/internal/concurrent/Task;JILjava/lang/Object;)V
:cond_46
return-void
.end method
.method private final declared-synchronized send(Lokio/ByteString;I)Z
.registers 9
monitor-enter p0
.line 341
:try_start_1
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
const/4 v1, 0x0
if-nez v0, :cond_3c
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz v0, :cond_b
goto :goto_3c
.line 344
:cond_b
iget-wide v2, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
invoke-virtual {p1}, Lokio/ByteString;->size()I
move-result v0
int-to-long v4, v0
add-long/2addr v2, v4
const-wide/32 v4, 0x1000000
cmp-long v0, v2, v4
if-lez v0, :cond_22
const/16 p1, 0x3e9
const/4 p2, 0x0
.line 345
invoke-virtual {p0, p1, p2}, Lokhttp3/internal/ws/RealWebSocket;->close(ILjava/lang/String;)Z
:try_end_20
.catchall {:try_start_1 .. :try_end_20} :catchall_3e
.line 346
monitor-exit p0
return v1
.line 350
:cond_22
:try_start_22
iget-wide v0, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
invoke-virtual {p1}, Lokio/ByteString;->size()I
move-result v2
int-to-long v2, v2
add-long/2addr v0, v2
iput-wide v0, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
.line 351
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
new-instance v1, Lokhttp3/internal/ws/RealWebSocket$Message;
invoke-direct {v1, p2, p1}, Lokhttp3/internal/ws/RealWebSocket$Message;-><init>(ILokio/ByteString;)V
invoke-virtual {v0, v1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
.line 352
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
:try_end_39
.catchall {:try_start_22 .. :try_end_39} :catchall_3e
const/4 p1, 0x1
.line 353
monitor-exit p0
return p1
.line 341
:cond_3c
:goto_3c
monitor-exit p0
return v1
:catchall_3e
move-exception p1
monitor-exit p0
throw p1
.end method
# virtual methods
.method public final awaitTermination(JLjava/util/concurrent/TimeUnit;)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/InterruptedException;
}
.end annotation
const-string v0, "timeUnit"
invoke-static {p3, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 262
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskQueue;->idleLatch()Ljava/util/concurrent/CountDownLatch;
move-result-object v0
invoke-virtual {v0, p1, p2, p3}, Ljava/util/concurrent/CountDownLatch;->await(JLjava/util/concurrent/TimeUnit;)Z
return-void
.end method
.method public cancel()V
.registers 2
.line 136
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->call:Lokhttp3/Call;
if-nez v0, :cond_7
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_7
invoke-interface {v0}, Lokhttp3/Call;->cancel()V
return-void
.end method
.method public final checkUpgradeSuccess$okhttp(Lokhttp3/Response;Lokhttp3/internal/connection/Exchange;)V
.registers 10
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const-string v0, "response"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 184
invoke-virtual {p1}, Lokhttp3/Response;->code()I
move-result v0
const/16 v1, 0x27
const/16 v2, 0x65
if-ne v0, v2, :cond_c4
const-string v0, "Connection"
const/4 v2, 0x0
const/4 v3, 0x2
.line 189
invoke-static {p1, v0, v2, v3, v2}, Lokhttp3/Response;->header$default(Lokhttp3/Response;Ljava/lang/String;Ljava/lang/String;ILjava/lang/Object;)Ljava/lang/String;
move-result-object v0
const-string v4, "Upgrade"
const/4 v5, 0x1
.line 190
invoke-static {v4, v0, v5}, Lkotlin/text/StringsKt;->equals(Ljava/lang/String;Ljava/lang/String;Z)Z
move-result v6
if-eqz v6, :cond_a8
.line 195
invoke-static {p1, v4, v2, v3, v2}, Lokhttp3/Response;->header$default(Lokhttp3/Response;Ljava/lang/String;Ljava/lang/String;ILjava/lang/Object;)Ljava/lang/String;
move-result-object v0
const-string/jumbo v4, "websocket"
.line 196
invoke-static {v4, v0, v5}, Lkotlin/text/StringsKt;->equals(Ljava/lang/String;Ljava/lang/String;Z)Z
move-result v4
if-eqz v4, :cond_8c
const-string v0, "Sec-WebSocket-Accept"
.line 201
invoke-static {p1, v0, v2, v3, v2}, Lokhttp3/Response;->header$default(Lokhttp3/Response;Ljava/lang/String;Ljava/lang/String;ILjava/lang/Object;)Ljava/lang/String;
move-result-object p1
.line 202
sget-object v0, Lokio/ByteString;->Companion:Lokio/ByteString$Companion;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
iget-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "258EAFA5-E914-47DA-95CA-C5AB0DC85B11"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v2}, Lokio/ByteString$Companion;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object v0
invoke-virtual {v0}, Lokio/ByteString;->sha1()Lokio/ByteString;
move-result-object v0
invoke-virtual {v0}, Lokio/ByteString;->base64()Ljava/lang/String;
move-result-object v0
.line 203
invoke-static {v0, p1}, Lkotlin/jvm/internal/Intrinsics;->areEqual(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v2
xor-int/2addr v2, v5
if-nez v2, :cond_68
if-eqz p2, :cond_5e
return-void
.line 209
:cond_5e
new-instance p1, Ljava/net/ProtocolException;
const-string p2, "Web Socket exchange missing: bad interceptor?"
invoke-direct {p1, p2}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
check-cast p1, Ljava/lang/Throwable;
throw p1
.line 204
:cond_68
new-instance p2, Ljava/net/ProtocolException;
.line 205
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Expected \'Sec-WebSocket-Accept\' header value \'"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "\' but was \'"
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 204
invoke-direct {p2, p1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
check-cast p2, Ljava/lang/Throwable;
throw p2
.line 197
:cond_8c
new-instance p1, Ljava/net/ProtocolException;
.line 198
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Expected \'Upgrade\' header value \'websocket\' but was \'"
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
.line 197
invoke-direct {p1, p2}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
check-cast p1, Ljava/lang/Throwable;
throw p1
.line 191
:cond_a8
new-instance p1, Ljava/net/ProtocolException;
.line 192
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Expected \'Connection\' header value \'Upgrade\' but was \'"
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
.line 191
invoke-direct {p1, p2}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
check-cast p1, Ljava/lang/Throwable;
throw p1
.line 185
:cond_c4
new-instance p2, Ljava/net/ProtocolException;
.line 186
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Expected HTTP 101 response but was \'"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lokhttp3/Response;->code()I
move-result v2
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const/16 v2, 0x20
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lokhttp3/Response;->message()Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 185
invoke-direct {p2, p1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
check-cast p2, Ljava/lang/Throwable;
throw p2
.end method
.method public close(ILjava/lang/String;)Z
.registers 5
const-wide/32 v0, 0xea60
.line 366
invoke-virtual {p0, p1, p2, v0, v1}, Lokhttp3/internal/ws/RealWebSocket;->close(ILjava/lang/String;J)Z
move-result p1
return p1
.end method
.method public final declared-synchronized close(ILjava/lang/String;J)Z
.registers 13
monitor-enter p0
.line 374
:try_start_1
sget-object v0, Lokhttp3/internal/ws/WebSocketProtocol;->INSTANCE:Lokhttp3/internal/ws/WebSocketProtocol;
invoke-virtual {v0, p1}, Lokhttp3/internal/ws/WebSocketProtocol;->validateCloseCode(I)V
const/4 v0, 0x0
.line 376
check-cast v0, Lokio/ByteString;
const/4 v1, 0x0
const/4 v2, 0x1
if-eqz p2, :cond_41
.line 378
sget-object v0, Lokio/ByteString;->Companion:Lokio/ByteString$Companion;
invoke-virtual {v0, p2}, Lokio/ByteString$Companion;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object v0
.line 379
invoke-virtual {v0}, Lokio/ByteString;->size()I
move-result v3
int-to-long v3, v3
const-wide/16 v5, 0x7b
cmp-long v7, v3, v5
if-gtz v7, :cond_20
const/4 v3, 0x1
goto :goto_21
:cond_20
const/4 v3, 0x0
:goto_21
if-eqz v3, :cond_24
goto :goto_41
.line 380
:cond_24
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "reason.size() > 123: "
invoke-virtual {p1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 379
new-instance p2, Ljava/lang/IllegalArgumentException;
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
check-cast p2, Ljava/lang/Throwable;
throw p2
.line 384
:cond_41
:goto_41
iget-boolean p2, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-nez p2, :cond_5b
iget-boolean p2, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz p2, :cond_4a
goto :goto_5b
.line 387
:cond_4a
iput-boolean v2, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
.line 390
iget-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
new-instance v1, Lokhttp3/internal/ws/RealWebSocket$Close;
invoke-direct {v1, p1, v0, p3, p4}, Lokhttp3/internal/ws/RealWebSocket$Close;-><init>(ILokio/ByteString;J)V
invoke-virtual {p2, v1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
.line 391
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
:try_end_59
.catchall {:try_start_1 .. :try_end_59} :catchall_5d
.line 392
monitor-exit p0
return v2
.line 384
:cond_5b
:goto_5b
monitor-exit p0
return v1
:catchall_5d
move-exception p1
monitor-exit p0
throw p1
.end method
.method public final connect(Lokhttp3/OkHttpClient;)V
.registers 5
const-string v0, "client"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 140
invoke-virtual {p1}, Lokhttp3/OkHttpClient;->newBuilder()Lokhttp3/OkHttpClient$Builder;
move-result-object p1
.line 141
sget-object v0, Lokhttp3/EventListener;->NONE:Lokhttp3/EventListener;
invoke-virtual {p1, v0}, Lokhttp3/OkHttpClient$Builder;->eventListener(Lokhttp3/EventListener;)Lokhttp3/OkHttpClient$Builder;
move-result-object p1
.line 142
sget-object v0, Lokhttp3/internal/ws/RealWebSocket;->ONLY_HTTP1:Ljava/util/List;
invoke-virtual {p1, v0}, Lokhttp3/OkHttpClient$Builder;->protocols(Ljava/util/List;)Lokhttp3/OkHttpClient$Builder;
move-result-object p1
.line 143
invoke-virtual {p1}, Lokhttp3/OkHttpClient$Builder;->build()Lokhttp3/OkHttpClient;
move-result-object p1
.line 144
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request;
invoke-virtual {v0}, Lokhttp3/Request;->newBuilder()Lokhttp3/Request$Builder;
move-result-object v0
const-string v1, "Upgrade"
const-string/jumbo v2, "websocket"
.line 145
invoke-virtual {v0, v1, v2}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
const-string v2, "Connection"
.line 146
invoke-virtual {v0, v2, v1}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
.line 147
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String;
const-string v2, "Sec-WebSocket-Key"
invoke-virtual {v0, v2, v1}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
const-string v1, "Sec-WebSocket-Version"
const-string v2, "13"
.line 148
invoke-virtual {v0, v1, v2}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
.line 149
invoke-virtual {v0}, Lokhttp3/Request$Builder;->build()Lokhttp3/Request;
move-result-object v0
.line 150
sget-object v1, Lokhttp3/RealCall;->Companion:Lokhttp3/RealCall$Companion;
const/4 v2, 0x1
invoke-virtual {v1, p1, v0, v2}, Lokhttp3/RealCall$Companion;->newRealCall(Lokhttp3/OkHttpClient;Lokhttp3/Request;Z)Lokhttp3/RealCall;
move-result-object p1
check-cast p1, Lokhttp3/Call;
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->call:Lokhttp3/Call;
if-nez p1, :cond_52
.line 151
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_52
new-instance v1, Lokhttp3/internal/ws/RealWebSocket$connect$1;
invoke-direct {v1, p0, v0}, Lokhttp3/internal/ws/RealWebSocket$connect$1;-><init>(Lokhttp3/internal/ws/RealWebSocket;Lokhttp3/Request;)V
check-cast v1, Lokhttp3/Callback;
invoke-interface {p1, v1}, Lokhttp3/Call;->enqueue(Lokhttp3/Callback;)V
return-void
.end method
.method public final failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
.registers 6
const-string v0, "e"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 511
monitor-enter p0
.line 512
:try_start_6
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
:try_end_8
.catchall {:try_start_6 .. :try_end_8} :catchall_39
if-eqz v0, :cond_c
monitor-exit p0
return-void
:cond_c
const/4 v0, 0x1
.line 513
:try_start_d
iput-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
.line 514
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
const/4 v1, 0x0
.line 515
check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Streams;
iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 516
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
invoke-virtual {v1}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V
.line 517
sget-object v1, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_1d
.catchall {:try_start_d .. :try_end_1d} :catchall_39
.line 511
monitor-exit p0
.line 520
:try_start_1e
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
move-object v2, p0
check-cast v2, Lokhttp3/WebSocket;
check-cast p1, Ljava/lang/Throwable;
invoke-virtual {v1, v2, p1, p2}, Lokhttp3/WebSocketListener;->onFailure(Lokhttp3/WebSocket;Ljava/lang/Throwable;Lokhttp3/Response;)V
:try_end_28
.catchall {:try_start_1e .. :try_end_28} :catchall_30
if-eqz v0, :cond_2f
.line 522
check-cast v0, Ljava/io/Closeable;
invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
:cond_2f
return-void
:catchall_30
move-exception p1
if-eqz v0, :cond_38
check-cast v0, Ljava/io/Closeable;
invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
:cond_38
throw p1
:catchall_39
move-exception p1
.line 511
monitor-exit p0
throw p1
.end method
.method public final getListener$okhttp()Lokhttp3/WebSocketListener;
.registers 2
.line 57
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
return-object v0
.end method
.method public final initReaderAndWriter(Ljava/lang/String;Lokhttp3/internal/ws/RealWebSocket$Streams;)V
.registers 15
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const-string v0, "name"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "streams"
invoke-static {p2, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 215
monitor-enter p0
.line 216
:try_start_b
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String;
.line 217
iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 218
new-instance v0, Lokhttp3/internal/ws/WebSocketWriter;
invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getClient()Z
move-result v1
invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getSink()Lokio/BufferedSink;
move-result-object v2
iget-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->random:Ljava/util/Random;
invoke-direct {v0, v1, v2, v3}, Lokhttp3/internal/ws/WebSocketWriter;-><init>(ZLokio/BufferedSink;Ljava/util/Random;)V
iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter;
.line 219
new-instance v0, Lokhttp3/internal/ws/RealWebSocket$WriterTask;
invoke-direct {v0, p0}, Lokhttp3/internal/ws/RealWebSocket$WriterTask;-><init>(Lokhttp3/internal/ws/RealWebSocket;)V
check-cast v0, Lokhttp3/internal/concurrent/Task;
iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writerTask:Lokhttp3/internal/concurrent/Task;
.line 220
iget-wide v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-eqz v4, :cond_5c
.line 221
sget-object v0, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
iget-wide v1, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J
move-result-wide v0
.line 222
iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, " ping"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
.line 571
new-instance v11, Lokhttp3/internal/ws/RealWebSocket$initReaderAndWriter$$inlined$synchronized$lambda$1;
move-object v3, v11
move-object v4, v5
move-wide v6, v0
move-object v8, p0
move-object v9, p1
move-object v10, p2
invoke-direct/range {v3 .. v10}, Lokhttp3/internal/ws/RealWebSocket$initReaderAndWriter$$inlined$synchronized$lambda$1;-><init>(Ljava/lang/String;Ljava/lang/String;JLokhttp3/internal/ws/RealWebSocket;Ljava/lang/String;Lokhttp3/internal/ws/RealWebSocket$Streams;)V
check-cast v11, Lokhttp3/internal/concurrent/Task;
invoke-virtual {v2, v11, v0, v1}, Lokhttp3/internal/concurrent/TaskQueue;->schedule(Lokhttp3/internal/concurrent/Task;J)V
.line 227
:cond_5c
iget-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
check-cast p1, Ljava/util/Collection;
invoke-interface {p1}, Ljava/util/Collection;->isEmpty()Z
move-result p1
xor-int/lit8 p1, p1, 0x1
if-eqz p1, :cond_6b
.line 228
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
.line 230
:cond_6b
sget-object p1, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_6d
.catchall {:try_start_b .. :try_end_6d} :catchall_81
.line 215
monitor-exit p0
.line 232
new-instance p1, Lokhttp3/internal/ws/WebSocketReader;
invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getClient()Z
move-result v0
invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getSource()Lokio/BufferedSource;
move-result-object p2
move-object v1, p0
check-cast v1, Lokhttp3/internal/ws/WebSocketReader$FrameCallback;
invoke-direct {p1, v0, p2, v1}, Lokhttp3/internal/ws/WebSocketReader;-><init>(ZLokio/BufferedSource;Lokhttp3/internal/ws/WebSocketReader$FrameCallback;)V
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader;
return-void
:catchall_81
move-exception p1
.line 215
monitor-exit p0
throw p1
.end method
.method public final loopReader()V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 238
:goto_0
iget v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
const/4 v1, -0x1
if-ne v0, v1, :cond_10
.line 240
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader;
if-nez v0, :cond_c
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_c
invoke-virtual {v0}, Lokhttp3/internal/ws/WebSocketReader;->processNextFrame()V
goto :goto_0
:cond_10
return-void
.end method
.method public onReadClose(ILjava/lang/String;)V
.registers 9
const-string v0, "reason"
invoke-static {p2, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
const/4 v0, 0x1
const/4 v1, 0x0
const/4 v2, -0x1
if-eq p1, v2, :cond_c
const/4 v3, 0x1
goto :goto_d
:cond_c
const/4 v3, 0x0
:goto_d
if-eqz v3, :cond_6e
const/4 v3, 0x0
.line 306
move-object v4, v3
check-cast v4, Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 307
monitor-enter p0
.line 308
:try_start_14
iget v5, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
if-ne v5, v2, :cond_19
goto :goto_1a
:cond_19
const/4 v0, 0x0
:goto_1a
if-eqz v0, :cond_5d
.line 309
iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
.line 310
iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseReason:Ljava/lang/String;
.line 311
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz v0, :cond_37
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result v0
if-eqz v0, :cond_37
.line 312
iget-object v4, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 313
check-cast v3, Lokhttp3/internal/ws/RealWebSocket$Streams;
iput-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 314
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V
.line 316
:cond_37
sget-object v0, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_39
.catchall {:try_start_14 .. :try_end_39} :catchall_6b
.line 307
monitor-exit p0
.line 319
:try_start_3a
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
move-object v1, p0
check-cast v1, Lokhttp3/WebSocket;
invoke-virtual {v0, v1, p1, p2}, Lokhttp3/WebSocketListener;->onClosing(Lokhttp3/WebSocket;ILjava/lang/String;)V
if-eqz v4, :cond_4c
.line 322
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
move-object v1, p0
check-cast v1, Lokhttp3/WebSocket;
invoke-virtual {v0, v1, p1, p2}, Lokhttp3/WebSocketListener;->onClosed(Lokhttp3/WebSocket;ILjava/lang/String;)V
:try_end_4c
.catchall {:try_start_3a .. :try_end_4c} :catchall_54
:cond_4c
if-eqz v4, :cond_53
.line 325
check-cast v4, Ljava/io/Closeable;
invoke-static {v4}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
:cond_53
return-void
:catchall_54
move-exception p1
if-eqz v4, :cond_5c
check-cast v4, Ljava/io/Closeable;
invoke-static {v4}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
:cond_5c
throw p1
:cond_5d
:try_start_5d
const-string p1, "already closed"
.line 308
new-instance p2, Ljava/lang/IllegalStateException;
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
check-cast p2, Ljava/lang/Throwable;
throw p2
:try_end_6b
.catchall {:try_start_5d .. :try_end_6b} :catchall_6b
:catchall_6b
move-exception p1
.line 307
monitor-exit p0
throw p1
:cond_6e
const-string p1, "Failed requirement."
.line 304
new-instance p2, Ljava/lang/IllegalArgumentException;
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
check-cast p2, Ljava/lang/Throwable;
throw p2
.end method
.method public onReadMessage(Ljava/lang/String;)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const-string v0, "text"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 280
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
move-object v1, p0
check-cast v1, Lokhttp3/WebSocket;
invoke-virtual {v0, v1, p1}, Lokhttp3/WebSocketListener;->onMessage(Lokhttp3/WebSocket;Ljava/lang/String;)V
return-void
.end method
.method public onReadMessage(Lokio/ByteString;)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const-string v0, "bytes"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 285
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
move-object v1, p0
check-cast v1, Lokhttp3/WebSocket;
invoke-virtual {v0, v1, p1}, Lokhttp3/WebSocketListener;->onMessage(Lokhttp3/WebSocket;Lokio/ByteString;)V
return-void
.end method
.method public declared-synchronized onReadPing(Lokio/ByteString;)V
.registers 3
monitor-enter p0
:try_start_1
const-string v0, "payload"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 290
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-nez v0, :cond_27
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz v0, :cond_17
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result v0
if-eqz v0, :cond_17
goto :goto_27
.line 292
:cond_17
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0, p1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
.line 293
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
.line 294
iget p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPingCount:I
add-int/lit8 p1, p1, 0x1
iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPingCount:I
:try_end_25
.catchall {:try_start_1 .. :try_end_25} :catchall_29
.line 295
monitor-exit p0
return-void
.line 290
:cond_27
:goto_27
monitor-exit p0
return-void
:catchall_29
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized onReadPong(Lokio/ByteString;)V
.registers 3
monitor-enter p0
:try_start_1
const-string v0, "payload"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 299
iget p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPongCount:I
add-int/lit8 p1, p1, 0x1
iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPongCount:I
const/4 p1, 0x0
.line 300
iput-boolean p1, p0, Lokhttp3/internal/ws/RealWebSocket;->awaitingPong:Z
:try_end_f
.catchall {:try_start_1 .. :try_end_f} :catchall_11
.line 301
monitor-exit p0
return-void
:catchall_11
move-exception p1
monitor-exit p0
throw p1
.end method
.method public final declared-synchronized pong(Lokio/ByteString;)Z
.registers 3
monitor-enter p0
:try_start_1
const-string v0, "payload"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 358
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-nez v0, :cond_22
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz v0, :cond_17
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result v0
if-eqz v0, :cond_17
goto :goto_22
.line 360
:cond_17
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0, p1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
.line 361
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
:try_end_1f
.catchall {:try_start_1 .. :try_end_1f} :catchall_25
const/4 p1, 0x1
.line 362
monitor-exit p0
return p1
:cond_22
:goto_22
const/4 p1, 0x0
.line 358
monitor-exit p0
return p1
:catchall_25
move-exception p1
monitor-exit p0
throw p1
.end method
.method public final processNextFrame()Z
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const/4 v0, 0x0
.line 251
:try_start_1
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader;
if-nez v1, :cond_8
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_8
invoke-virtual {v1}, Lokhttp3/internal/ws/WebSocketReader;->processNextFrame()V
.line 252
iget v1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
:try_end_d
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_d} :catch_12
const/4 v2, -0x1
if-ne v1, v2, :cond_17
const/4 v0, 0x1
goto :goto_17
:catch_12
move-exception v1
const/4 v2, 0x0
.line 254
invoke-virtual {p0, v1, v2}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
:cond_17
:goto_17
return v0
.end method
.method public declared-synchronized queueSize()J
.registers 3
monitor-enter p0
.line 133
:try_start_1
iget-wide v0, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return-wide v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public final declared-synchronized receivedPingCount()I
.registers 2
monitor-enter p0
.line 274
:try_start_1
iget v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPingCount:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public final declared-synchronized receivedPongCount()I
.registers 2
monitor-enter p0
.line 276
:try_start_1
iget v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPongCount:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public request()Lokhttp3/Request;
.registers 2
.line 131
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request;
return-object v0
.end method
.method public send(Ljava/lang/String;)Z
.registers 3
const-string v0, "text"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
.line 332
sget-object v0, Lokio/ByteString;->Companion:Lokio/ByteString$Companion;
invoke-virtual {v0, p1}, Lokio/ByteString$Companion;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object p1
const/4 v0, 0x1
invoke-direct {p0, p1, v0}, Lokhttp3/internal/ws/RealWebSocket;->send(Lokio/ByteString;I)Z
move-result p1
return p1
.end method
.method public send(Lokio/ByteString;)Z
.registers 3
const-string v0, "bytes"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V
const/4 v0, 0x2
.line 336
invoke-direct {p0, p1, v0}, Lokhttp3/internal/ws/RealWebSocket;->send(Lokio/ByteString;I)Z
move-result p1
return p1
.end method
.method public final declared-synchronized sentPingCount()I
.registers 2
monitor-enter p0
.line 272
:try_start_1
iget v0, p0, Lokhttp3/internal/ws/RealWebSocket;->sentPingCount:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public final tearDown()V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/InterruptedException;
}
.end annotation
.line 268
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V
.line 269
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskQueue;->idleLatch()Ljava/util/concurrent/CountDownLatch;
move-result-object v0
sget-object v1, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v2, 0xa
invoke-virtual {v0, v2, v3, v1}, Ljava/util/concurrent/CountDownLatch;->await(JLjava/util/concurrent/TimeUnit;)Z
return-void
.end method
.method public final writeOneFrame$okhttp()Z
.registers 24
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
move-object/from16 v13, p0
.line 421
new-instance v0, Lkotlin/jvm/internal/Ref$ObjectRef;
invoke-direct {v0}, Lkotlin/jvm/internal/Ref$ObjectRef;-><init>()V
const/4 v1, 0x0
iput-object v1, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
.line 422
new-instance v14, Lkotlin/jvm/internal/Ref$IntRef;
invoke-direct {v14}, Lkotlin/jvm/internal/Ref$IntRef;-><init>()V
const/4 v2, -0x1
iput v2, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I
.line 423
new-instance v15, Lkotlin/jvm/internal/Ref$ObjectRef;
invoke-direct {v15}, Lkotlin/jvm/internal/Ref$ObjectRef;-><init>()V
move-object v3, v1
check-cast v3, Ljava/lang/String;
iput-object v3, v15, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
.line 424
new-instance v12, Lkotlin/jvm/internal/Ref$ObjectRef;
invoke-direct {v12}, Lkotlin/jvm/internal/Ref$ObjectRef;-><init>()V
move-object v3, v1
check-cast v3, Lokhttp3/internal/ws/RealWebSocket$Streams;
iput-object v3, v12, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
.line 426
monitor-enter p0
.line 427
:try_start_27
iget-boolean v3, v13, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
:try_end_29
.catchall {:try_start_27 .. :try_end_29} :catchall_19e
const/4 v4, 0x0
if-eqz v3, :cond_2e
.line 428
monitor-exit p0
return v4
.line 431
:cond_2e
:try_start_2e
iget-object v11, v13, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter;
.line 432
iget-object v3, v13, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque;
invoke-virtual {v3}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object;
move-result-object v3
move-object v10, v3
check-cast v10, Lokio/ByteString;
if-nez v10, :cond_c4
.line 434
iget-object v3, v13, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {v3}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object;
move-result-object v3
iput-object v3, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
.line 435
iget-object v3, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
instance-of v3, v3, Lokhttp3/internal/ws/RealWebSocket$Close;
if-eqz v3, :cond_b8
.line 436
iget v3, v13, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
iput v3, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I
.line 437
iget-object v3, v13, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseReason:Ljava/lang/String;
iput-object v3, v15, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
.line 438
iget v3, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I
if-eq v3, v2, :cond_64
.line 439
iget-object v2, v13, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
iput-object v2, v12, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
.line 440
check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Streams;
iput-object v1, v13, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 441
iget-object v1, v13, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
invoke-virtual {v1}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V
goto/16 :goto_c4
.line 444
:cond_64
iget-object v1, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
if-eqz v1, :cond_b0
check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Close;
invoke-virtual {v1}, Lokhttp3/internal/ws/RealWebSocket$Close;->getCancelAfterCloseMillis()J
move-result-wide v1
.line 445
iget-object v9, v13, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
iget-object v4, v13, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, " cancel"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
sget-object v3, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v3, v1, v2}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J
move-result-wide v7
const/4 v5, 0x1
.line 582
new-instance v16, Lokhttp3/internal/ws/RealWebSocket$writeOneFrame$$inlined$synchronized$lambda$1;
move-object/from16 v1, v16
move-object v2, v4
move v3, v5
move-object/from16 v6, p0
move-wide/from16 v17, v7
move-object v7, v11
move-object v8, v10
move-object/from16 v19, v9
move-object v9, v0
move-object/from16 v20, v10
move-object v10, v14
move-object/from16 v21, v11
move-object v11, v15
move-object/from16 v22, v12
invoke-direct/range {v1 .. v12}, Lokhttp3/internal/ws/RealWebSocket$writeOneFrame$$inlined$synchronized$lambda$1;-><init>(Ljava/lang/String;ZLjava/lang/String;ZLokhttp3/internal/ws/RealWebSocket;Lokhttp3/internal/ws/WebSocketWriter;Lokio/ByteString;Lkotlin/jvm/internal/Ref$ObjectRef;Lkotlin/jvm/internal/Ref$IntRef;Lkotlin/jvm/internal/Ref$ObjectRef;Lkotlin/jvm/internal/Ref$ObjectRef;)V
move-object/from16 v1, v16
check-cast v1, Lokhttp3/internal/concurrent/Task;
move-wide/from16 v3, v17
move-object/from16 v2, v19
invoke-virtual {v2, v1, v3, v4}, Lokhttp3/internal/concurrent/TaskQueue;->schedule(Lokhttp3/internal/concurrent/Task;J)V
goto :goto_ca
.line 444
:cond_b0
new-instance v0, Lkotlin/TypeCastException;
const-string v1, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Close"
invoke-direct {v0, v1}, Lkotlin/TypeCastException;-><init>(Ljava/lang/String;)V
throw v0
:cond_b8
move-object/from16 v20, v10
move-object/from16 v21, v11
move-object/from16 v22, v12
.line 449
iget-object v1, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
:try_end_c0
.catchall {:try_start_2e .. :try_end_c0} :catchall_19e
if-nez v1, :cond_ca
.line 450
monitor-exit p0
return v4
:cond_c4
:goto_c4
move-object/from16 v20, v10
move-object/from16 v21, v11
move-object/from16 v22, v12
.line 453
:cond_ca
:goto_ca
:try_start_ca
sget-object v1, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_cc
.catchall {:try_start_ca .. :try_end_cc} :catchall_19e
.line 426
monitor-exit p0
move-object/from16 v3, v20
if-eqz v3, :cond_df
move-object/from16 v1, v21
if-nez v1, :cond_d8
.line 457
:try_start_d5
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_d8
invoke-virtual {v1, v3}, Lokhttp3/internal/ws/WebSocketWriter;->writePong(Lokio/ByteString;)V
:goto_db
move-object/from16 v1, v22
goto/16 :goto_16c
:cond_df
move-object/from16 v1, v21
.line 458
iget-object v2, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
instance-of v2, v2, Lokhttp3/internal/ws/RealWebSocket$Message;
if-eqz v2, :cond_135
.line 459
iget-object v2, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
if-eqz v2, :cond_12d
check-cast v2, Lokhttp3/internal/ws/RealWebSocket$Message;
invoke-virtual {v2}, Lokhttp3/internal/ws/RealWebSocket$Message;->getData()Lokio/ByteString;
move-result-object v2
if-nez v1, :cond_f6
.line 460
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
.line 461
:cond_f6
iget-object v0, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
if-eqz v0, :cond_125
check-cast v0, Lokhttp3/internal/ws/RealWebSocket$Message;
invoke-virtual {v0}, Lokhttp3/internal/ws/RealWebSocket$Message;->getFormatOpcode()I
move-result v0
invoke-virtual {v2}, Lokio/ByteString;->size()I
move-result v3
int-to-long v3, v3
.line 460
invoke-virtual {v1, v0, v3, v4}, Lokhttp3/internal/ws/WebSocketWriter;->newMessageSink(IJ)Lokio/Sink;
move-result-object v0
.line 461
invoke-static {v0}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink;
move-result-object v0
.line 462
invoke-interface {v0, v2}, Lokio/BufferedSink;->write(Lokio/ByteString;)Lokio/BufferedSink;
.line 463
invoke-interface {v0}, Lokio/BufferedSink;->close()V
.line 464
monitor-enter p0
:try_end_114
.catchall {:try_start_d5 .. :try_end_114} :catchall_18f
.line 465
:try_start_114
iget-wide v0, v13, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
invoke-virtual {v2}, Lokio/ByteString;->size()I
move-result v2
int-to-long v2, v2
sub-long/2addr v0, v2
iput-wide v0, v13, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
.line 466
sget-object v0, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_120
.catchall {:try_start_114 .. :try_end_120} :catchall_122
.line 464
:try_start_120
monitor-exit p0
goto :goto_db
:catchall_122
move-exception v0
monitor-exit p0
throw v0
.line 461
:cond_125
new-instance v0, Lkotlin/TypeCastException;
const-string v1, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Message"
invoke-direct {v0, v1}, Lkotlin/TypeCastException;-><init>(Ljava/lang/String;)V
throw v0
.line 459
:cond_12d
new-instance v0, Lkotlin/TypeCastException;
const-string v1, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Message"
invoke-direct {v0, v1}, Lkotlin/TypeCastException;-><init>(Ljava/lang/String;)V
throw v0
.line 467
:cond_135
iget-object v2, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
instance-of v2, v2, Lokhttp3/internal/ws/RealWebSocket$Close;
if-eqz v2, :cond_183
.line 468
iget-object v0, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
if-eqz v0, :cond_179
check-cast v0, Lokhttp3/internal/ws/RealWebSocket$Close;
if-nez v1, :cond_146
.line 469
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_146
invoke-virtual {v0}, Lokhttp3/internal/ws/RealWebSocket$Close;->getCode()I
move-result v2
invoke-virtual {v0}, Lokhttp3/internal/ws/RealWebSocket$Close;->getReason()Lokio/ByteString;
move-result-object v0
invoke-virtual {v1, v2, v0}, Lokhttp3/internal/ws/WebSocketWriter;->writeClose(ILokio/ByteString;)V
:try_end_151
.catchall {:try_start_120 .. :try_end_151} :catchall_18f
move-object/from16 v1, v22
.line 472
:try_start_153
iget-object v0, v1, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
check-cast v0, Lokhttp3/internal/ws/RealWebSocket$Streams;
if-eqz v0, :cond_16c
.line 473
iget-object v0, v13, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
move-object v2, v13
check-cast v2, Lokhttp3/WebSocket;
iget v3, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I
iget-object v4, v15, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
check-cast v4, Ljava/lang/String;
if-nez v4, :cond_169
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_169
invoke-virtual {v0, v2, v3, v4}, Lokhttp3/WebSocketListener;->onClosed(Lokhttp3/WebSocket;ILjava/lang/String;)V
:try_end_16c
.catchall {:try_start_153 .. :try_end_16c} :catchall_18d
:cond_16c
:goto_16c
const/4 v0, 0x1
.line 481
iget-object v1, v1, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Streams;
if-eqz v1, :cond_178
check-cast v1, Ljava/io/Closeable;
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
:cond_178
return v0
:cond_179
move-object/from16 v1, v22
.line 468
:try_start_17b
new-instance v0, Lkotlin/TypeCastException;
const-string v2, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Close"
invoke-direct {v0, v2}, Lkotlin/TypeCastException;-><init>(Ljava/lang/String;)V
throw v0
:cond_183
move-object/from16 v1, v22
.line 476
new-instance v0, Ljava/lang/AssertionError;
invoke-direct {v0}, Ljava/lang/AssertionError;-><init>()V
check-cast v0, Ljava/lang/Throwable;
throw v0
:try_end_18d
.catchall {:try_start_17b .. :try_end_18d} :catchall_18d
:catchall_18d
move-exception v0
goto :goto_192
:catchall_18f
move-exception v0
move-object/from16 v1, v22
.line 481
:goto_192
iget-object v1, v1, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object;
check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Streams;
if-eqz v1, :cond_19d
check-cast v1, Ljava/io/Closeable;
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
:cond_19d
throw v0
:catchall_19e
move-exception v0
.line 426
monitor-exit p0
throw v0
.end method
.method public final writePingFrame$okhttp()V
.registers 8
.line 488
monitor-enter p0
.line 489
:try_start_1
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5e
if-eqz v0, :cond_7
monitor-exit p0
return-void
.line 490
:cond_7
:try_start_7
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter;
.line 491
iget-boolean v1, p0, Lokhttp3/internal/ws/RealWebSocket;->awaitingPong:Z
const/4 v2, -0x1
if-eqz v1, :cond_11
iget v1, p0, Lokhttp3/internal/ws/RealWebSocket;->sentPingCount:I
goto :goto_12
:cond_11
const/4 v1, -0x1
.line 492
:goto_12
iget v3, p0, Lokhttp3/internal/ws/RealWebSocket;->sentPingCount:I
const/4 v4, 0x1
add-int/2addr v3, v4
iput v3, p0, Lokhttp3/internal/ws/RealWebSocket;->sentPingCount:I
.line 493
iput-boolean v4, p0, Lokhttp3/internal/ws/RealWebSocket;->awaitingPong:Z
.line 494
sget-object v3, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_1c
.catchall {:try_start_7 .. :try_end_1c} :catchall_5e
.line 488
monitor-exit p0
const/4 v3, 0x0
if-eq v1, v2, :cond_4c
.line 497
new-instance v0, Ljava/net/SocketTimeoutException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "sent ping but didn\'t receive pong within "
invoke-virtual {v2, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 498
iget-wide v5, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
invoke-virtual {v2, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v5, "ms (after "
invoke-virtual {v2, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sub-int/2addr v1, v4
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " successful ping/pongs)"
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 497
invoke-direct {v0, v1}, Ljava/net/SocketTimeoutException;-><init>(Ljava/lang/String;)V
check-cast v0, Ljava/lang/Exception;
invoke-virtual {p0, v0, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
return-void
:cond_4c
if-nez v0, :cond_51
.line 503
:try_start_4e
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V
:cond_51
sget-object v1, Lokio/ByteString;->EMPTY:Lokio/ByteString;
invoke-virtual {v0, v1}, Lokhttp3/internal/ws/WebSocketWriter;->writePing(Lokio/ByteString;)V
:try_end_56
.catch Ljava/io/IOException; {:try_start_4e .. :try_end_56} :catch_57
goto :goto_5d
:catch_57
move-exception v0
.line 505
check-cast v0, Ljava/lang/Exception;
invoke-virtual {p0, v0, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
:goto_5d
return-void
:catchall_5e
move-exception v0
.line 488
monitor-exit p0
throw v0
.end method