LocalSocketServer.smali
.class public Lcom/facebook/stetho/server/LocalSocketServer;
.super Ljava/lang/Object;
.source "LocalSocketServer.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/facebook/stetho/server/LocalSocketServer$WorkerThread;
}
.end annotation
# static fields
.field public static final MAX_BIND_RETRIES:I
.field public static final TIME_BETWEEN_BIND_RETRIES_MS:I
.field public static final WORKER_THREAD_NAME_PREFIX:Ljava/lang/String; = "StethoWorker"
# instance fields
.field public final mAddress:Ljava/lang/String;
.field public final mFriendlyName:Ljava/lang/String;
.field public mListenerThread:Ljava/lang/Thread;
.field public mServerSocket:Landroid/net/LocalServerSocket;
.field public final mSocketHandler:Lcom/facebook/stetho/server/SocketHandler;
.field public mStopped:Z
.field public final mThreadId:Ljava/util/concurrent/atomic/AtomicInteger;
# direct methods
.method static constructor <clinit>()V
.registers 1
const v0, 0x58
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/facebook/stetho/server/LocalSocketServer;->MAX_BIND_RETRIES:I
const v0, 0x3b2
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/facebook/stetho/server/LocalSocketServer;->TIME_BETWEEN_BIND_RETRIES_MS:I
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Ljava/lang/String;Lcom/facebook/stetho/server/SocketHandler;)V
.registers 5
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
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;
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;
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;
iput-object p3, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mSocketHandler:Lcom/facebook/stetho/server/SocketHandler;
return-void
.end method
.method public static bindToSocket(Ljava/lang/String;)Landroid/net/LocalServerSocket;
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.annotation runtime Ljavax/annotation/Nonnull;
.end annotation
const/4 v0, 0x2
const/4 v1, 0x0
:goto_2
const/4 v2, 0x3
:try_start_3
invoke-static {v2}, Lcom/facebook/stetho/common/LogUtil;->isLoggable(I)Z
move-result v2
if-eqz v2, :cond_1d
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
: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..."
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
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
:cond_37
goto :goto_39
:goto_38
throw v1
:goto_39
goto :goto_38
.end method
.method private listenOnAddress(Ljava/lang/String;)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
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;
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
:goto_1a
invoke-static {}, Ljava/lang/Thread;->interrupted()Z
move-result v0
if-nez v0, :cond_6e
: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
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
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;
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
invoke-virtual {v1, v0}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V
const/4 v0, 0x1
invoke-virtual {v1, v0}, Ljava/lang/Thread;->setDaemon(Z)V
invoke-virtual {v1}, Ljava/lang/Thread;->start()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"
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
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"
invoke-static {v0, v1}, Lcom/facebook/stetho/common/LogUtil;->w(Ljava/lang/Throwable;Ljava/lang/String;)V
goto :goto_1a
: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
monitor-enter p0
:try_start_1
iget-boolean v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mStopped:Z
if-eqz v0, :cond_7
monitor-exit p0
return-void
: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;
monitor-exit p0
:try_end_e
.catchall {:try_start_1 .. :try_end_e} :catchall_14
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
: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
monitor-enter p0
const/4 v0, 0x1
:try_start_2
iput-boolean v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mStopped:Z
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mListenerThread:Ljava/lang/Thread;
if-nez v0, :cond_a
monitor-exit p0
return-void
:cond_a
monitor-exit p0
:try_end_b
.catchall {:try_start_2 .. :try_end_b} :catchall_1a
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mListenerThread:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
:try_start_10
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mServerSocket:Landroid/net/LocalServerSocket;
if-eqz v0, :cond_19
iget-object v0, p0, Lcom/facebook/stetho/server/LocalSocketServer;->mServerSocket:Landroid/net/LocalServerSocket;
invoke-virtual {v0}, Landroid/net/LocalServerSocket;->close()V
:try_end_19
.catch Ljava/io/IOException; {:try_start_10 .. :try_end_19} :catch_19
:catch_19
:cond_19
return-void
:catchall_1a
move-exception v0
:try_start_1b
monitor-exit p0
:try_end_1c
.catchall {:try_start_1b .. :try_end_1c} :catchall_1a
throw v0
.end method