LocalSocketServer.smali
.class public Lcom/facebook/stetho/server/LocalSocketServer;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/facebook/stetho/server/LocalSocketServer$WorkerThread;
}
.end annotation
# static fields
.field private static final MAX_BIND_RETRIES:I = 0x2
.field private static final TIME_BETWEEN_BIND_RETRIES_MS:I = 0x3e8
.field private static final WORKER_THREAD_NAME_PREFIX:Ljava/lang/String; = "StethoWorker"
# instance fields
.field private final mAddress:Ljava/lang/String;
.field private final mFriendlyName:Ljava/lang/String;
.field private mListenerThread:Ljava/lang/Thread;
.field private mServerSocket:Landroid/net/LocalServerSocket;
.field private final mSocketHandler:Lcom/facebook/stetho/server/SocketHandler;
.field private mStopped:Z
.field private final mThreadId:Ljava/util/concurrent/atomic/AtomicInteger;
# direct methods
.method public constructor <init>(Ljava/lang/String;Ljava/lang/String;Lcom/facebook/stetho/server/SocketHandler;)V
.registers 5
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance v0, Ljava/util/concurrent/atomic/AtomicInteger;
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>()V
iput-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mThreadId:Ljava/util/concurrent/atomic/AtomicInteger;
.line 3
invoke-static {p1}, Lcom/facebook/stetho/common/Util;->throwIfNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/lang/String;
iput-object p1, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mFriendlyName:Ljava/lang/String;
.line 4
invoke-static {p2}, Lcom/facebook/stetho/common/Util;->throwIfNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/lang/String;
iput-object p1, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mAddress:Ljava/lang/String;
.line 5
iput-object p3, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mSocketHandler:Lcom/facebook/stetho/server/SocketHandler;
return-void
.end method
.method public static INVOKEVIRTUAL_com_facebook_stetho_server_LocalSocketServer_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Ljava/lang/Thread;)V
.registers 3
.line 1
:try_start_0
invoke-static {}, Lcom/shopee/app/asm/fix/androidx/b;->b()Z
move-result v0
if-eqz v0, :cond_12
.line 2
invoke-static {p0}, Lcom/shopee/app/asm/fix/androidx/b;->a(Ljava/lang/Thread;)V
:try_end_9
.catchall {:try_start_0 .. :try_end_9} :catchall_a
goto :goto_12
:catchall_a
move-exception v0
.line 3
invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;
move-result-object v1
invoke-virtual {v1, v0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V
.line 4
:cond_12
:goto_12
invoke-virtual {p0}, Ljava/lang/Thread;->start()V
return-void
.end method
.method private static bindToSocket(Ljava/lang/String;)Landroid/net/LocalServerSocket;
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const/4 v0, 0x2
const/4 v1, 0x0
:goto_2
const/4 v2, 0x3
.line 1
:try_start_3
invoke-static {v2}, Lcom/facebook/stetho/common/LogUtil;->isLoggable(I)Z
move-result v2
if-eqz v2, :cond_1d
.line 2
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Trying to bind to @"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p0}, 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-static {v2}, Lcom/facebook/stetho/common/LogUtil;->d(Ljava/lang/String;)V
.line 3
:cond_1d
new-instance v2, Landroid/net/LocalServerSocket;
invoke-direct {v2, p0}, Landroid/net/LocalServerSocket;-><init>(Ljava/lang/String;)V
:try_end_22
.catch Ljava/net/BindException; {:try_start_3 .. :try_end_22} :catch_23
return-object v2
:catch_23
move-exception v2
const-string v3, "Binding error, sleep 1000 ms..."
.line 4
invoke-static {v2, v3}, Lcom/facebook/stetho/common/LogUtil;->w(Ljava/lang/Throwable;Ljava/lang/String;)V
if-nez v1, :cond_2c
move-object v1, v2
:cond_2c
const-wide/16 v2, 0x3e8
.line 5
invoke-static {v2, v3}, Lcom/facebook/stetho/common/Util;->sleepUninterruptibly(J)V
add-int/lit8 v2, v0, -0x1
if-lez v0, :cond_37
move v0, v2
goto :goto_2
.line 6
:cond_37
throw v1
.end method
.method private listenOnAddress(Ljava/lang/String;)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-static {p1}, Lcom/facebook/stetho/server/LocalSocketServer;->bindToSocket(Ljava/lang/String;)Landroid/net/LocalServerSocket;
move-result-object v0
iput-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mServerSocket:Landroid/net/LocalServerSocket;
.line 2
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Listening on @"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/facebook/stetho/common/LogUtil;->i(Ljava/lang/String;)V
.line 3
:goto_1a
invoke-static {}, Ljava/lang/Thread;->interrupted()Z
move-result v0
if-nez v0, :cond_6e
.line 4
:try_start_20
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mServerSocket:Landroid/net/LocalServerSocket;
invoke-virtual {v0}, Landroid/net/LocalServerSocket;->accept()Landroid/net/LocalSocket;
move-result-object v0
.line 5
new-instance v1, Lcom/facebook/stetho/server/LocalSocketServer$WorkerThread;
iget-object v2, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mSocketHandler:Lcom/facebook/stetho/server/SocketHandler;
invoke-direct {v1, v0, v2}, Lcom/facebook/stetho/server/LocalSocketServer$WorkerThread;-><init>(Landroid/net/LocalSocket;Lcom/facebook/stetho/server/SocketHandler;)V
.line 6
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "StethoWorker-"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mFriendlyName:Ljava/lang/String;
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "-"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mThreadId:Ljava/util/concurrent/atomic/AtomicInteger;
.line 7
invoke-virtual {v2}, Ljava/util/concurrent/atomic/AtomicInteger;->incrementAndGet()I
move-result v2
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 8
invoke-virtual {v1, v0}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V
const/4 v0, 0x1
.line 9
invoke-virtual {v1, v0}, Ljava/lang/Thread;->setDaemon(Z)V
.line 10
invoke-static {v1}, Lcom/facebook/stetho/server/LocalSocketServer;->INVOKEVIRTUAL_com_facebook_stetho_server_LocalSocketServer_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Ljava/lang/Thread;)V
:try_end_58
.catch Ljava/net/SocketException; {:try_start_20 .. :try_end_58} :catch_60
.catch Ljava/io/InterruptedIOException; {:try_start_20 .. :try_end_58} :catch_6e
.catch Ljava/io/IOException; {:try_start_20 .. :try_end_58} :catch_59
goto :goto_1a
:catch_59
move-exception v0
const-string v1, "I/O error initialising connection thread"
.line 11
invoke-static {v0, v1}, Lcom/facebook/stetho/common/LogUtil;->w(Ljava/lang/Throwable;Ljava/lang/String;)V
goto :goto_6e
:catch_60
move-exception v0
.line 12
invoke-static {}, Ljava/lang/Thread;->interrupted()Z
move-result v1
if-eqz v1, :cond_68
goto :goto_6e
:cond_68
const-string v1, "I/O error"
.line 13
invoke-static {v0, v1}, Lcom/facebook/stetho/common/LogUtil;->w(Ljava/lang/Throwable;Ljava/lang/String;)V
goto :goto_1a
.line 14
:catch_6e
:cond_6e
:goto_6e
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Server shutdown on @"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Lcom/facebook/stetho/common/LogUtil;->i(Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method public getName()Ljava/lang/String;
.registers 2
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mFriendlyName:Ljava/lang/String;
return-object v0
.end method
.method public run()V
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
monitor-enter p0
.line 2
:try_start_1
iget-boolean v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mStopped:Z
if-eqz v0, :cond_7
.line 3
monitor-exit p0
return-void
.line 4
:cond_7
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
iput-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mListenerThread:Ljava/lang/Thread;
.line 5
monitor-exit p0
:try_end_e
.catchall {:try_start_1 .. :try_end_e} :catchall_14
.line 6
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mAddress:Ljava/lang/String;
invoke-direct {p0, v0}, Lcom/facebook/stetho/server/LocalSocketServer;->listenOnAddress(Ljava/lang/String;)V
return-void
:catchall_14
move-exception v0
.line 7
:try_start_15
monitor-exit p0
:try_end_16
.catchall {:try_start_15 .. :try_end_16} :catchall_14
throw v0
.end method
.method public stop()V
.registers 2
.line 1
monitor-enter p0
const/4 v0, 0x1
.line 2
:try_start_2
iput-boolean v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mStopped:Z
.line 3
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mListenerThread:Ljava/lang/Thread;
if-nez v0, :cond_a
.line 4
monitor-exit p0
return-void
.line 5
:cond_a
monitor-exit p0
:try_end_b
.catchall {:try_start_2 .. :try_end_b} :catchall_16
.line 6
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
.line 7
:try_start_e
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mServerSocket:Landroid/net/LocalServerSocket;
if-eqz v0, :cond_15
.line 8
invoke-virtual {v0}, Landroid/net/LocalServerSocket;->close()V
:try_end_15
.catch Ljava/io/IOException; {:try_start_e .. :try_end_15} :catch_15
:catch_15
:cond_15
return-void
:catchall_16
move-exception v0
.line 9
:try_start_17
monitor-exit p0
:try_end_18
.catchall {:try_start_17 .. :try_end_18} :catchall_16
throw v0
.end method