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 56
nop
.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 9
.param p1, "request" # Lokhttp3/Request;
.param p2, "listener" # Lokhttp3/WebSocketListener;
.param p3, "random" # Ljava/util/Random;
.param p4, "pingIntervalMillis" # J
.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;
.line 122
const/4 v0, -0x1
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
.line 152
const/16 v0, 0x10
new-array v0, v0, [B
.line 153
.local v0, "nonce":[B
invoke-virtual {p3, v0}, Ljava/util/Random;->nextBytes([B)V
.line 154
invoke-static {v0}, Lokio/ByteString;->of([B)Lokio/ByteString;
move-result-object v1
invoke-virtual {v1}, Lokio/ByteString;->base64()Ljava/lang/String;
move-result-object v1
iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String;
.line 156
new-instance v1, Lokhttp3/internal/ws/RealWebSocket$1;
invoke-direct {v1, p0}, Lokhttp3/internal/ws/RealWebSocket$1;-><init>(Lokhttp3/internal/ws/RealWebSocket;)V
iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->writerRunnable:Ljava/lang/Runnable;
.line 166
return-void
.line 145
.end local v0 # "nonce":[B
:cond_41
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Request must be GET: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Lokhttp3/Request;->method()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private runWriter()V
.registers 3
.line 436
nop
.line 438
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
if-eqz v0, :cond_a
.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
.line 441
:cond_a
return-void
.end method
.method private declared-synchronized send(Lokio/ByteString;I)Z
.registers 9
.param p1, "data" # Lokio/ByteString;
.param p2, "formatOpcode" # I
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
.line 389
const/16 v0, 0x3e9
const/4 v2, 0x0
invoke-virtual {p0, v0, v2}, 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
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
: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
.line 397
const/4 v0, 0x1
monitor-exit p0
return v0
.line 385
:cond_3c
:goto_3c
monitor-exit p0
return v1
.line 384
.end local p1 # "data":Lokio/ByteString;
.end local p2 # "formatOpcode":I
:catchall_3e
move-exception p1
monitor-exit p0
throw p1
.end method
# virtual methods
.method awaitTermination(ILjava/util/concurrent/TimeUnit;)V
.registers 6
.param p1, "timeout" # I
.param p2, "timeUnit" # Ljava/util/concurrent/TimeUnit;
.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
.line 296
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
.line 178
return-void
.end method
.method checkResponse(Lokhttp3/Response;)V
.registers 10
.param p1, "response" # Lokhttp3/Response;
.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
.line 231
const-string v0, "Connection"
invoke-virtual {p1, v0}, Lokhttp3/Response;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 232
.local v0, "headerConnection":Ljava/lang/String;
const-string v2, "Upgrade"
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 v2
.line 238
.local v2, "headerUpgrade":Ljava/lang/String;
const-string v3, "websocket"
invoke-virtual {v3, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_72
.line 243
const-string v3, "Sec-WebSocket-Accept"
invoke-virtual {p1, v3}, Lokhttp3/Response;->header(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
.line 244
.local v3, "headerAccept":Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
iget-object v5, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, "258EAFA5-E914-47DA-95CA-C5AB0DC85B11"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v4}, Lokio/ByteString;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object v4
.line 245
invoke-virtual {v4}, Lokio/ByteString;->sha1()Lokio/ByteString;
move-result-object v4
invoke-virtual {v4}, Lokio/ByteString;->base64()Ljava/lang/String;
move-result-object v4
.line 246
.local v4, "acceptExpected":Ljava/lang/String;
invoke-virtual {v4, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v5
if-eqz v5, :cond_50
.line 250
return-void
.line 247
:cond_50
new-instance v5, Ljava/net/ProtocolException;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "Expected \'Sec-WebSocket-Accept\' header value \'"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v7, "\' but was \'"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v5, v1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw v5
.line 239
.end local v3 # "headerAccept":Ljava/lang/String;
.end local v4 # "acceptExpected":Ljava/lang/String;
:cond_72
new-instance v3, Ljava/net/ProtocolException;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Expected \'Upgrade\' header value \'websocket\' but was \'"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v3, v1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw v3
.line 233
.end local v2 # "headerUpgrade":Ljava/lang/String;
:cond_8c
new-instance v2, Ljava/net/ProtocolException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Expected \'Connection\' header value \'Upgrade\' but was \'"
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;
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 v1
invoke-direct {v2, v1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw v2
.line 227
.end local v0 # "headerConnection":Ljava/lang/String;
: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 v3
invoke-virtual {v2, v3}, 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 v1
invoke-direct {v0, v1}, Ljava/net/ProtocolException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public close(ILjava/lang/String;)Z
.registers 5
.param p1, "code" # I
.param p2, "reason" # Ljava/lang/String;
.line 410
const-wide/32 v0, 0xea60
invoke-virtual {p0, p1, p2, v0, v1}, Lokhttp3/internal/ws/RealWebSocket;->close(ILjava/lang/String;J)Z
move-result v0
return v0
.end method
.method declared-synchronized close(ILjava/lang/String;J)Z
.registers 11
.param p1, "code" # I
.param p2, "reason" # Ljava/lang/String;
.param p3, "cancelAfterCloseMillis" # J
monitor-enter p0
.line 414
:try_start_1
invoke-static {p1}, Lokhttp3/internal/ws/WebSocketProtocol;->validateCloseCode(I)V
.line 416
const/4 v0, 0x0
.line 417
.local v0, "reasonBytes":Lokio/ByteString;
if-eqz p2, :cond_2f
.line 418
invoke-static {p2}, Lokio/ByteString;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object v1
move-object v0, v1
.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_18
goto :goto_2f
.line 420
:cond_18
new-instance v1, Ljava/lang/IllegalArgumentException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "reason.size() > 123: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p2}, 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-direct {v1, v2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v1
.line 424
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
:cond_2f
:goto_2f
iget-boolean v1, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
if-nez v1, :cond_4a
iget-boolean v1, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
if-eqz v1, :cond_38
goto :goto_4a
.line 427
:cond_38
const/4 v1, 0x1
iput-boolean v1, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z
.line 430
iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
new-instance v3, Lokhttp3/internal/ws/RealWebSocket$Close;
invoke-direct {v3, p1, v0, p3, p4}, Lokhttp3/internal/ws/RealWebSocket$Close;-><init>(ILokio/ByteString;J)V
invoke-virtual {v2, v3}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
.line 431
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
:try_end_48
.catchall {:try_start_1 .. :try_end_48} :catchall_4d
.line 432
monitor-exit p0
return v1
.line 424
:cond_4a
:goto_4a
const/4 v1, 0x0
monitor-exit p0
return v1
.line 413
.end local v0 # "reasonBytes":Lokio/ByteString;
.end local p1 # "code":I
.end local p2 # "reason":Ljava/lang/String;
.end local p3 # "cancelAfterCloseMillis":J
:catchall_4d
move-exception p1
monitor-exit p0
throw p1
.end method
.method public connect(Lokhttp3/OkHttpClient;)V
.registers 5
.param p1, "client" # Lokhttp3/OkHttpClient;
.line 181
invoke-virtual {p1}, Lokhttp3/OkHttpClient;->newBuilder()Lokhttp3/OkHttpClient$Builder;
move-result-object v0
sget-object v1, Lokhttp3/EventListener;->NONE:Lokhttp3/EventListener;
.line 182
invoke-virtual {v0, v1}, Lokhttp3/OkHttpClient$Builder;->eventListener(Lokhttp3/EventListener;)Lokhttp3/OkHttpClient$Builder;
move-result-object v0
sget-object v1, Lokhttp3/internal/ws/RealWebSocket;->ONLY_HTTP1:Ljava/util/List;
.line 183
invoke-virtual {v0, v1}, Lokhttp3/OkHttpClient$Builder;->protocols(Ljava/util/List;)Lokhttp3/OkHttpClient$Builder;
move-result-object v0
.line 184
invoke-virtual {v0}, 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
.line 186
const-string v1, "Upgrade"
const-string v2, "websocket"
invoke-virtual {v0, v1, v2}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder;
move-result-object v0
.line 187
const-string v2, "Connection"
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;
.line 188
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
.line 189
const-string v1, "Sec-WebSocket-Version"
const-string v2, "13"
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
.local v0, "request":Lokhttp3/Request;
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 v1
iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->call:Lokhttp3/Call;
.line 192
new-instance v2, Lokhttp3/internal/ws/RealWebSocket$2;
invoke-direct {v2, p0, v0}, Lokhttp3/internal/ws/RealWebSocket$2;-><init>(Lokhttp3/internal/ws/RealWebSocket;Lokhttp3/Request;)V
invoke-interface {v1, v2}, Lokhttp3/Call;->enqueue(Lokhttp3/Callback;)V
.line 223
return-void
.end method
.method public failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
.registers 6
.param p1, "e" # Ljava/lang/Exception;
.param p2, "response" # 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
.line 562
:cond_7
const/4 v0, 0x1
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;
.line 564
.local v0, "streamsToClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
const/4 v1, 0x0
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_19
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
const/4 v2, 0x0
invoke-interface {v1, v2}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
.line 566
:cond_19
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
if-eqz v1, :cond_22
iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v1}, Ljava/util/concurrent/ScheduledExecutorService;->shutdown()V
.line 567
:cond_22
monitor-exit p0
:try_end_23
.catchall {:try_start_1 .. :try_end_23} :catchall_32
.line 570
:try_start_23
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_28
.catchall {:try_start_23 .. :try_end_28} :catchall_2d
.line 572
invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
.line 573
nop
.line 574
return-void
.line 572
:catchall_2d
move-exception v1
invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
throw v1
.line 567
.end local v0 # "streamsToClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
:catchall_32
move-exception v0
:try_start_33
monitor-exit p0
:try_end_34
.catchall {:try_start_33 .. :try_end_34} :catchall_32
throw v0
.end method
.method public initReaderAndWriter(Ljava/lang/String;Lokhttp3/internal/ws/RealWebSocket$Streams;)V
.registers 14
.param p1, "name" # Ljava/lang/String;
.param p2, "streams" # Lokhttp3/internal/ws/RealWebSocket$Streams;
.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 v1
invoke-direct {v4, v0, v1}, 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 v5, v0, v2
if-eqz v5, :cond_33
.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 v6, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
iget-wide v8, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
sget-object v10, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface/range {v4 .. v10}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
.line 261
:cond_33
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result v0
if-nez v0, :cond_3e
.line 262
invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V
.line 264
:cond_3e
monitor-exit p0
:try_end_3f
.catchall {:try_start_1 .. :try_end_3f} :catchall_4b
.line 266
new-instance v0, Lokhttp3/internal/ws/WebSocketReader;
iget-boolean v1, p2, Lokhttp3/internal/ws/RealWebSocket$Streams;->client:Z
iget-object v2, p2, Lokhttp3/internal/ws/RealWebSocket$Streams;->source:Lokio/BufferedSource;
invoke-direct {v0, v1, v2, p0}, Lokhttp3/internal/ws/WebSocketReader;-><init>(ZLokio/BufferedSource;Lokhttp3/internal/ws/WebSocketReader$FrameCallback;)V
iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader;
.line 267
return-void
.line 264
:catchall_4b
move-exception v0
:try_start_4c
monitor-exit p0
:try_end_4d
.catchall {:try_start_4c .. :try_end_4d} :catchall_4b
throw v0
.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
.line 275
:cond_b
return-void
.end method
.method public onReadClose(ILjava/lang/String;)V
.registers 6
.param p1, "code" # I
.param p2, "reason" # Ljava/lang/String;
.line 345
const/4 v0, -0x1
if-eq p1, v0, :cond_50
.line 347
const/4 v1, 0x0
.line 348
.local v1, "toClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
monitor-enter p0
.line 349
:try_start_5
iget v2, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
if-ne v2, v0, :cond_45
.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
if-eqz v0, :cond_2e
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_2e
.line 353
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
move-object v1, v0
.line 354
const/4 v0, 0x0
iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 355
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
if-eqz v0, :cond_29
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
const/4 v2, 0x0
invoke-interface {v0, v2}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
.line 356
:cond_29
iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ScheduledExecutorService;->shutdown()V
.line 358
:cond_2e
monitor-exit p0
:try_end_2f
.catchall {:try_start_5 .. :try_end_2f} :catchall_4d
.line 361
:try_start_2f
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
.line 363
if-eqz v1, :cond_3b
.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_3b
.catchall {:try_start_2f .. :try_end_3b} :catchall_40
.line 367
:cond_3b
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
.line 368
nop
.line 369
return-void
.line 367
:catchall_40
move-exception v0
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
throw v0
.line 349
:cond_45
:try_start_45
new-instance v0, Ljava/lang/IllegalStateException;
const-string v2, "already closed"
invoke-direct {v0, v2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
.end local v1 # "toClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
.end local p1 # "code":I
.end local p2 # "reason":Ljava/lang/String;
throw v0
.line 358
.restart local v1 # "toClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
.restart local p1 # "code":I
.restart local p2 # "reason":Ljava/lang/String;
:catchall_4d
move-exception v0
monitor-exit p0
:try_end_4f
.catchall {:try_start_45 .. :try_end_4f} :catchall_4d
throw v0
.line 345
.end local v1 # "toClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
:cond_50
new-instance v0, Ljava/lang/IllegalArgumentException;
invoke-direct {v0}, Ljava/lang/IllegalArgumentException;-><init>()V
throw v0
.end method
.method public onReadMessage(Ljava/lang/String;)V
.registers 3
.param p1, "text" # Ljava/lang/String;
.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
.line 323
return-void
.end method
.method public onReadMessage(Lokio/ByteString;)V
.registers 3
.param p1, "bytes" # Lokio/ByteString;
.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
.line 327
return-void
.end method
.method public declared-synchronized onReadPing(Lokio/ByteString;)V
.registers 3
.param p1, "payload" # Lokio/ByteString;
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
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
: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 v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPingCount:I
add-int/lit8 v0, v0, 0x1
iput v0, 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
.line 330
.end local p1 # "payload":Lokio/ByteString;
:catchall_24
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized onReadPong(Lokio/ByteString;)V
.registers 3
.param p1, "buffer" # Lokio/ByteString;
monitor-enter p0
.line 340
:try_start_1
iget v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPongCount:I
add-int/lit8 v0, v0, 0x1
iput v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPongCount:I
.line 341
const/4 v0, 0x0
iput-boolean v0, 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
.line 339
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
.end local p1 # "buffer":Lokio/ByteString;
:catchall_c
move-exception p1
monitor-exit p0
throw p1
.end method
.method declared-synchronized pong(Lokio/ByteString;)Z
.registers 3
.param p1, "payload" # Lokio/ByteString;
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
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
: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
.line 406
const/4 v0, 0x1
monitor-exit p0
return v0
.line 402
:cond_1d
:goto_1d
const/4 v0, 0x0
monitor-exit p0
return v0
.line 401
.end local p1 # "payload":Lokio/ByteString;
: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
.line 283
const/4 v0, 0x0
: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
.line 285
:catch_d
move-exception v1
.line 286
.local v1, "e":Ljava/lang/Exception;
const/4 v2, 0x0
invoke-virtual {p0, v1, v2}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
.line 287
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
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
: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
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
: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
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
: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 4
.param p1, "text" # Ljava/lang/String;
.line 374
if-eqz p1, :cond_c
.line 375
invoke-static {p1}, Lokio/ByteString;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString;
move-result-object v0
const/4 v1, 0x1
invoke-direct {p0, v0, v1}, Lokhttp3/internal/ws/RealWebSocket;->send(Lokio/ByteString;I)Z
move-result v0
return v0
.line 374
:cond_c
new-instance v0, Ljava/lang/NullPointerException;
const-string v1, "text == null"
invoke-direct {v0, v1}, Ljava/lang/NullPointerException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public send(Lokio/ByteString;)Z
.registers 4
.param p1, "bytes" # Lokio/ByteString;
.line 379
if-eqz p1, :cond_8
.line 380
const/4 v0, 0x2
invoke-direct {p0, p1, v0}, Lokhttp3/internal/ws/RealWebSocket;->send(Lokio/ByteString;I)Z
move-result v0
return v0
.line 379
:cond_8
new-instance v0, Ljava/lang/NullPointerException;
const-string v1, "bytes == null"
invoke-direct {v0, v1}, Ljava/lang/NullPointerException;-><init>(Ljava/lang/String;)V
throw v0
.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
.end local p0 # "this":Lokhttp3/internal/ws/RealWebSocket;
: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
.line 303
const/4 v1, 0x0
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
.line 307
return-void
.end method
.method writeOneFrame()Z
.registers 13
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 459
const/4 v0, 0x0
.line 460
.local v0, "messageOrClose":Ljava/lang/Object;
const/4 v1, -0x1
.line 461
.local v1, "receivedCloseCode":I
const/4 v2, 0x0
.line 462
.local v2, "receivedCloseReason":Ljava/lang/String;
const/4 v3, 0x0
.line 464
.local v3, "streamsToClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
monitor-enter p0
.line 465
:try_start_5
iget-boolean v4, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z
const/4 v5, 0x0
if-eqz v4, :cond_c
.line 466
monitor-exit p0
return v5
.line 469
:cond_c
iget-object v4, p0, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter;
.line 470
.local v4, "writer":Lokhttp3/internal/ws/WebSocketWriter;
iget-object v6, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque;
invoke-virtual {v6}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object;
move-result-object v6
check-cast v6, Lokio/ByteString;
.line 471
.local v6, "pong":Lokio/ByteString;
if-nez v6, :cond_52
.line 472
iget-object v7, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque;
invoke-virtual {v7}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object;
move-result-object v7
move-object v0, v7
.line 473
nop
instance-of v7, v0, Lokhttp3/internal/ws/RealWebSocket$Close;
if-eqz v7, :cond_4e
.line 474
iget v5, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I
move v1, v5
.line 475
iget-object v5, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseReason:Ljava/lang/String;
move-object v2, v5
.line 476
const/4 v5, -0x1
if-eq v1, v5, :cond_39
.line 477
iget-object v5, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
move-object v3, v5
.line 478
const/4 v5, 0x0
iput-object v5, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams;
.line 479
iget-object v5, p0, Lokhttp3/internal/ws/RealWebSocket;->executor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v5}, Ljava/util/concurrent/ScheduledExecutorService;->shutdown()V
goto :goto_52
.line 482
:cond_39
iget-object v5, 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, v0
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 {v5, v7, v8, v9, v10}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object v5
iput-object v5, p0, Lokhttp3/internal/ws/RealWebSocket;->cancelFuture:Ljava/util/concurrent/ScheduledFuture;
goto :goto_52
.line 485
:cond_4e
if-nez v0, :cond_52
.line 486
monitor-exit p0
return v5
.line 489
:cond_52
:goto_52
monitor-exit p0
:try_end_53
.catchall {:try_start_5 .. :try_end_53} :catchall_b0
.line 492
if-eqz v6, :cond_59
.line 493
:try_start_55
invoke-virtual {v4, v6}, Lokhttp3/internal/ws/WebSocketWriter;->writePong(Lokio/ByteString;)V
goto :goto_a0
.line 495
:cond_59
instance-of v5, v0, Lokhttp3/internal/ws/RealWebSocket$Message;
if-eqz v5, :cond_8a
.line 496
move-object v5, v0
check-cast v5, Lokhttp3/internal/ws/RealWebSocket$Message;
iget-object v5, v5, Lokhttp3/internal/ws/RealWebSocket$Message;->data:Lokio/ByteString;
.line 497
.local v5, "data":Lokio/ByteString;
move-object v7, v0
check-cast v7, Lokhttp3/internal/ws/RealWebSocket$Message;
iget v7, v7, Lokhttp3/internal/ws/RealWebSocket$Message;->formatOpcode:I
.line 498
invoke-virtual {v5}, Lokio/ByteString;->size()I
move-result v8
int-to-long v8, v8
.line 497
invoke-virtual {v4, v7, v8, v9}, Lokhttp3/internal/ws/WebSocketWriter;->newMessageSink(IJ)Lokio/Sink;
move-result-object v7
invoke-static {v7}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink;
move-result-object v7
.line 499
.local v7, "sink":Lokio/BufferedSink;
invoke-interface {v7, v5}, Lokio/BufferedSink;->write(Lokio/ByteString;)Lokio/BufferedSink;
.line 500
invoke-interface {v7}, Lokio/BufferedSink;->close()V
.line 501
monitor-enter p0
:try_end_7b
.catchall {:try_start_55 .. :try_end_7b} :catchall_ab
.line 502
:try_start_7b
iget-wide v8, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
invoke-virtual {v5}, Lokio/ByteString;->size()I
move-result v10
int-to-long v10, v10
sub-long/2addr v8, v10
iput-wide v8, p0, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J
.line 503
monitor-exit p0
.line 505
.end local v5 # "data":Lokio/ByteString;
.end local v7 # "sink":Lokio/BufferedSink;
goto :goto_a0
.line 503
.restart local v5 # "data":Lokio/ByteString;
.restart local v7 # "sink":Lokio/BufferedSink;
:catchall_87
move-exception v8
monitor-exit p0
:try_end_89
.catchall {:try_start_7b .. :try_end_89} :catchall_87
.end local v0 # "messageOrClose":Ljava/lang/Object;
.end local v1 # "receivedCloseCode":I
.end local v2 # "receivedCloseReason":Ljava/lang/String;
.end local v3 # "streamsToClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
.end local v4 # "writer":Lokhttp3/internal/ws/WebSocketWriter;
.end local v6 # "pong":Lokio/ByteString;
:try_start_89
throw v8
.line 505
.end local v5 # "data":Lokio/ByteString;
.end local v7 # "sink":Lokio/BufferedSink;
.restart local v0 # "messageOrClose":Ljava/lang/Object;
.restart local v1 # "receivedCloseCode":I
.restart local v2 # "receivedCloseReason":Ljava/lang/String;
.restart local v3 # "streamsToClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
.restart local v4 # "writer":Lokhttp3/internal/ws/WebSocketWriter;
.restart local v6 # "pong":Lokio/ByteString;
:cond_8a
instance-of v5, v0, Lokhttp3/internal/ws/RealWebSocket$Close;
if-eqz v5, :cond_a5
.line 506
move-object v5, v0
check-cast v5, Lokhttp3/internal/ws/RealWebSocket$Close;
.line 507
.local v5, "close":Lokhttp3/internal/ws/RealWebSocket$Close;
iget v7, v5, Lokhttp3/internal/ws/RealWebSocket$Close;->code:I
iget-object v8, v5, Lokhttp3/internal/ws/RealWebSocket$Close;->reason:Lokio/ByteString;
invoke-virtual {v4, v7, v8}, Lokhttp3/internal/ws/WebSocketWriter;->writeClose(ILokio/ByteString;)V
.line 510
if-eqz v3, :cond_9f
.line 511
iget-object v7, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener;
invoke-virtual {v7, p0, v1, v2}, Lokhttp3/WebSocketListener;->onClosed(Lokhttp3/WebSocket;ILjava/lang/String;)V
:try_end_9f
.catchall {:try_start_89 .. :try_end_9f} :catchall_ab
.line 514
.end local v5 # "close":Lokhttp3/internal/ws/RealWebSocket$Close;
:cond_9f
nop
.line 518
:goto_a0
const/4 v5, 0x1
.line 520
invoke-static {v3}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
.line 518
return v5
.line 515
:cond_a5
:try_start_a5
new-instance v5, Ljava/lang/AssertionError;
invoke-direct {v5}, Ljava/lang/AssertionError;-><init>()V
.end local v0 # "messageOrClose":Ljava/lang/Object;
.end local v1 # "receivedCloseCode":I
.end local v2 # "receivedCloseReason":Ljava/lang/String;
.end local v3 # "streamsToClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
.end local v4 # "writer":Lokhttp3/internal/ws/WebSocketWriter;
.end local v6 # "pong":Lokio/ByteString;
throw v5
:try_end_ab
.catchall {:try_start_a5 .. :try_end_ab} :catchall_ab
.line 520
.restart local v0 # "messageOrClose":Ljava/lang/Object;
.restart local v1 # "receivedCloseCode":I
.restart local v2 # "receivedCloseReason":Ljava/lang/String;
.restart local v3 # "streamsToClose":Lokhttp3/internal/ws/RealWebSocket$Streams;
.restart local v4 # "writer":Lokhttp3/internal/ws/WebSocketWriter;
.restart local v6 # "pong":Lokio/ByteString;
:catchall_ab
move-exception v5
invoke-static {v3}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V
throw v5
.line 489
.end local v4 # "writer":Lokhttp3/internal/ws/WebSocketWriter;
.end local v6 # "pong":Lokio/ByteString;
:catchall_b0
move-exception v4
:try_start_b1
monitor-exit p0
:try_end_b2
.catchall {:try_start_b1 .. :try_end_b2} :catchall_b0
throw v4
.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
.local v0, "writer":Lokhttp3/internal/ws/WebSocketWriter;
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
.local v1, "failedPing":I
: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_54
.line 544
const/4 v3, 0x0
if-eq v1, v2, :cond_49
.line 545
new-instance v2, Ljava/net/SocketTimeoutException;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "sent ping but didn\'t receive pong within "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v5, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J
invoke-virtual {v4, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v5, "ms (after "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
add-int/lit8 v5, v1, -0x1
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v5, " successful ping/pongs)"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-direct {v2, v4}, Ljava/net/SocketTimeoutException;-><init>(Ljava/lang/String;)V
invoke-virtual {p0, v2, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
.line 548
return-void
.line 552
:cond_49
:try_start_49
sget-object v2, Lokio/ByteString;->EMPTY:Lokio/ByteString;
invoke-virtual {v0, v2}, Lokhttp3/internal/ws/WebSocketWriter;->writePing(Lokio/ByteString;)V
:try_end_4e
.catch Ljava/io/IOException; {:try_start_49 .. :try_end_4e} :catch_4f
.line 555
goto :goto_53
.line 553
:catch_4f
move-exception v2
.line 554
.local v2, "e":Ljava/io/IOException;
invoke-virtual {p0, v2, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V
.line 556
.end local v2 # "e":Ljava/io/IOException;
:goto_53
return-void
.line 542
.end local v0 # "writer":Lokhttp3/internal/ws/WebSocketWriter;
.end local v1 # "failedPing":I
:catchall_54
move-exception v0
:try_start_55
monitor-exit p0
:try_end_56
.catchall {:try_start_55 .. :try_end_56} :catchall_54
throw v0
.end method