RealWebSocket.smali
.class public final Lokhttp3/internal/ws/RealWebSocket;
.super Ljava/lang/Object;
.source "RealWebSocket.java"
# interfaces
.implements Lokhttp3/WebSocket;
.implements Lokhttp3/internal/ws/WebSocketReader$FrameCallback;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lokhttp3/internal/ws/RealWebSocket$CancelRunnable;,
Lokhttp3/internal/ws/RealWebSocket$Streams;,
Lokhttp3/internal/ws/RealWebSocket$Close;,
Lokhttp3/internal/ws/RealWebSocket$Message;,
Lokhttp3/internal/ws/RealWebSocket$PingRunnable;
}
.end annotation
# static fields
.field static final synthetic $assertionsDisabled:Z = false
.field private static final CANCEL_AFTER_CLOSE_MILLIS:J = 0xea60L
.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 cancelFuture:Ljava/util/concurrent/ScheduledFuture;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ScheduledFuture<",
"*>;"
}
.end annotation
.end field
.field private enqueuedClose:Z
.field private executor:Ljava/util/concurrent/ScheduledExecutorService;
.field private failed:Z
.field private final key:Ljava/lang/String;
.field 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 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 writer:Lokhttp3/internal/ws/WebSocketWriter;
.field private final writerRunnable:Ljava/lang/Runnable;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 57
sget-object v0, Lokhttp3/Protocol;->HTTP_1_1:Lokhttp3/Protocol;
invoke-static {v0}, Ljava/util/Collections;->singletonList(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/Request;Lokhttp3/WebSocketListener;Ljava/util/Random;J)V
.registers 8
.line 143
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 104
new-instance v0, Ljava/util/ArrayDeque;
invoke-direct {v0}, Ljava/util/ArrayDeque;-><init>()V
iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque;
.line 107
new-instance v0, Ljava/util/ArrayDeque;
invoke-direct {v0}, Ljava/util/ArrayDeque;-><init>()V
iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
const/4 v0, -0x1
.line 122
iput v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
.line 144
invoke-virtual {p1}, Lokhttp3/Request;->method()Ljava/lang/String;
move-result-object v0
const-string v1, "GET"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_41
.line 147
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request;
.line 148
iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
.line 149
iput-object p3, p0, Lokhttp3/internal/ws/RealWebSocket;->random:Ljava/util/Random;
.line 150
iput-wide p4, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
const/16 p1, 0x10
new-array p1, p1, [B
.line 153
invoke-virtual {p3, p1}, Ljava/util/Random;->nextBytes([B)V
.line 154
invoke-static {p1}, Lokio/ByteString;->of([B)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;
.line 156
new-instance p1, Lokhttp3/internal/ws/RealWebSocket$1;
invoke-direct {p1, p0}, Lokhttp3/internal/ws/RealWebSocket$1;-><init>(Lokhttp3/internal/ws/RealWebSocket;)V
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->writerRunnable:Ljava/lang/Runnable;
return-void
.line 145
:cond_41
new-instance p2, Ljava/lang/IllegalArgumentException;
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "Request must be GET: "
invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lokhttp3/Request;->method()Ljava/lang/String;
move-result-object p1
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p2
.end method
.method private runWriter()V
.registers 3
.line 438
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
if-eqz v0, :cond_9
.line 439
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->writerRunnable:Ljava/lang/Runnable;
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledExecutorService;->execute(Ljava/lang/Runnable;)V
:cond_9
return-void
.end method
.method private declared-synchronized send(Lokio/ByteString;I)Z
.registers 9
monitor-enter p0
.line 385
: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 388
: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 389
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 390
monitor-exit p0
return v1
.line 394
: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 395
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 396
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 397
monitor-exit p0
return p1
.line 385
:cond_3c
:goto_3c
monitor-exit p0
return v1
:catchall_3e
move-exception p1
monitor-exit p0
throw p1
.end method
# virtual methods
.method awaitTermination(ILjava/util/concurrent/TimeUnit;)V
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/InterruptedException;
}
.end annotation
.line 295
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
int-to-long v1, p1
invoke-interface {v0, v1, v2, p2}, Ljava/util/concurrent/ScheduledExecutorService;->awaitTermination(JLjava/util/concurrent/TimeUnit;)Z
return-void
.end method
.method public cancel()V
.registers 2
.line 177
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->call:Lokhttp3/Call;
invoke-interface {v0}, Lokhttp3/Call;->cancel()V
return-void
.end method
.method checkResponse(Lokhttp3/Response;)V
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/net/ProtocolException;
}
.end annotation
.line 226
invoke-virtual {p1}, Lokhttp3/Response;->code()I
move-result v0
const-string v1, "\'"
const/16 v2, 0x65
if-ne v0, v2, :cond_a6
const-string v0, "Connection"
.line 231
invoke-virtual {p1, v0}, Lokhttp3/Response;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
const-string v2, "Upgrade"
.line 232
invoke-virtual {v2, v0}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_8c
.line 237
invoke-virtual {p1, v2}, Lokhttp3/Response;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
const-string v2, "websocket"
.line 238
invoke-virtual {v2, v0}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_72
const-string v0, "Sec-WebSocket-Accept"
.line 243
invoke-virtual {p1, v0}, Lokhttp3/Response;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 244
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String;
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "258EAFA5-E914-47DA-95CA-C5AB0DC85B11"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lokio/ByteString;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object v0
.line 245
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 246
invoke-virtual {v0, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_50
return-void
.line 247
:cond_50
new-instance v2, Ljava/net/ProtocolException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Expected \'Sec-WebSocket-Accept\' header value \'"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "\' but was \'"
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v2, p1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw v2
.line 239
:cond_72
new-instance p1, Ljava/net/ProtocolException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Expected \'Upgrade\' header value \'websocket\' but was \'"
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;
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 v0
invoke-direct {p1, v0}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw p1
.line 233
:cond_8c
new-instance p1, Ljava/net/ProtocolException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Expected \'Connection\' header value \'Upgrade\' but was \'"
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;
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 v0
invoke-direct {p1, v0}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw p1
.line 227
:cond_a6
new-instance v0, Ljava/net/ProtocolException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Expected HTTP 101 response but was \'"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 228
invoke-virtual {p1}, Lokhttp3/Response;->code()I
move-result v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, " "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lokhttp3/Response;->message()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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 p1
invoke-direct {v0, p1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public close(ILjava/lang/String;)Z
.registers 5
const-wide/32 v0, 0xea60
.line 410
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 declared-synchronized close(ILjava/lang/String;J)Z
.registers 11
monitor-enter p0
.line 414
:try_start_1
invoke-static {p1}, Lokhttp3/internal/ws/WebSocketProtocol;->validateCloseCode(I)V
const/4 v0, 0x0
if-eqz p2, :cond_2e
.line 418
invoke-static {p2}, Lokio/ByteString;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object v0
.line 419
invoke-virtual {v0}, Lokio/ByteString;->size()I
move-result v1
int-to-long v1, v1
const-wide/16 v3, 0x7b
cmp-long v5, v1, v3
if-gtz v5, :cond_17
goto :goto_2e
.line 420
:cond_17
new-instance p1, Ljava/lang/IllegalArgumentException;
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "reason.size() > 123: "
invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.line 424
:cond_2e
:goto_2e
iget-boolean p2, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-nez p2, :cond_49
iget-boolean p2, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz p2, :cond_37
goto :goto_49
:cond_37
const/4 p2, 0x1
.line 427
iput-boolean p2, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
.line 430
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
new-instance v2, Lokhttp3/internal/ws/RealWebSocket$Close;
invoke-direct {v2, p1, v0, p3, p4}, Lokhttp3/internal/ws/RealWebSocket$Close;-><init>(ILokio/ByteString;J)V
invoke-virtual {v1, v2}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
.line 431
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
:try_end_47
.catchall {:try_start_1 .. :try_end_47} :catchall_4c
.line 432
monitor-exit p0
return p2
:cond_49
:goto_49
const/4 p1, 0x0
.line 424
monitor-exit p0
return p1
:catchall_4c
move-exception p1
monitor-exit p0
throw p1
.end method
.method public connect(Lokhttp3/OkHttpClient;)V
.registers 5
.line 181
invoke-virtual {p1}, Lokhttp3/OkHttpClient;->newBuilder()Lokhttp3/OkHttpClient$Builder;
move-result-object p1
sget-object v0, Lokhttp3/EventListener;->NONE:Lokhttp3/EventListener;
.line 182
invoke-virtual {p1, v0}, Lokhttp3/OkHttpClient$Builder;->eventListener(Lokhttp3/EventListener;)Lokhttp3/OkHttpClient$Builder;
move-result-object p1
sget-object v0, Lokhttp3/internal/ws/RealWebSocket;->ONLY_HTTP1:Ljava/util/List;
.line 183
invoke-virtual {p1, v0}, Lokhttp3/OkHttpClient$Builder;->protocols(Ljava/util/List;)Lokhttp3/OkHttpClient$Builder;
move-result-object p1
.line 184
invoke-virtual {p1}, Lokhttp3/OkHttpClient$Builder;->build()Lokhttp3/OkHttpClient;
move-result-object p1
.line 185
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 v2, "websocket"
.line 186
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 187
invoke-virtual {v0, v2, v1}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String;
const-string v2, "Sec-WebSocket-Key"
.line 188
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 189
invoke-virtual {v0, v1, v2}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
.line 190
invoke-virtual {v0}, Lokhttp3/Request$Builder;->build()Lokhttp3/Request;
move-result-object v0
.line 191
sget-object v1, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
invoke-virtual {v1, p1, v0}, Lokhttp3/internal/Internal;->newWebSocketCall(Lokhttp3/OkHttpClient;Lokhttp3/Request;)Lokhttp3/Call;
move-result-object p1
iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->call:Lokhttp3/Call;
.line 192
new-instance v1, Lokhttp3/internal/ws/RealWebSocket$2;
invoke-direct {v1, p0, v0}, Lokhttp3/internal/ws/RealWebSocket$2;-><init>(Lokhttp3/internal/ws/RealWebSocket;Lokhttp3/Request;)V
invoke-interface {p1, v1}, Lokhttp3/Call;->enqueue(Lokhttp3/Callback;)V
return-void
.end method
.method public failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
.registers 6
.param p2 # Lokhttp3/Response;
.annotation runtime Ljavax/annotation/Nullable;
.end annotation
.end param
.line 560
monitor-enter p0
.line 561
:try_start_1
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-eqz v0, :cond_7
monitor-exit p0
return-void
:cond_7
const/4 v0, 0x1
.line 562
iput-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
.line 563
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
const/4 v1, 0x0
.line 564
iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 565
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
if-eqz v1, :cond_17
const/4 v2, 0x0
invoke-interface {v1, v2}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
.line 566
:cond_17
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
if-eqz v1, :cond_1e
invoke-interface {v1}, Ljava/util/concurrent/ScheduledExecutorService;->shutdown()V
.line 567
:cond_1e
monitor-exit p0
:try_end_1f
.catchall {:try_start_1 .. :try_end_1f} :catchall_2d
.line 570
:try_start_1f
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
invoke-virtual {v1, p0, p1, p2}, Lokhttp3/WebSocketListener;->onFailure(Lokhttp3/WebSocket;Ljava/lang/Throwable;Lokhttp3/Response;)V
:try_end_24
.catchall {:try_start_1f .. :try_end_24} :catchall_28
.line 572
invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
return-void
:catchall_28
move-exception p1
invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
throw p1
:catchall_2d
move-exception p1
.line 567
:try_start_2e
monitor-exit p0
:try_end_2f
.catchall {:try_start_2e .. :try_end_2f} :catchall_2d
throw p1
.end method
.method public initReaderAndWriter(Ljava/lang/String;Lokhttp3/internal/ws/RealWebSocket$Streams;)V
.registers 14
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 253
monitor-enter p0
.line 254
:try_start_1
iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 255
new-instance v0, Lokhttp3/internal/ws/WebSocketWriter;
iget-boolean v1, p2, Lokhttp3/internal/ws/RealWebSocket$Streams;->client:Z
iget-object v2, p2, Lokhttp3/internal/ws/RealWebSocket$Streams;->sink:Lokio/BufferedSink;
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 256
new-instance v4, Ljava/util/concurrent/ScheduledThreadPoolExecutor;
const/4 v0, 0x1
const/4 v1, 0x0
invoke-static {p1, v1}, Lokhttp3/internal/Util;->threadFactory(Ljava/lang/String;Z)Ljava/util/concurrent/ThreadFactory;
move-result-object p1
invoke-direct {v4, v0, p1}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;-><init>(ILjava/util/concurrent/ThreadFactory;)V
iput-object v4, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
.line 257
iget-wide v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
const-wide/16 v2, 0x0
cmp-long p1, v0, v2
if-eqz p1, :cond_32
.line 258
new-instance v5, Lokhttp3/internal/ws/RealWebSocket$PingRunnable;
invoke-direct {v5, p0}, Lokhttp3/internal/ws/RealWebSocket$PingRunnable;-><init>(Lokhttp3/internal/ws/RealWebSocket;)V
iget-wide v8, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
sget-object v10, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
move-wide v6, v8
invoke-interface/range {v4 .. v10}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
.line 261
:cond_32
iget-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {p1}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result p1
if-nez p1, :cond_3d
.line 262
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
.line 264
:cond_3d
monitor-exit p0
:try_end_3e
.catchall {:try_start_1 .. :try_end_3e} :catchall_4a
.line 266
new-instance p1, Lokhttp3/internal/ws/WebSocketReader;
iget-boolean v0, p2, Lokhttp3/internal/ws/RealWebSocket$Streams;->client:Z
iget-object p2, p2, Lokhttp3/internal/ws/RealWebSocket$Streams;->source:Lokio/BufferedSource;
invoke-direct {p1, v0, p2, p0}, 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_4a
move-exception p1
.line 264
:try_start_4b
monitor-exit p0
:try_end_4c
.catchall {:try_start_4b .. :try_end_4c} :catchall_4a
throw p1
.end method
.method public loopReader()V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 271
:goto_0
iget v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
const/4 v1, -0x1
if-ne v0, v1, :cond_b
.line 273
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader;
invoke-virtual {v0}, Lokhttp3/internal/ws/WebSocketReader;->processNextFrame()V
goto :goto_0
:cond_b
return-void
.end method
.method public onReadClose(ILjava/lang/String;)V
.registers 6
const/4 v0, -0x1
if-eq p1, v0, :cond_4c
.line 348
monitor-enter p0
.line 349
:try_start_4
iget v1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
if-ne v1, v0, :cond_41
.line 350
iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
.line 351
iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseReason:Ljava/lang/String;
.line 352
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
const/4 v1, 0x0
if-eqz v0, :cond_2b
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_2b
.line 353
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 354
iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 355
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
if-eqz v1, :cond_25
const/4 v2, 0x0
invoke-interface {v1, v2}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
.line 356
:cond_25
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v1}, Ljava/util/concurrent/ScheduledExecutorService;->shutdown()V
move-object v1, v0
.line 358
:cond_2b
monitor-exit p0
:try_end_2c
.catchall {:try_start_4 .. :try_end_2c} :catchall_49
.line 361
:try_start_2c
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
invoke-virtual {v0, p0, p1, p2}, Lokhttp3/WebSocketListener;->onClosing(Lokhttp3/WebSocket;ILjava/lang/String;)V
if-eqz v1, :cond_38
.line 364
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
invoke-virtual {v0, p0, p1, p2}, Lokhttp3/WebSocketListener;->onClosed(Lokhttp3/WebSocket;ILjava/lang/String;)V
:try_end_38
.catchall {:try_start_2c .. :try_end_38} :catchall_3c
.line 367
:cond_38
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
return-void
:catchall_3c
move-exception p1
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
throw p1
.line 349
:cond_41
:try_start_41
new-instance p1, Ljava/lang/IllegalStateException;
const-string p2, "already closed"
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
:catchall_49
move-exception p1
.line 358
monitor-exit p0
:try_end_4b
.catchall {:try_start_41 .. :try_end_4b} :catchall_49
throw p1
.line 345
:cond_4c
new-instance p1, Ljava/lang/IllegalArgumentException;
invoke-direct {p1}, Ljava/lang/IllegalArgumentException;-><init>()V
throw p1
.end method
.method public onReadMessage(Ljava/lang/String;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 322
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
invoke-virtual {v0, p0, p1}, Lokhttp3/WebSocketListener;->onMessage(Lokhttp3/WebSocket;Ljava/lang/String;)V
return-void
.end method
.method public onReadMessage(Lokio/ByteString;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 326
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
invoke-virtual {v0, p0, 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
.line 331
:try_start_1
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_12
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_12
goto :goto_22
.line 333
:cond_12
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 334
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
.line 335
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_20
.catchall {:try_start_1 .. :try_end_20} :catchall_24
.line 336
monitor-exit p0
return-void
.line 331
:cond_22
:goto_22
monitor-exit p0
return-void
:catchall_24
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized onReadPong(Lokio/ByteString;)V
.registers 2
monitor-enter p0
.line 340
:try_start_1
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 341
iput-boolean p1, p0, Lokhttp3/internal/ws/RealWebSocket;->awaitingPong:Z
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_c
.line 342
monitor-exit p0
return-void
:catchall_c
move-exception p1
monitor-exit p0
throw p1
.end method
.method declared-synchronized pong(Lokio/ByteString;)Z
.registers 3
monitor-enter p0
.line 402
:try_start_1
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-nez v0, :cond_1d
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz v0, :cond_12
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_12
goto :goto_1d
.line 404
:cond_12
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 405
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
:try_end_1a
.catchall {:try_start_1 .. :try_end_1a} :catchall_20
const/4 p1, 0x1
.line 406
monitor-exit p0
return p1
:cond_1d
:goto_1d
const/4 p1, 0x0
.line 402
monitor-exit p0
return p1
:catchall_20
move-exception p1
monitor-exit p0
throw p1
.end method
.method processNextFrame()Z
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const/4 v0, 0x0
.line 283
:try_start_1
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader;
invoke-virtual {v1}, Lokhttp3/internal/ws/WebSocketReader;->processNextFrame()V
.line 284
iget v1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
:try_end_8
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_8} :catch_d
const/4 v2, -0x1
if-ne v1, v2, :cond_c
const/4 v0, 0x1
:cond_c
return v0
:catch_d
move-exception v1
const/4 v2, 0x0
.line 286
invoke-virtual {p0, v1, v2}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
return v0
.end method
.method public declared-synchronized queueSize()J
.registers 3
monitor-enter p0
.line 173
: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 declared-synchronized receivedPingCount()I
.registers 2
monitor-enter p0
.line 314
: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 declared-synchronized receivedPongCount()I
.registers 2
monitor-enter p0
.line 318
: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 169
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
if-eqz p1, :cond_c
.line 375
invoke-static {p1}, Lokio/ByteString;->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
.line 374
:cond_c
new-instance p1, Ljava/lang/NullPointerException;
const-string v0, "text == null"
invoke-direct {p1, v0}, Ljava/lang/NullPointerException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public send(Lokio/ByteString;)Z
.registers 3
if-eqz p1, :cond_8
const/4 v0, 0x2
.line 380
invoke-direct {p0, p1, v0}, Lokhttp3/internal/ws/RealWebSocket;->send(Lokio/ByteString;I)Z
move-result p1
return p1
.line 379
:cond_8
new-instance p1, Ljava/lang/NullPointerException;
const-string v0, "bytes == null"
invoke-direct {p1, v0}, Ljava/lang/NullPointerException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method declared-synchronized sentPingCount()I
.registers 2
monitor-enter p0
.line 310
: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 tearDown()V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/InterruptedException;
}
.end annotation
.line 302
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
if-eqz v0, :cond_8
const/4 v1, 0x0
.line 303
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
.line 305
:cond_8
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ScheduledExecutorService;->shutdown()V
.line 306
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
const-wide/16 v1, 0xa
sget-object v3, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v0, v1, v2, v3}, Ljava/util/concurrent/ScheduledExecutorService;->awaitTermination(JLjava/util/concurrent/TimeUnit;)Z
return-void
.end method
.method writeOneFrame()Z
.registers 13
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 464
monitor-enter p0
.line 465
:try_start_1
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
const/4 v1, 0x0
if-eqz v0, :cond_8
.line 466
monitor-exit p0
return v1
.line 469
:cond_8
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter;
.line 470
iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque;
invoke-virtual {v2}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lokio/ByteString;
const/4 v3, -0x1
const/4 v4, 0x0
if-nez v2, :cond_53
.line 472
iget-object v5, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {v5}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object;
move-result-object v5
.line 473
instance-of v6, v5, Lokhttp3/internal/ws/RealWebSocket$Close;
if-eqz v6, :cond_4b
.line 474
iget v1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
.line 475
iget-object v6, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseReason:Ljava/lang/String;
if-eq v1, v3, :cond_34
.line 477
iget-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 478
iput-object v4, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 479
iget-object v4, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v4}, Ljava/util/concurrent/ScheduledExecutorService;->shutdown()V
move-object v4, v5
move-object v11, v3
move v3, v1
move-object v1, v11
goto :goto_55
.line 482
:cond_34
iget-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
new-instance v7, Lokhttp3/internal/ws/RealWebSocket$CancelRunnable;
invoke-direct {v7, p0}, Lokhttp3/internal/ws/RealWebSocket$CancelRunnable;-><init>(Lokhttp3/internal/ws/RealWebSocket;)V
move-object v8, v5
check-cast v8, Lokhttp3/internal/ws/RealWebSocket$Close;
iget-wide v8, v8, Lokhttp3/internal/ws/RealWebSocket$Close;->cancelAfterCloseMillis:J
sget-object v10, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v3, v7, v8, v9, v10}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object v3
iput-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
move v3, v1
move-object v1, v4
goto :goto_51
:cond_4b
if-nez v5, :cond_4f
.line 486
monitor-exit p0
return v1
:cond_4f
move-object v1, v4
move-object v6, v1
:goto_51
move-object v4, v5
goto :goto_55
:cond_53
move-object v1, v4
move-object v6, v1
.line 489
:goto_55
monitor-exit p0
:try_end_56
.catchall {:try_start_1 .. :try_end_56} :catchall_b0
if-eqz v2, :cond_5c
.line 493
:try_start_58
invoke-virtual {v0, v2}, Lokhttp3/internal/ws/WebSocketWriter;->writePong(Lokio/ByteString;)V
goto :goto_a0
.line 495
:cond_5c
instance-of v2, v4, Lokhttp3/internal/ws/RealWebSocket$Message;
if-eqz v2, :cond_8c
.line 496
move-object v2, v4
check-cast v2, Lokhttp3/internal/ws/RealWebSocket$Message;
iget-object v2, v2, Lokhttp3/internal/ws/RealWebSocket$Message;->data:Lokio/ByteString;
.line 497
check-cast v4, Lokhttp3/internal/ws/RealWebSocket$Message;
iget v3, v4, Lokhttp3/internal/ws/RealWebSocket$Message;->formatOpcode:I
.line 498
invoke-virtual {v2}, Lokio/ByteString;->size()I
move-result v4
int-to-long v4, v4
.line 497
invoke-virtual {v0, v3, v4, v5}, Lokhttp3/internal/ws/WebSocketWriter;->newMessageSink(IJ)Lokio/Sink;
move-result-object v0
invoke-static {v0}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink;
move-result-object v0
.line 499
invoke-interface {v0, v2}, Lokio/BufferedSink;->write(Lokio/ByteString;)Lokio/BufferedSink;
.line 500
invoke-interface {v0}, Lokio/BufferedSink;->close()V
.line 501
monitor-enter p0
:try_end_7d
.catchall {:try_start_58 .. :try_end_7d} :catchall_ab
.line 502
:try_start_7d
iget-wide v3, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
invoke-virtual {v2}, Lokio/ByteString;->size()I
move-result v0
int-to-long v5, v0
sub-long/2addr v3, v5
iput-wide v3, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
.line 503
monitor-exit p0
goto :goto_a0
:catchall_89
move-exception v0
monitor-exit p0
:try_end_8b
.catchall {:try_start_7d .. :try_end_8b} :catchall_89
:try_start_8b
throw v0
.line 505
:cond_8c
instance-of v2, v4, Lokhttp3/internal/ws/RealWebSocket$Close;
if-eqz v2, :cond_a5
.line 506
check-cast v4, Lokhttp3/internal/ws/RealWebSocket$Close;
.line 507
iget v2, v4, Lokhttp3/internal/ws/RealWebSocket$Close;->code:I
iget-object v4, v4, Lokhttp3/internal/ws/RealWebSocket$Close;->reason:Lokio/ByteString;
invoke-virtual {v0, v2, v4}, Lokhttp3/internal/ws/WebSocketWriter;->writeClose(ILokio/ByteString;)V
if-eqz v1, :cond_a0
.line 511
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
invoke-virtual {v0, p0, v3, v6}, Lokhttp3/WebSocketListener;->onClosed(Lokhttp3/WebSocket;ILjava/lang/String;)V
:try_end_a0
.catchall {:try_start_8b .. :try_end_a0} :catchall_ab
:cond_a0
:goto_a0
const/4 v0, 0x1
.line 520
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
return v0
.line 515
:cond_a5
:try_start_a5
new-instance v0, Ljava/lang/AssertionError;
invoke-direct {v0}, Ljava/lang/AssertionError;-><init>()V
throw v0
:try_end_ab
.catchall {:try_start_a5 .. :try_end_ab} :catchall_ab
:catchall_ab
move-exception v0
.line 520
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
throw v0
:catchall_b0
move-exception v0
.line 489
:try_start_b1
monitor-exit p0
:try_end_b2
.catchall {:try_start_b1 .. :try_end_b2} :catchall_b0
throw v0
.end method
.method writePingFrame()V
.registers 8
.line 536
monitor-enter p0
.line 537
:try_start_1
iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-eqz v0, :cond_7
monitor-exit p0
return-void
.line 538
:cond_7
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter;
.line 539
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 540
: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 541
iput-boolean v4, p0, Lokhttp3/internal/ws/RealWebSocket;->awaitingPong:Z
.line 542
monitor-exit p0
:try_end_1b
.catchall {:try_start_1 .. :try_end_1b} :catchall_53
const/4 v3, 0x0
if-eq v1, v2, :cond_48
.line 545
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;
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
invoke-direct {v0, v1}, Ljava/net/SocketTimeoutException;-><init>(Ljava/lang/String;)V
invoke-virtual {p0, v0, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
return-void
.line 552
:cond_48
:try_start_48
sget-object v1, Lokio/ByteString;->EMPTY:Lokio/ByteString;
invoke-virtual {v0, v1}, Lokhttp3/internal/ws/WebSocketWriter;->writePing(Lokio/ByteString;)V
:try_end_4d
.catch Ljava/io/IOException; {:try_start_48 .. :try_end_4d} :catch_4e
goto :goto_52
:catch_4e
move-exception v0
.line 554
invoke-virtual {p0, v0, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
:goto_52
return-void
:catchall_53
move-exception v0
.line 542
:try_start_54
monitor-exit p0
:try_end_55
.catchall {:try_start_54 .. :try_end_55} :catchall_53
throw v0
.end method