.class public final Lokhttp3/internal/ws/RealWebSocket; .super Ljava/lang/Object; .source "RealWebSocket.kt" # interfaces .implements Lokhttp3/WebSocket; .implements Lokhttp3/internal/ws/WebSocketReader$FrameCallback; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lokhttp3/internal/ws/RealWebSocket$Message;, Lokhttp3/internal/ws/RealWebSocket$Close;, Lokhttp3/internal/ws/RealWebSocket$Streams;, Lokhttp3/internal/ws/RealWebSocket$WriterTask;, Lokhttp3/internal/ws/RealWebSocket$Companion; } .end annotation .annotation system Ldalvik/annotation/SourceDebugExtension; value = "SMAP\nRealWebSocket.kt\nKotlin\n*S Kotlin\n*F\n+ 1 RealWebSocket.kt\nokhttp3/internal/ws/RealWebSocket\n+ 2 TaskQueue.kt\nokhttp3/internal/concurrent/TaskQueue\n+ 3 Util.kt\nokhttp3/internal/Util\n*L\n1#1,571:1\n84#2,4:572\n93#2,10:580\n573#3,4:576\n*E\n*S KotlinDebug\n*F\n+ 1 RealWebSocket.kt\nokhttp3/internal/ws/RealWebSocket\n*L\n216#1,4:572\n427#1,10:580\n397#1,4:576\n*E\n" .end annotation .annotation runtime Lkotlin/Metadata; bv = { 0x1, 0x0, 0x3 } d1 = { "\u0000\u00b0\u0001\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\t\n\u0002\u0008\u0002\n\u0002\u0010\u000b\n\u0000\n\u0002\u0018\u0002\n\u0002\u0008\u0003\n\u0002\u0010\u000e\n\u0002\u0008\u0003\n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0008\n\u0002\u0008\u0005\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0002\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0002\u0008\u0003\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\u0008\u0007\n\u0002\u0018\u0002\n\u0002\u0008\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0008\u001b\u0018\u0000 \\2\u00020\u00012\u00020\u0002:\u0005[\\]^_B-\u0012\u0006\u0010\u0003\u001a\u00020\u0004\u0012\u0006\u0010\u0005\u001a\u00020\u0006\u0012\u0006\u0010\u0007\u001a\u00020\u0008\u0012\u0006\u0010\t\u001a\u00020\n\u0012\u0006\u0010\u000b\u001a\u00020\u000c\u00a2\u0006\u0002\u0010\rJ\u0016\u0010/\u001a\u0002002\u0006\u00101\u001a\u00020\u000c2\u0006\u00102\u001a\u000203J\u0008\u00104\u001a\u000200H\u0016J\u001f\u00105\u001a\u0002002\u0006\u00106\u001a\u0002072\u0008\u00108\u001a\u0004\u0018\u000109H\u0000\u00a2\u0006\u0002\u0008:J\u001a\u0010;\u001a\u00020\u000f2\u0006\u0010<\u001a\u00020\"2\u0008\u0010=\u001a\u0004\u0018\u00010\u0015H\u0016J \u0010;\u001a\u00020\u000f2\u0006\u0010<\u001a\u00020\"2\u0008\u0010=\u001a\u0004\u0018\u00010\u00152\u0006\u0010>\u001a\u00020\u000cJ\u000e\u0010?\u001a\u0002002\u0006\u0010@\u001a\u00020AJ\u001c\u0010B\u001a\u0002002\n\u0010C\u001a\u00060Dj\u0002`E2\u0008\u00106\u001a\u0004\u0018\u000107J\u0016\u0010F\u001a\u0002002\u0006\u0010\u001b\u001a\u00020\u00152\u0006\u0010\'\u001a\u00020(J\u0006\u0010G\u001a\u000200J\u0018\u0010H\u001a\u0002002\u0006\u0010<\u001a\u00020\"2\u0006\u0010=\u001a\u00020\u0015H\u0016J\u0010\u0010I\u001a\u0002002\u0006\u0010J\u001a\u00020\u0015H\u0016J\u0010\u0010I\u001a\u0002002\u0006\u0010K\u001a\u00020\u001dH\u0016J\u0010\u0010L\u001a\u0002002\u0006\u0010M\u001a\u00020\u001dH\u0016J\u0010\u0010N\u001a\u0002002\u0006\u0010M\u001a\u00020\u001dH\u0016J\u000e\u0010O\u001a\u00020\u000f2\u0006\u0010M\u001a\u00020\u001dJ\u0006\u0010P\u001a\u00020\u000fJ\u0008\u0010\u001e\u001a\u00020\u000cH\u0016J\u0006\u0010$\u001a\u00020\"J\u0006\u0010%\u001a\u00020\"J\u0008\u0010Q\u001a\u00020\u0006H\u0016J\u0008\u0010R\u001a\u000200H\u0002J\u0010\u0010S\u001a\u00020\u000f2\u0006\u0010J\u001a\u00020\u0015H\u0016J\u0010\u0010S\u001a\u00020\u000f2\u0006\u0010K\u001a\u00020\u001dH\u0016J\u0018\u0010S\u001a\u00020\u000f2\u0006\u0010T\u001a\u00020\u001d2\u0006\u0010U\u001a\u00020\"H\u0002J\u0006\u0010&\u001a\u00020\"J\u0006\u0010V\u001a\u000200J\r\u0010W\u001a\u00020\u000fH\u0000\u00a2\u0006\u0002\u0008XJ\r\u0010Y\u001a\u000200H\u0000\u00a2\u0006\u0002\u0008ZR\u000e\u0010\u000e\u001a\u00020\u000fX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010\u0010\u001a\u0004\u0018\u00010\u0011X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0012\u001a\u00020\u000fX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0013\u001a\u00020\u000fX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0014\u001a\u00020\u0015X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0014\u0010\u0007\u001a\u00020\u0008X\u0080\u0004\u00a2\u0006\u0008\n\u0000\u001a\u0004\u0008\u0016\u0010\u0017R\u0014\u0010\u0018\u001a\u0008\u0012\u0004\u0012\u00020\u001a0\u0019X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0010\u0010\u001b\u001a\u0004\u0018\u00010\u0015X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u000b\u001a\u00020\u000cX\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0014\u0010\u001c\u001a\u0008\u0012\u0004\u0012\u00020\u001d0\u0019X\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u000e\u0010\u001e\u001a\u00020\u000cX\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010\t\u001a\u00020\nX\u0082\u0004\u00a2\u0006\u0002\n\u0000R\u0010\u0010\u001f\u001a\u0004\u0018\u00010 X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010!\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010#\u001a\u0004\u0018\u00010\u0015X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010$\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010%\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010&\u001a\u00020\"X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010\'\u001a\u0004\u0018\u00010(X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u000e\u0010)\u001a\u00020*X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010+\u001a\u0004\u0018\u00010,X\u0082\u000e\u00a2\u0006\u0002\n\u0000R\u0010\u0010-\u001a\u0004\u0018\u00010.X\u0082\u000e\u00a2\u0006\u0002\n\u0000\u00a8\u0006`" } d2 = { "Lokhttp3/internal/ws/RealWebSocket;", "Lokhttp3/WebSocket;", "Lokhttp3/internal/ws/WebSocketReader$FrameCallback;", "taskRunner", "Lokhttp3/internal/concurrent/TaskRunner;", "originalRequest", "Lokhttp3/Request;", "listener", "Lokhttp3/WebSocketListener;", "random", "Ljava/util/Random;", "pingIntervalMillis", "", "(Lokhttp3/internal/concurrent/TaskRunner;Lokhttp3/Request;Lokhttp3/WebSocketListener;Ljava/util/Random;J)V", "awaitingPong", "", "call", "Lokhttp3/Call;", "enqueuedClose", "failed", "key", "", "getListener$okhttp", "()Lokhttp3/WebSocketListener;", "messageAndCloseQueue", "Ljava/util/ArrayDeque;", "", "name", "pongQueue", "Lokio/ByteString;", "queueSize", "reader", "Lokhttp3/internal/ws/WebSocketReader;", "receivedCloseCode", "", "receivedCloseReason", "receivedPingCount", "receivedPongCount", "sentPingCount", "streams", "Lokhttp3/internal/ws/RealWebSocket$Streams;", "taskQueue", "Lokhttp3/internal/concurrent/TaskQueue;", "writer", "Lokhttp3/internal/ws/WebSocketWriter;", "writerTask", "Lokhttp3/internal/concurrent/Task;", "awaitTermination", "", "timeout", "timeUnit", "Ljava/util/concurrent/TimeUnit;", "cancel", "checkUpgradeSuccess", "response", "Lokhttp3/Response;", "exchange", "Lokhttp3/internal/connection/Exchange;", "checkUpgradeSuccess$okhttp", "close", "code", "reason", "cancelAfterCloseMillis", "connect", "client", "Lokhttp3/OkHttpClient;", "failWebSocket", "e", "Ljava/lang/Exception;", "Lkotlin/Exception;", "initReaderAndWriter", "loopReader", "onReadClose", "onReadMessage", "text", "bytes", "onReadPing", "payload", "onReadPong", "pong", "processNextFrame", "request", "runWriter", "send", "data", "formatOpcode", "tearDown", "writeOneFrame", "writeOneFrame$okhttp", "writePingFrame", "writePingFrame$okhttp", "Close", "Companion", "Message", "Streams", "WriterTask", "okhttp" } k = 0x1 mv = { 0x1, 0x1, 0x10 } .end annotation # static fields .field private static final CANCEL_AFTER_CLOSE_MILLIS:J = 0xea60L .field public static final Companion:Lokhttp3/internal/ws/RealWebSocket$Companion; .field private static final MAX_QUEUE_SIZE:J = 0x1000000L .field private static final ONLY_HTTP1:Ljava/util/List; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/List<", "Lokhttp3/Protocol;", ">;" } .end annotation .end field # instance fields .field private awaitingPong:Z .field private call:Lokhttp3/Call; .field private enqueuedClose:Z .field private failed:Z .field private final key:Ljava/lang/String; .field private final listener:Lokhttp3/WebSocketListener; .field private final messageAndCloseQueue:Ljava/util/ArrayDeque; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/ArrayDeque<", "Ljava/lang/Object;", ">;" } .end annotation .end field .field private name:Ljava/lang/String; .field private final originalRequest:Lokhttp3/Request; .field private final pingIntervalMillis:J .field private final pongQueue:Ljava/util/ArrayDeque; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/ArrayDeque<", "Lokio/ByteString;", ">;" } .end annotation .end field .field private queueSize:J .field private final random:Ljava/util/Random; .field private reader:Lokhttp3/internal/ws/WebSocketReader; .field private receivedCloseCode:I .field private receivedCloseReason:Ljava/lang/String; .field private receivedPingCount:I .field private receivedPongCount:I .field private sentPingCount:I .field private streams:Lokhttp3/internal/ws/RealWebSocket$Streams; .field private taskQueue:Lokhttp3/internal/concurrent/TaskQueue; .field private writer:Lokhttp3/internal/ws/WebSocketWriter; .field private writerTask:Lokhttp3/internal/concurrent/Task; # direct methods .method static constructor ()V .registers 2 new-instance v0, Lokhttp3/internal/ws/RealWebSocket$Companion; const/4 v1, 0x0 invoke-direct {v0, v1}, Lokhttp3/internal/ws/RealWebSocket$Companion;->(Lkotlin/jvm/internal/DefaultConstructorMarker;)V sput-object v0, Lokhttp3/internal/ws/RealWebSocket;->Companion:Lokhttp3/internal/ws/RealWebSocket$Companion; .line 556 sget-object v0, Lokhttp3/Protocol;->HTTP_1_1:Lokhttp3/Protocol; invoke-static {v0}, Lkotlin/collections/CollectionsKt;->listOf(Ljava/lang/Object;)Ljava/util/List; move-result-object v0 sput-object v0, Lokhttp3/internal/ws/RealWebSocket;->ONLY_HTTP1:Ljava/util/List; return-void .end method .method public constructor (Lokhttp3/internal/concurrent/TaskRunner;Lokhttp3/Request;Lokhttp3/WebSocketListener;Ljava/util/Random;J)V .registers 13 const-string v0, "taskRunner" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V const-string v0, "originalRequest" invoke-static {p2, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V const-string v0, "listener" invoke-static {p3, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V const-string v0, "random" invoke-static {p4, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 54 invoke-direct {p0}, Ljava/lang/Object;->()V iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request; iput-object p3, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; iput-object p4, p0, Lokhttp3/internal/ws/RealWebSocket;->random:Ljava/util/Random; iput-wide p5, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J .line 79 invoke-virtual {p1}, Lokhttp3/internal/concurrent/TaskRunner;->newQueue()Lokhttp3/internal/concurrent/TaskQueue; move-result-object p1 iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; .line 92 new-instance p1, Ljava/util/ArrayDeque; invoke-direct {p1}, Ljava/util/ArrayDeque;->()V iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque; .line 95 new-instance p1, Ljava/util/ArrayDeque; invoke-direct {p1}, Ljava/util/ArrayDeque;->()V iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque; const/4 p1, -0x1 .line 104 iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I .line 125 const-string p1, "GET" invoke-virtual {p2}, Lokhttp3/Request;->method()Ljava/lang/String; move-result-object p3 invoke-static {p1, p3}, Lkotlin/jvm/internal/Intrinsics;->areEqual(Ljava/lang/Object;Ljava/lang/Object;)Z move-result p1 if-eqz p1, :cond_5a .line 129 sget-object v0, Lokio/ByteString;->Companion:Lokio/ByteString$Companion; const/16 p1, 0x10 new-array v1, p1, [B invoke-virtual {p4, v1}, Ljava/util/Random;->nextBytes([B)V const/4 v4, 0x3 const/4 v5, 0x0 const/4 v2, 0x0 const/4 v3, 0x0 invoke-static/range {v0 .. v5}, Lokio/ByteString$Companion;->of$default(Lokio/ByteString$Companion;[BIIILjava/lang/Object;)Lokio/ByteString; move-result-object p1 invoke-virtual {p1}, Lokio/ByteString;->base64()Ljava/lang/String; move-result-object p1 iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String; return-void .line 126 :cond_5a new-instance p1, Ljava/lang/StringBuilder; const-string p3, "Request must be GET: " invoke-direct {p1, p3}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {p2}, Lokhttp3/Request;->method()Ljava/lang/String; move-result-object p2 invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 .line 125 new-instance p2, Ljava/lang/IllegalArgumentException; invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p1 invoke-direct {p2, p1}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V check-cast p2, Ljava/lang/Throwable; throw p2 .end method .method public static final synthetic access$getName$p(Lokhttp3/internal/ws/RealWebSocket;)Ljava/lang/String; .registers 1 .line 54 iget-object p0, p0, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String; return-object p0 .end method .method public static final synthetic access$setName$p(Lokhttp3/internal/ws/RealWebSocket;Ljava/lang/String;)V .registers 2 .line 54 iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String; return-void .end method .method private final runWriter()V .registers 8 .line 576 sget-boolean v0, Lokhttp3/internal/Util;->assertionsEnabled:Z if-eqz v0, :cond_39 invoke-static {p0}, Ljava/lang/Thread;->holdsLock(Ljava/lang/Object;)Z move-result v0 if-eqz v0, :cond_b goto :goto_39 .line 577 :cond_b new-instance v0, Ljava/lang/AssertionError; new-instance v1, Ljava/lang/StringBuilder; const-string v2, "Thread " invoke-direct {v1, v2}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread; move-result-object v2 const-string v3, "Thread.currentThread()" invoke-static {v2, v3}, Lkotlin/jvm/internal/Intrinsics;->checkExpressionValueIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 const-string v2, " MUST hold lock on " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-direct {v0, v1}, Ljava/lang/AssertionError;->(Ljava/lang/Object;)V check-cast v0, Ljava/lang/Throwable; throw v0 .line 399 :cond_39 :goto_39 iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->writerTask:Lokhttp3/internal/concurrent/Task; if-eqz v2, :cond_46 .line 401 iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; const/4 v5, 0x2 const/4 v6, 0x0 const-wide/16 v3, 0x0 invoke-static/range {v1 .. v6}, Lokhttp3/internal/concurrent/TaskQueue;->schedule$default(Lokhttp3/internal/concurrent/TaskQueue;Lokhttp3/internal/concurrent/Task;JILjava/lang/Object;)V :cond_46 return-void .end method .method private final declared-synchronized send(Lokio/ByteString;I)Z .registers 9 monitor-enter p0 .line 342 :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 345 :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 346 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 347 monitor-exit p0 return v1 .line 351 :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 352 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;->(ILokio/ByteString;)V invoke-virtual {v0, v1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z .line 353 invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V :try_end_39 .catchall {:try_start_22 .. :try_end_39} :catchall_3e .line 354 monitor-exit p0 const/4 p1, 0x1 return p1 .line 342 :cond_3c :goto_3c monitor-exit p0 return v1 :catchall_3e move-exception p1 :try_start_3f monitor-exit p0 :try_end_40 .catchall {:try_start_3f .. :try_end_40} :catchall_3e throw p1 .end method # virtual methods .method public final awaitTermination(JLjava/util/concurrent/TimeUnit;)V .registers 5 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/InterruptedException; } .end annotation const-string v0, "timeUnit" invoke-static {p3, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 263 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskQueue;->idleLatch()Ljava/util/concurrent/CountDownLatch; move-result-object v0 invoke-virtual {v0, p1, p2, p3}, Ljava/util/concurrent/CountDownLatch;->await(JLjava/util/concurrent/TimeUnit;)Z return-void .end method .method public cancel()V .registers 2 .line 137 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->call:Lokhttp3/Call; if-nez v0, :cond_7 invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V :cond_7 invoke-interface {v0}, Lokhttp3/Call;->cancel()V return-void .end method .method public final checkUpgradeSuccess$okhttp(Lokhttp3/Response;Lokhttp3/internal/connection/Exchange;)V .registers 10 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation const-string v0, "response" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 185 invoke-virtual {p1}, Lokhttp3/Response;->code()I move-result v0 const/16 v1, 0x65 const/16 v2, 0x27 if-ne v0, v1, :cond_c3 .line 190 const-string v0, "Connection" const/4 v1, 0x0 const/4 v3, 0x2 invoke-static {p1, v0, v1, v3, v1}, Lokhttp3/Response;->header$default(Lokhttp3/Response;Ljava/lang/String;Ljava/lang/String;ILjava/lang/Object;)Ljava/lang/String; move-result-object v0 .line 191 const-string v4, "Upgrade" const/4 v5, 0x1 invoke-static {v4, v0, v5}, Lkotlin/text/StringsKt;->equals(Ljava/lang/String;Ljava/lang/String;Z)Z move-result v6 if-eqz v6, :cond_a8 .line 196 invoke-static {p1, v4, v1, v3, v1}, Lokhttp3/Response;->header$default(Lokhttp3/Response;Ljava/lang/String;Ljava/lang/String;ILjava/lang/Object;)Ljava/lang/String; move-result-object v0 .line 197 const-string v4, "websocket" invoke-static {v4, v0, v5}, Lkotlin/text/StringsKt;->equals(Ljava/lang/String;Ljava/lang/String;Z)Z move-result v4 if-eqz v4, :cond_8d .line 202 const-string v0, "Sec-WebSocket-Accept" invoke-static {p1, v0, v1, v3, v1}, Lokhttp3/Response;->header$default(Lokhttp3/Response;Ljava/lang/String;Ljava/lang/String;ILjava/lang/Object;)Ljava/lang/String; move-result-object p1 .line 203 sget-object v0, Lokio/ByteString;->Companion:Lokio/ByteString$Companion; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V iget-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String; invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 const-string v3, "258EAFA5-E914-47DA-95CA-C5AB0DC85B11" invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-virtual {v0, v1}, Lokio/ByteString$Companion;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString; move-result-object v0 invoke-virtual {v0}, Lokio/ByteString;->sha1()Lokio/ByteString; move-result-object v0 invoke-virtual {v0}, Lokio/ByteString;->base64()Ljava/lang/String; move-result-object v0 .line 204 invoke-static {v0, p1}, Lkotlin/jvm/internal/Intrinsics;->areEqual(Ljava/lang/Object;Ljava/lang/Object;)Z move-result v1 if-eqz v1, :cond_68 if-eqz p2, :cond_5e return-void .line 210 :cond_5e new-instance p1, Ljava/net/ProtocolException; const-string p2, "Web Socket exchange missing: bad interceptor?" invoke-direct {p1, p2}, Ljava/net/ProtocolException;->(Ljava/lang/String;)V check-cast p1, Ljava/lang/Throwable; throw p1 .line 205 :cond_68 new-instance p2, Ljava/net/ProtocolException; .line 206 new-instance v1, Ljava/lang/StringBuilder; const-string v3, "Expected \'Sec-WebSocket-Accept\' header value \'" invoke-direct {v1, v3}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v0 const-string v1, "\' but was \'" invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v0 invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 .line 205 invoke-direct {p2, p1}, Ljava/net/ProtocolException;->(Ljava/lang/String;)V check-cast p2, Ljava/lang/Throwable; throw p2 .line 198 :cond_8d new-instance p1, Ljava/net/ProtocolException; .line 199 new-instance p2, Ljava/lang/StringBuilder; const-string v1, "Expected \'Upgrade\' header value \'websocket\' but was \'" invoke-direct {p2, v1}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p2 invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder; move-result-object p2 invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 .line 198 invoke-direct {p1, p2}, Ljava/net/ProtocolException;->(Ljava/lang/String;)V check-cast p1, Ljava/lang/Throwable; throw p1 .line 192 :cond_a8 new-instance p1, Ljava/net/ProtocolException; .line 193 new-instance p2, Ljava/lang/StringBuilder; const-string v1, "Expected \'Connection\' header value \'Upgrade\' but was \'" invoke-direct {p2, v1}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p2 invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder; move-result-object p2 invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 .line 192 invoke-direct {p1, p2}, Ljava/net/ProtocolException;->(Ljava/lang/String;)V check-cast p1, Ljava/lang/Throwable; throw p1 .line 186 :cond_c3 new-instance p2, Ljava/net/ProtocolException; .line 187 new-instance v0, Ljava/lang/StringBuilder; const-string v1, "Expected HTTP 101 response but was \'" invoke-direct {v0, v1}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {p1}, Lokhttp3/Response;->code()I move-result v1 invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; move-result-object v0 const/16 v1, 0x20 invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder; move-result-object v0 invoke-virtual {p1}, Lokhttp3/Response;->message()Ljava/lang/String; move-result-object p1 invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 .line 186 invoke-direct {p2, p1}, Ljava/net/ProtocolException;->(Ljava/lang/String;)V check-cast p2, Ljava/lang/Throwable; throw p2 .end method .method public close(ILjava/lang/String;)Z .registers 5 const-wide/32 v0, 0xea60 .line 367 invoke-virtual {p0, p1, p2, v0, v1}, Lokhttp3/internal/ws/RealWebSocket;->close(ILjava/lang/String;J)Z move-result p1 return p1 .end method .method public final declared-synchronized close(ILjava/lang/String;J)Z .registers 13 const-string v0, "reason.size() > 123: " monitor-enter p0 .line 375 :try_start_3 sget-object v1, Lokhttp3/internal/ws/WebSocketProtocol;->INSTANCE:Lokhttp3/internal/ws/WebSocketProtocol; invoke-virtual {v1, p1}, Lokhttp3/internal/ws/WebSocketProtocol;->validateCloseCode(I)V const/4 v1, 0x0 .line 377 move-object v2, v1 check-cast v2, Lokio/ByteString; const/4 v2, 0x0 const/4 v3, 0x1 if-eqz p2, :cond_40 .line 379 sget-object v1, Lokio/ByteString;->Companion:Lokio/ByteString$Companion; invoke-virtual {v1, p2}, Lokio/ByteString$Companion;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString; move-result-object v1 .line 380 invoke-virtual {v1}, Lokio/ByteString;->size()I move-result v4 int-to-long v4, v4 const-wide/16 v6, 0x7b cmp-long v4, v4, v6 if-gtz v4, :cond_23 move v4, v3 goto :goto_24 :cond_23 move v4, v2 :goto_24 if-eqz v4, :cond_27 goto :goto_40 .line 381 :cond_27 new-instance p1, Ljava/lang/StringBuilder; invoke-direct {p1, v0}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object p1 invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 .line 380 new-instance p2, Ljava/lang/IllegalArgumentException; invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p1 invoke-direct {p2, p1}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V check-cast p2, Ljava/lang/Throwable; throw p2 .line 385 :cond_40 :goto_40 iget-boolean p2, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z if-nez p2, :cond_5a iget-boolean p2, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z if-eqz p2, :cond_49 goto :goto_5a .line 388 :cond_49 iput-boolean v3, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z .line 391 iget-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque; new-instance v0, Lokhttp3/internal/ws/RealWebSocket$Close; invoke-direct {v0, p1, v1, p3, p4}, Lokhttp3/internal/ws/RealWebSocket$Close;->(ILokio/ByteString;J)V invoke-virtual {p2, v0}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z .line 392 invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V :try_end_58 .catchall {:try_start_3 .. :try_end_58} :catchall_5c .line 393 monitor-exit p0 return v3 .line 385 :cond_5a :goto_5a monitor-exit p0 return v2 :catchall_5c move-exception p1 :try_start_5d monitor-exit p0 :try_end_5e .catchall {:try_start_5d .. :try_end_5e} :catchall_5c throw p1 .end method .method public final connect(Lokhttp3/OkHttpClient;)V .registers 5 const-string v0, "client" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 141 invoke-virtual {p1}, Lokhttp3/OkHttpClient;->newBuilder()Lokhttp3/OkHttpClient$Builder; move-result-object p1 .line 142 sget-object v0, Lokhttp3/EventListener;->NONE:Lokhttp3/EventListener; invoke-virtual {p1, v0}, Lokhttp3/OkHttpClient$Builder;->eventListener(Lokhttp3/EventListener;)Lokhttp3/OkHttpClient$Builder; move-result-object p1 .line 143 sget-object v0, Lokhttp3/internal/ws/RealWebSocket;->ONLY_HTTP1:Ljava/util/List; invoke-virtual {p1, v0}, Lokhttp3/OkHttpClient$Builder;->protocols(Ljava/util/List;)Lokhttp3/OkHttpClient$Builder; move-result-object p1 .line 144 invoke-virtual {p1}, Lokhttp3/OkHttpClient$Builder;->build()Lokhttp3/OkHttpClient; move-result-object p1 .line 145 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 146 const-string v1, "websocket" const-string v2, "Upgrade" invoke-virtual {v0, v2, v1}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder; move-result-object v0 .line 147 const-string v1, "Connection" invoke-virtual {v0, v1, v2}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder; move-result-object v0 .line 148 const-string v1, "Sec-WebSocket-Key" iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->key:Ljava/lang/String; invoke-virtual {v0, v1, v2}, Lokhttp3/Request$Builder;->header(Ljava/lang/String;Ljava/lang/String;)Lokhttp3/Request$Builder; move-result-object v0 .line 149 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 150 invoke-virtual {v0}, Lokhttp3/Request$Builder;->build()Lokhttp3/Request; move-result-object v0 .line 151 new-instance v1, Lokhttp3/internal/connection/RealCall; const/4 v2, 0x1 invoke-direct {v1, p1, v0, v2}, Lokhttp3/internal/connection/RealCall;->(Lokhttp3/OkHttpClient;Lokhttp3/Request;Z)V check-cast v1, Lokhttp3/Call; iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->call:Lokhttp3/Call; .line 152 new-instance p1, Lokhttp3/internal/ws/RealWebSocket$connect$1; invoke-direct {p1, p0, v0}, Lokhttp3/internal/ws/RealWebSocket$connect$1;->(Lokhttp3/internal/ws/RealWebSocket;Lokhttp3/Request;)V check-cast p1, Lokhttp3/Callback; invoke-interface {v1, p1}, Lokhttp3/Call;->enqueue(Lokhttp3/Callback;)V return-void .end method .method public final failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V .registers 6 const-string v0, "e" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 512 monitor-enter p0 .line 513 :try_start_6 iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z :try_end_8 .catchall {:try_start_6 .. :try_end_8} :catchall_3a if-eqz v0, :cond_c monitor-exit p0 return-void :cond_c const/4 v0, 0x1 .line 514 :try_start_d iput-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z .line 515 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams; const/4 v1, 0x0 .line 516 move-object v2, v1 check-cast v2, Lokhttp3/internal/ws/RealWebSocket$Streams; iput-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams; .line 517 iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; invoke-virtual {v1}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V .line 518 sget-object v1, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_1e .catchall {:try_start_d .. :try_end_1e} :catchall_3a .line 512 monitor-exit p0 .line 521 :try_start_1f iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; move-object v2, p0 check-cast v2, Lokhttp3/WebSocket; check-cast p1, Ljava/lang/Throwable; invoke-virtual {v1, v2, p1, p2}, Lokhttp3/WebSocketListener;->onFailure(Lokhttp3/WebSocket;Ljava/lang/Throwable;Lokhttp3/Response;)V :try_end_29 .catchall {:try_start_1f .. :try_end_29} :catchall_31 if-eqz v0, :cond_30 .line 523 check-cast v0, Ljava/io/Closeable; invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V :cond_30 return-void :catchall_31 move-exception p1 if-eqz v0, :cond_39 check-cast v0, Ljava/io/Closeable; invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V :cond_39 throw p1 :catchall_3a move-exception p1 .line 512 monitor-exit p0 throw p1 .end method .method public final getListener$okhttp()Lokhttp3/WebSocketListener; .registers 2 .line 58 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; return-object v0 .end method .method public final initReaderAndWriter(Ljava/lang/String;Lokhttp3/internal/ws/RealWebSocket$Streams;)V .registers 15 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation const-string v0, "name" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V const-string v0, "streams" invoke-static {p2, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 216 monitor-enter p0 .line 217 :try_start_b iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String; .line 218 iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams; .line 219 new-instance v0, Lokhttp3/internal/ws/WebSocketWriter; invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getClient()Z move-result v1 invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getSink()Lokio/BufferedSink; move-result-object v2 iget-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->random:Ljava/util/Random; invoke-direct {v0, v1, v2, v3}, Lokhttp3/internal/ws/WebSocketWriter;->(ZLokio/BufferedSink;Ljava/util/Random;)V iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter; .line 220 new-instance v0, Lokhttp3/internal/ws/RealWebSocket$WriterTask; invoke-direct {v0, p0}, Lokhttp3/internal/ws/RealWebSocket$WriterTask;->(Lokhttp3/internal/ws/RealWebSocket;)V check-cast v0, Lokhttp3/internal/concurrent/Task; iput-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writerTask:Lokhttp3/internal/concurrent/Task; .line 221 iget-wide v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J const-wide/16 v2, 0x0 cmp-long v0, v0, v2 if-eqz v0, :cond_5e .line 222 sget-object v0, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit; iget-wide v1, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J move-result-wide v0 .line 223 iget-object v2, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 const-string v4, " ping" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v5 .line 572 new-instance v11, Lokhttp3/internal/ws/RealWebSocket$initReaderAndWriter$$inlined$synchronized$lambda$1; move-object v3, v11 move-object v4, v5 move-wide v6, v0 move-object v8, p0 move-object v9, p1 move-object v10, p2 invoke-direct/range {v3 .. v10}, Lokhttp3/internal/ws/RealWebSocket$initReaderAndWriter$$inlined$synchronized$lambda$1;->(Ljava/lang/String;Ljava/lang/String;JLokhttp3/internal/ws/RealWebSocket;Ljava/lang/String;Lokhttp3/internal/ws/RealWebSocket$Streams;)V check-cast v11, Lokhttp3/internal/concurrent/Task; invoke-virtual {v2, v11, v0, v1}, Lokhttp3/internal/concurrent/TaskQueue;->schedule(Lokhttp3/internal/concurrent/Task;J)V .line 228 :cond_5e iget-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque; check-cast p1, Ljava/util/Collection; invoke-interface {p1}, Ljava/util/Collection;->isEmpty()Z move-result p1 if-nez p1, :cond_6b .line 229 invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V .line 231 :cond_6b sget-object p1, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_6d .catchall {:try_start_b .. :try_end_6d} :catchall_81 .line 216 monitor-exit p0 .line 233 new-instance p1, Lokhttp3/internal/ws/WebSocketReader; invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getClient()Z move-result v0 invoke-virtual {p2}, Lokhttp3/internal/ws/RealWebSocket$Streams;->getSource()Lokio/BufferedSource; move-result-object p2 move-object v1, p0 check-cast v1, Lokhttp3/internal/ws/WebSocketReader$FrameCallback; invoke-direct {p1, v0, p2, v1}, Lokhttp3/internal/ws/WebSocketReader;->(ZLokio/BufferedSource;Lokhttp3/internal/ws/WebSocketReader$FrameCallback;)V iput-object p1, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader; return-void :catchall_81 move-exception p1 .line 216 monitor-exit p0 throw p1 .end method .method public final loopReader()V .registers 3 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 239 :goto_0 iget v0, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I const/4 v1, -0x1 if-ne v0, v1, :cond_10 .line 241 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader; if-nez v0, :cond_c invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V :cond_c invoke-virtual {v0}, Lokhttp3/internal/ws/WebSocketReader;->processNextFrame()V goto :goto_0 :cond_10 return-void .end method .method public onReadClose(ILjava/lang/String;)V .registers 8 const-string v0, "reason" invoke-static {p2, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V const/4 v0, 0x1 const/4 v1, 0x0 const/4 v2, -0x1 if-eq p1, v2, :cond_c move v3, v0 goto :goto_d :cond_c move v3, v1 :goto_d if-eqz v3, :cond_70 const/4 v3, 0x0 .line 307 move-object v4, v3 check-cast v4, Lokhttp3/internal/ws/RealWebSocket$Streams; .line 308 monitor-enter p0 .line 309 :try_start_14 iget v4, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I if-ne v4, v2, :cond_19 goto :goto_1a :cond_19 move v0, v1 :goto_1a if-eqz v0, :cond_5f .line 310 iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I .line 311 iput-object p2, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseReason:Ljava/lang/String; .line 312 iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z if-eqz v0, :cond_39 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_39 .line 313 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams; .line 314 move-object v1, v3 check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Streams; iput-object v3, p0, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams; .line 315 iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; invoke-virtual {v1}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V move-object v3, v0 .line 317 :cond_39 sget-object v0, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_3b .catchall {:try_start_14 .. :try_end_3b} :catchall_6d .line 308 monitor-exit p0 .line 320 :try_start_3c iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; move-object v1, p0 check-cast v1, Lokhttp3/WebSocket; invoke-virtual {v0, v1, p1, p2}, Lokhttp3/WebSocketListener;->onClosing(Lokhttp3/WebSocket;ILjava/lang/String;)V if-eqz v3, :cond_4e .line 323 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; move-object v1, p0 check-cast v1, Lokhttp3/WebSocket; invoke-virtual {v0, v1, p1, p2}, Lokhttp3/WebSocketListener;->onClosed(Lokhttp3/WebSocket;ILjava/lang/String;)V :try_end_4e .catchall {:try_start_3c .. :try_end_4e} :catchall_56 :cond_4e if-eqz v3, :cond_55 .line 326 check-cast v3, Ljava/io/Closeable; invoke-static {v3}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V :cond_55 return-void :catchall_56 move-exception p1 if-eqz v3, :cond_5e check-cast v3, Ljava/io/Closeable; invoke-static {v3}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V :cond_5e throw p1 .line 309 :cond_5f :try_start_5f const-string p1, "already closed" new-instance p2, Ljava/lang/IllegalStateException; invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p1 invoke-direct {p2, p1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V check-cast p2, Ljava/lang/Throwable; throw p2 :try_end_6d .catchall {:try_start_5f .. :try_end_6d} :catchall_6d :catchall_6d move-exception p1 .line 308 monitor-exit p0 throw p1 .line 305 :cond_70 const-string p1, "Failed requirement." new-instance p2, Ljava/lang/IllegalArgumentException; invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p1 invoke-direct {p2, p1}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V check-cast p2, Ljava/lang/Throwable; throw p2 .end method .method public onReadMessage(Ljava/lang/String;)V .registers 4 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation const-string v0, "text" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 281 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; move-object v1, p0 check-cast v1, Lokhttp3/WebSocket; invoke-virtual {v0, v1, p1}, Lokhttp3/WebSocketListener;->onMessage(Lokhttp3/WebSocket;Ljava/lang/String;)V return-void .end method .method public onReadMessage(Lokio/ByteString;)V .registers 4 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation const-string v0, "bytes" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 286 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; move-object v1, p0 check-cast v1, Lokhttp3/WebSocket; invoke-virtual {v0, v1, p1}, Lokhttp3/WebSocketListener;->onMessage(Lokhttp3/WebSocket;Lokio/ByteString;)V return-void .end method .method public declared-synchronized onReadPing(Lokio/ByteString;)V .registers 3 monitor-enter p0 :try_start_1 const-string v0, "payload" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 291 iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z if-nez v0, :cond_27 iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z if-eqz v0, :cond_17 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque; invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z move-result v0 if-eqz v0, :cond_17 goto :goto_27 .line 293 :cond_17 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque; invoke-virtual {v0, p1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z .line 294 invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V .line 295 iget p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPingCount:I add-int/lit8 p1, p1, 0x1 iput p1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedPingCount:I :try_end_25 .catchall {:try_start_1 .. :try_end_25} :catchall_29 .line 296 monitor-exit p0 return-void .line 291 :cond_27 :goto_27 monitor-exit p0 return-void :catchall_29 move-exception p1 :try_start_2a monitor-exit p0 :try_end_2b .catchall {:try_start_2a .. :try_end_2b} :catchall_29 throw p1 .end method .method public declared-synchronized onReadPong(Lokio/ByteString;)V .registers 3 monitor-enter p0 :try_start_1 const-string v0, "payload" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 300 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 301 iput-boolean p1, p0, Lokhttp3/internal/ws/RealWebSocket;->awaitingPong:Z :try_end_f .catchall {:try_start_1 .. :try_end_f} :catchall_11 .line 302 monitor-exit p0 return-void :catchall_11 move-exception p1 :try_start_12 monitor-exit p0 :try_end_13 .catchall {:try_start_12 .. :try_end_13} :catchall_11 throw p1 .end method .method public final declared-synchronized pong(Lokio/ByteString;)Z .registers 3 monitor-enter p0 :try_start_1 const-string v0, "payload" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 359 iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z if-nez v0, :cond_22 iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->enqueuedClose:Z if-eqz v0, :cond_17 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque; invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z move-result v0 if-eqz v0, :cond_17 goto :goto_22 .line 361 :cond_17 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque; invoke-virtual {v0, p1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z .line 362 invoke-direct {p0}, Lokhttp3/internal/ws/RealWebSocket;->runWriter()V :try_end_1f .catchall {:try_start_1 .. :try_end_1f} :catchall_25 .line 363 monitor-exit p0 const/4 p1, 0x1 return p1 .line 359 :cond_22 :goto_22 monitor-exit p0 const/4 p1, 0x0 return p1 :catchall_25 move-exception p1 :try_start_26 monitor-exit p0 :try_end_27 .catchall {:try_start_26 .. :try_end_27} :catchall_25 throw p1 .end method .method public final processNextFrame()Z .registers 4 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation const/4 v0, 0x0 .line 252 :try_start_1 iget-object v1, p0, Lokhttp3/internal/ws/RealWebSocket;->reader:Lokhttp3/internal/ws/WebSocketReader; if-nez v1, :cond_8 invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V :cond_8 invoke-virtual {v1}, Lokhttp3/internal/ws/WebSocketReader;->processNextFrame()V .line 253 iget v1, p0, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I :try_end_d .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_d} :catch_12 const/4 v2, -0x1 if-ne v1, v2, :cond_17 const/4 v0, 0x1 goto :goto_17 :catch_12 move-exception v1 const/4 v2, 0x0 .line 255 invoke-virtual {p0, v1, v2}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V :cond_17 :goto_17 return v0 .end method .method public declared-synchronized queueSize()J .registers 3 monitor-enter p0 .line 134 :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 :try_start_6 monitor-exit p0 :try_end_7 .catchall {:try_start_6 .. :try_end_7} :catchall_5 throw v0 .end method .method public final declared-synchronized receivedPingCount()I .registers 2 monitor-enter p0 .line 275 :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 :try_start_6 monitor-exit p0 :try_end_7 .catchall {:try_start_6 .. :try_end_7} :catchall_5 throw v0 .end method .method public final declared-synchronized receivedPongCount()I .registers 2 monitor-enter p0 .line 277 :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 :try_start_6 monitor-exit p0 :try_end_7 .catchall {:try_start_6 .. :try_end_7} :catchall_5 throw v0 .end method .method public request()Lokhttp3/Request; .registers 2 .line 132 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->originalRequest:Lokhttp3/Request; return-object v0 .end method .method public send(Ljava/lang/String;)Z .registers 3 const-string v0, "text" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V .line 333 sget-object v0, Lokio/ByteString;->Companion:Lokio/ByteString$Companion; invoke-virtual {v0, p1}, Lokio/ByteString$Companion;->encodeUtf8(Ljava/lang/String;)Lokio/ByteString; move-result-object p1 const/4 v0, 0x1 invoke-direct {p0, p1, v0}, Lokhttp3/internal/ws/RealWebSocket;->send(Lokio/ByteString;I)Z move-result p1 return p1 .end method .method public send(Lokio/ByteString;)Z .registers 3 const-string v0, "bytes" invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->checkParameterIsNotNull(Ljava/lang/Object;Ljava/lang/String;)V const/4 v0, 0x2 .line 337 invoke-direct {p0, p1, v0}, Lokhttp3/internal/ws/RealWebSocket;->send(Lokio/ByteString;I)Z move-result p1 return p1 .end method .method public final declared-synchronized sentPingCount()I .registers 2 monitor-enter p0 .line 273 :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 :try_start_6 monitor-exit p0 :try_end_7 .catchall {:try_start_6 .. :try_end_7} :catchall_5 throw v0 .end method .method public final tearDown()V .registers 5 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/InterruptedException; } .end annotation .line 269 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V .line 270 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskQueue;->idleLatch()Ljava/util/concurrent/CountDownLatch; move-result-object v0 const-wide/16 v1, 0xa sget-object v3, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit; invoke-virtual {v0, v1, v2, v3}, Ljava/util/concurrent/CountDownLatch;->await(JLjava/util/concurrent/TimeUnit;)Z return-void .end method .method public final writeOneFrame$okhttp()Z .registers 24 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation move-object/from16 v13, p0 .line 422 new-instance v0, Lkotlin/jvm/internal/Ref$ObjectRef; invoke-direct {v0}, Lkotlin/jvm/internal/Ref$ObjectRef;->()V const/4 v1, 0x0 iput-object v1, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; .line 423 new-instance v14, Lkotlin/jvm/internal/Ref$IntRef; invoke-direct {v14}, Lkotlin/jvm/internal/Ref$IntRef;->()V const/4 v2, -0x1 iput v2, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I .line 424 new-instance v15, Lkotlin/jvm/internal/Ref$ObjectRef; invoke-direct {v15}, Lkotlin/jvm/internal/Ref$ObjectRef;->()V move-object v3, v1 check-cast v3, Ljava/lang/String; iput-object v1, v15, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; .line 425 new-instance v12, Lkotlin/jvm/internal/Ref$ObjectRef; invoke-direct {v12}, Lkotlin/jvm/internal/Ref$ObjectRef;->()V move-object v3, v1 check-cast v3, Lokhttp3/internal/ws/RealWebSocket$Streams; iput-object v1, v12, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; .line 427 monitor-enter p0 .line 428 :try_start_27 iget-boolean v3, v13, Lokhttp3/internal/ws/RealWebSocket;->failed:Z :try_end_29 .catchall {:try_start_27 .. :try_end_29} :catchall_1a1 const/4 v4, 0x0 if-eqz v3, :cond_2e .line 429 monitor-exit p0 return v4 .line 432 :cond_2e :try_start_2e iget-object v11, v13, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter; .line 433 iget-object v3, v13, Lokhttp3/internal/ws/RealWebSocket;->pongQueue:Ljava/util/ArrayDeque; invoke-virtual {v3}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object; move-result-object v3 move-object v10, v3 check-cast v10, Lokio/ByteString; if-nez v10, :cond_c7 .line 435 iget-object v3, v13, Lokhttp3/internal/ws/RealWebSocket;->messageAndCloseQueue:Ljava/util/ArrayDeque; invoke-virtual {v3}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object; move-result-object v3 iput-object v3, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; .line 436 iget-object v3, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; instance-of v3, v3, Lokhttp3/internal/ws/RealWebSocket$Close; if-eqz v3, :cond_bb .line 437 iget v3, v13, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseCode:I iput v3, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I .line 438 iget-object v3, v13, Lokhttp3/internal/ws/RealWebSocket;->receivedCloseReason:Ljava/lang/String; iput-object v3, v15, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; .line 439 iget v3, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I if-eq v3, v2, :cond_65 .line 440 iget-object v2, v13, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams; iput-object v2, v12, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; .line 441 move-object v2, v1 check-cast v2, Lokhttp3/internal/ws/RealWebSocket$Streams; iput-object v1, v13, Lokhttp3/internal/ws/RealWebSocket;->streams:Lokhttp3/internal/ws/RealWebSocket$Streams; .line 442 iget-object v1, v13, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; invoke-virtual {v1}, Lokhttp3/internal/concurrent/TaskQueue;->shutdown()V goto/16 :goto_c7 .line 445 :cond_65 iget-object v1, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; if-eqz v1, :cond_b3 check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Close; invoke-virtual {v1}, Lokhttp3/internal/ws/RealWebSocket$Close;->getCancelAfterCloseMillis()J move-result-wide v1 .line 446 iget-object v9, v13, Lokhttp3/internal/ws/RealWebSocket;->taskQueue:Lokhttp3/internal/concurrent/TaskQueue; new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V iget-object v4, v13, Lokhttp3/internal/ws/RealWebSocket;->name:Ljava/lang/String; invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 const-string v4, " cancel" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 sget-object v3, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit; invoke-virtual {v3, v1, v2}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J move-result-wide v7 .line 583 new-instance v16, Lokhttp3/internal/ws/RealWebSocket$writeOneFrame$$inlined$synchronized$lambda$1; const/4 v5, 0x1 move-object/from16 v1, v16 move-object v2, v4 move v3, v5 move-object/from16 v6, p0 move-wide/from16 v17, v7 move-object v7, v11 move-object v8, v10 move-object/from16 v19, v9 move-object v9, v0 move-object/from16 v20, v10 move-object v10, v14 move-object/from16 v21, v11 move-object v11, v15 move-object/from16 v22, v12 invoke-direct/range {v1 .. v12}, Lokhttp3/internal/ws/RealWebSocket$writeOneFrame$$inlined$synchronized$lambda$1;->(Ljava/lang/String;ZLjava/lang/String;ZLokhttp3/internal/ws/RealWebSocket;Lokhttp3/internal/ws/WebSocketWriter;Lokio/ByteString;Lkotlin/jvm/internal/Ref$ObjectRef;Lkotlin/jvm/internal/Ref$IntRef;Lkotlin/jvm/internal/Ref$ObjectRef;Lkotlin/jvm/internal/Ref$ObjectRef;)V move-object/from16 v1, v16 check-cast v1, Lokhttp3/internal/concurrent/Task; move-wide/from16 v3, v17 move-object/from16 v2, v19 invoke-virtual {v2, v1, v3, v4}, Lokhttp3/internal/concurrent/TaskQueue;->schedule(Lokhttp3/internal/concurrent/Task;J)V goto :goto_cd .line 445 :cond_b3 new-instance v0, Lkotlin/TypeCastException; const-string v1, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Close" invoke-direct {v0, v1}, Lkotlin/TypeCastException;->(Ljava/lang/String;)V throw v0 :cond_bb move-object/from16 v20, v10 move-object/from16 v21, v11 move-object/from16 v22, v12 .line 450 iget-object v1, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; :try_end_c3 .catchall {:try_start_2e .. :try_end_c3} :catchall_1a1 if-nez v1, :cond_cd .line 451 monitor-exit p0 return v4 :cond_c7 :goto_c7 move-object/from16 v20, v10 move-object/from16 v21, v11 move-object/from16 v22, v12 .line 454 :cond_cd :goto_cd :try_start_cd sget-object v1, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_cf .catchall {:try_start_cd .. :try_end_cf} :catchall_1a1 .line 427 monitor-exit p0 move-object/from16 v3, v20 if-eqz v3, :cond_e2 move-object/from16 v1, v21 if-nez v1, :cond_db .line 458 :try_start_d8 invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V :cond_db invoke-virtual {v1, v3}, Lokhttp3/internal/ws/WebSocketWriter;->writePong(Lokio/ByteString;)V :goto_de move-object/from16 v1, v22 goto/16 :goto_16f :cond_e2 move-object/from16 v1, v21 .line 459 iget-object v2, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; instance-of v2, v2, Lokhttp3/internal/ws/RealWebSocket$Message; if-eqz v2, :cond_138 .line 460 iget-object v2, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; if-eqz v2, :cond_130 check-cast v2, Lokhttp3/internal/ws/RealWebSocket$Message; invoke-virtual {v2}, Lokhttp3/internal/ws/RealWebSocket$Message;->getData()Lokio/ByteString; move-result-object v2 if-nez v1, :cond_f9 .line 461 invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V .line 462 :cond_f9 iget-object v0, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; if-eqz v0, :cond_128 check-cast v0, Lokhttp3/internal/ws/RealWebSocket$Message; invoke-virtual {v0}, Lokhttp3/internal/ws/RealWebSocket$Message;->getFormatOpcode()I move-result v0 invoke-virtual {v2}, Lokio/ByteString;->size()I move-result v3 int-to-long v3, v3 .line 461 invoke-virtual {v1, v0, v3, v4}, Lokhttp3/internal/ws/WebSocketWriter;->newMessageSink(IJ)Lokio/Sink; move-result-object v0 .line 462 invoke-static {v0}, Lokio/Okio;->buffer(Lokio/Sink;)Lokio/BufferedSink; move-result-object v0 .line 463 invoke-interface {v0, v2}, Lokio/BufferedSink;->write(Lokio/ByteString;)Lokio/BufferedSink; .line 464 invoke-interface {v0}, Lokio/BufferedSink;->close()V .line 465 monitor-enter p0 :try_end_117 .catchall {:try_start_d8 .. :try_end_117} :catchall_192 .line 466 :try_start_117 iget-wide v0, v13, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J invoke-virtual {v2}, Lokio/ByteString;->size()I move-result v2 int-to-long v2, v2 sub-long/2addr v0, v2 iput-wide v0, v13, Lokhttp3/internal/ws/RealWebSocket;->queueSize:J .line 467 sget-object v0, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_123 .catchall {:try_start_117 .. :try_end_123} :catchall_125 .line 465 :try_start_123 monitor-exit p0 goto :goto_de :catchall_125 move-exception v0 monitor-exit p0 throw v0 .line 462 :cond_128 new-instance v0, Lkotlin/TypeCastException; const-string v1, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Message" invoke-direct {v0, v1}, Lkotlin/TypeCastException;->(Ljava/lang/String;)V throw v0 .line 460 :cond_130 new-instance v0, Lkotlin/TypeCastException; const-string v1, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Message" invoke-direct {v0, v1}, Lkotlin/TypeCastException;->(Ljava/lang/String;)V throw v0 .line 468 :cond_138 iget-object v2, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; instance-of v2, v2, Lokhttp3/internal/ws/RealWebSocket$Close; if-eqz v2, :cond_186 .line 469 iget-object v0, v0, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; if-eqz v0, :cond_17c check-cast v0, Lokhttp3/internal/ws/RealWebSocket$Close; if-nez v1, :cond_149 .line 470 invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V :cond_149 invoke-virtual {v0}, Lokhttp3/internal/ws/RealWebSocket$Close;->getCode()I move-result v2 invoke-virtual {v0}, Lokhttp3/internal/ws/RealWebSocket$Close;->getReason()Lokio/ByteString; move-result-object v0 invoke-virtual {v1, v2, v0}, Lokhttp3/internal/ws/WebSocketWriter;->writeClose(ILokio/ByteString;)V :try_end_154 .catchall {:try_start_123 .. :try_end_154} :catchall_192 move-object/from16 v1, v22 .line 473 :try_start_156 iget-object v0, v1, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; check-cast v0, Lokhttp3/internal/ws/RealWebSocket$Streams; if-eqz v0, :cond_16f .line 474 iget-object v0, v13, Lokhttp3/internal/ws/RealWebSocket;->listener:Lokhttp3/WebSocketListener; move-object v2, v13 check-cast v2, Lokhttp3/WebSocket; iget v3, v14, Lkotlin/jvm/internal/Ref$IntRef;->element:I iget-object v4, v15, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; check-cast v4, Ljava/lang/String; if-nez v4, :cond_16c invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V :cond_16c invoke-virtual {v0, v2, v3, v4}, Lokhttp3/WebSocketListener;->onClosed(Lokhttp3/WebSocket;ILjava/lang/String;)V :try_end_16f .catchall {:try_start_156 .. :try_end_16f} :catchall_190 .line 482 :cond_16f :goto_16f iget-object v0, v1, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; check-cast v0, Lokhttp3/internal/ws/RealWebSocket$Streams; if-eqz v0, :cond_17a check-cast v0, Ljava/io/Closeable; invoke-static {v0}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V :cond_17a const/4 v0, 0x1 return v0 :cond_17c move-object/from16 v1, v22 .line 469 :try_start_17e new-instance v0, Lkotlin/TypeCastException; const-string v2, "null cannot be cast to non-null type okhttp3.internal.ws.RealWebSocket.Close" invoke-direct {v0, v2}, Lkotlin/TypeCastException;->(Ljava/lang/String;)V throw v0 :cond_186 move-object/from16 v1, v22 .line 477 new-instance v0, Ljava/lang/AssertionError; invoke-direct {v0}, Ljava/lang/AssertionError;->()V check-cast v0, Ljava/lang/Throwable; throw v0 :try_end_190 .catchall {:try_start_17e .. :try_end_190} :catchall_190 :catchall_190 move-exception v0 goto :goto_195 :catchall_192 move-exception v0 move-object/from16 v1, v22 .line 482 :goto_195 iget-object v1, v1, Lkotlin/jvm/internal/Ref$ObjectRef;->element:Ljava/lang/Object; check-cast v1, Lokhttp3/internal/ws/RealWebSocket$Streams; if-eqz v1, :cond_1a0 check-cast v1, Ljava/io/Closeable; invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/io/Closeable;)V :cond_1a0 throw v0 :catchall_1a1 move-exception v0 .line 427 monitor-exit p0 throw v0 .end method .method public final writePingFrame$okhttp()V .registers 8 .line 489 monitor-enter p0 .line 490 :try_start_1 iget-boolean v0, p0, Lokhttp3/internal/ws/RealWebSocket;->failed:Z :try_end_3 .catchall {:try_start_1 .. :try_end_3} :catchall_5f if-eqz v0, :cond_7 monitor-exit p0 return-void .line 491 :cond_7 :try_start_7 iget-object v0, p0, Lokhttp3/internal/ws/RealWebSocket;->writer:Lokhttp3/internal/ws/WebSocketWriter; .line 492 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 move v1, v2 .line 493 :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 494 iput-boolean v4, p0, Lokhttp3/internal/ws/RealWebSocket;->awaitingPong:Z .line 495 sget-object v3, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_1c .catchall {:try_start_7 .. :try_end_1c} :catchall_5f .line 489 monitor-exit p0 const/4 v3, 0x0 if-eq v1, v2, :cond_4d .line 498 new-instance v0, Ljava/net/SocketTimeoutException; new-instance v2, Ljava/lang/StringBuilder; const-string v5, "sent ping but didn\'t receive pong within " invoke-direct {v2, v5}, Ljava/lang/StringBuilder;->(Ljava/lang/String;)V .line 499 iget-wide v5, p0, Lokhttp3/internal/ws/RealWebSocket;->pingIntervalMillis:J invoke-virtual {v2, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; move-result-object v2 const-string v5, "ms (after " invoke-virtual {v2, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 sub-int/2addr v1, v4 invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; move-result-object v1 const-string v2, " successful ping/pongs)" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 .line 498 invoke-direct {v0, v1}, Ljava/net/SocketTimeoutException;->(Ljava/lang/String;)V check-cast v0, Ljava/lang/Exception; invoke-virtual {p0, v0, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V return-void :cond_4d if-nez v0, :cond_52 .line 504 :try_start_4f invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->throwNpe()V :cond_52 sget-object v1, Lokio/ByteString;->EMPTY:Lokio/ByteString; invoke-virtual {v0, v1}, Lokhttp3/internal/ws/WebSocketWriter;->writePing(Lokio/ByteString;)V :try_end_57 .catch Ljava/io/IOException; {:try_start_4f .. :try_end_57} :catch_58 goto :goto_5e :catch_58 move-exception v0 .line 506 check-cast v0, Ljava/lang/Exception; invoke-virtual {p0, v0, v3}, Lokhttp3/internal/ws/RealWebSocket;->failWebSocket(Ljava/lang/Exception;Lokhttp3/Response;)V :goto_5e return-void :catchall_5f move-exception v0 .line 489 monitor-exit p0 throw v0 .end method