a.smali
.class public final Lcom/baidu/crabsdk/sender/a;
.super Ljava/lang/Thread;
# static fields
.field private static b:Z
# instance fields
.field private final a:Landroid/content/Context;
.field private final c:Ljava/lang/ref/SoftReference;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/ref/SoftReference",
"<",
"Landroid/os/Looper;",
">;"
}
.end annotation
.end field
.field private d:Ljava/lang/ref/SoftReference;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/ref/SoftReference",
"<",
"Landroid/os/Handler;",
">;"
}
.end annotation
.end field
.field private final e:I
.field private volatile f:I
.field private g:Z
.field private final h:Ljava/lang/Runnable;
# direct methods
.method static constructor <clinit>()V
.registers 1
const/4 v0, 0x0
sput-boolean v0, Lcom/baidu/crabsdk/sender/a;->b:Z
return-void
.end method
.method public constructor <init>(Landroid/content/Context;)V
.registers 5
const/4 v2, 0x0
invoke-direct {p0}, Ljava/lang/Thread;-><init>()V
new-instance v0, Ljava/lang/ref/SoftReference;
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/ref/SoftReference;-><init>(Ljava/lang/Object;)V
iput-object v0, p0, Lcom/baidu/crabsdk/sender/a;->c:Ljava/lang/ref/SoftReference;
iput v2, p0, Lcom/baidu/crabsdk/sender/a;->f:I
iput-boolean v2, p0, Lcom/baidu/crabsdk/sender/a;->g:Z
new-instance v0, Lcom/baidu/crabsdk/sender/b;
invoke-direct {v0, p0}, Lcom/baidu/crabsdk/sender/b;-><init>(Lcom/baidu/crabsdk/sender/a;)V
iput-object v0, p0, Lcom/baidu/crabsdk/sender/a;->h:Ljava/lang/Runnable;
iput-object p1, p0, Lcom/baidu/crabsdk/sender/a;->a:Landroid/content/Context;
const/16 v0, 0xbb8
iput v0, p0, Lcom/baidu/crabsdk/sender/a;->e:I
return-void
.end method
.method static synthetic a(Lcom/baidu/crabsdk/sender/a;)I
.registers 2
iget v0, p0, Lcom/baidu/crabsdk/sender/a;->f:I
return v0
.end method
.method static synthetic a(Lcom/baidu/crabsdk/sender/a;I)I
.registers 2
iput p1, p0, Lcom/baidu/crabsdk/sender/a;->f:I
return p1
.end method
.method private a()V
.registers 14
const/4 v12, 0x0
const-string v0, "===readLog()==="
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->s(Ljava/lang/String;)I
iget-boolean v0, p0, Lcom/baidu/crabsdk/sender/a;->g:Z
if-eqz v0, :cond_b
:cond_a
:goto_a
return-void
:cond_b
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/baidu/crabsdk/sender/a;->g:Z
:try_start_e
const-string v0, "===readingTrace==="
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->s(Ljava/lang/String;)I
const-string v0, "MM-dd HH:mm:ss.SSS"
new-instance v1, Ljava/text/SimpleDateFormat;
invoke-direct {v1, v0}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V
const-string v2, "Wrote stack traces to \'/data/anr/traces.txt\'"
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v4
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v3
invoke-virtual {v1, v3}, Ljava/text/SimpleDateFormat;->format(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime;
move-result-object v3
const-string v6, "logcat -v time"
invoke-virtual {v3, v6}, Ljava/lang/Runtime;->exec(Ljava/lang/String;)Ljava/lang/Process;
move-result-object v3
new-instance v6, Ljava/io/BufferedReader;
new-instance v7, Ljava/io/InputStreamReader;
invoke-virtual {v3}, Ljava/lang/Process;->getInputStream()Ljava/io/InputStream;
move-result-object v3
invoke-direct {v7, v3}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;)V
const/16 v3, 0x2000
invoke-direct {v6, v7, v3}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;I)V
:cond_42
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v8
sub-long/2addr v8, v4
const-wide/16 v10, 0x7530
cmp-long v3, v8, v10
if-gtz v3, :cond_b7
invoke-virtual {v6}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v3
if-eqz v3, :cond_b7
invoke-virtual {v3}, Ljava/lang/String;->length()I
move-result v7
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v8
if-lt v7, v8, :cond_b7
const/4 v7, 0x0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v8
invoke-virtual {v3, v7, v8}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v7
invoke-virtual {v7, v1}, Ljava/lang/String;->compareTo(Ljava/lang/String;)I
move-result v7
if-ltz v7, :cond_42
invoke-virtual {v3, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v3
if-eqz v3, :cond_42
const-string v0, "===line.contains(tracesWroteLog)==="
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->s(Ljava/lang/String;)I
iget-object v0, p0, Lcom/baidu/crabsdk/sender/a;->a:Landroid/content/Context;
const/4 v1, 0x0
const/4 v2, 0x0
invoke-static {v0, v1, v2}, Lcom/baidu/crabsdk/sender/d;->a(Landroid/content/Context;Ljava/lang/Throwable;Z)Ljava/util/Map;
move-result-object v0
invoke-static {}, Lcom/baidu/crabsdk/b/c;->w()Ljava/util/Map;
move-result-object v1
if-eqz v1, :cond_a
invoke-interface {v1}, Ljava/util/Map;->size()I
move-result v2
if-eqz v2, :cond_a
invoke-interface {v0, v1}, Ljava/util/Map;->putAll(Ljava/util/Map;)V
invoke-static {v0}, Lcom/baidu/crabsdk/sender/d;->b(Ljava/util/Map;)V
invoke-static {v0}, Lcom/baidu/crabsdk/sender/f;->d(Ljava/util/Map;)Ljava/lang/String;
move-result-object v0
iget-object v2, p0, Lcom/baidu/crabsdk/sender/a;->a:Landroid/content/Context;
invoke-static {v2, v0}, Lcom/baidu/crabsdk/sender/f;->a(Landroid/content/Context;Ljava/lang/String;)V
invoke-static {}, Lcom/baidu/crabsdk/sender/e;->ae()V
invoke-static {}, Lcom/baidu/crabsdk/sender/e;->X()Z
move-result v0
if-eqz v0, :cond_ae
const-string v0, "===uploadAnr==="
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->s(Ljava/lang/String;)I
const/4 v0, 0x0
iget-object v2, p0, Lcom/baidu/crabsdk/sender/a;->a:Landroid/content/Context;
invoke-static {v0, v2}, Lcom/baidu/crabsdk/sender/h;->a(ZLandroid/content/Context;)V
:cond_ae
sget-object v0, Lcom/baidu/crabsdk/a;->L:Lcom/baidu/crabsdk/OnAnrCrashListener;
if-eqz v0, :cond_b7
sget-object v0, Lcom/baidu/crabsdk/a;->L:Lcom/baidu/crabsdk/OnAnrCrashListener;
invoke-interface {v0, v1}, Lcom/baidu/crabsdk/OnAnrCrashListener;->onAnrStarted(Ljava/util/Map;)V
:try_end_b7
.catch Ljava/lang/Exception; {:try_start_e .. :try_end_b7} :catch_bb
:cond_b7
:goto_b7
iput-boolean v12, p0, Lcom/baidu/crabsdk/sender/a;->g:Z
goto/16 :goto_a
:catch_bb
move-exception v0
const-string v1, "ANR Log"
invoke-static {v1, v0}, Lcom/baidu/crabsdk/c/a;->a(Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_b7
.end method
# virtual methods
.method public final run()V
.registers 6
const/4 v4, 0x0
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "***isRunning = "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
sget-boolean v1, Lcom/baidu/crabsdk/sender/a;->b:Z
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "***"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->s(Ljava/lang/String;)I
sget-boolean v0, Lcom/baidu/crabsdk/sender/a;->b:Z
if-eqz v0, :cond_20
:goto_1f
return-void
:cond_20
const/4 v0, 0x1
sput-boolean v0, Lcom/baidu/crabsdk/sender/a;->b:Z
const-string v0, "|AnrWatchThread|"
invoke-virtual {p0, v0}, Lcom/baidu/crabsdk/sender/a;->setName(Ljava/lang/String;)V
const-string v0, "AnrWatchThread start!"
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I
:cond_2d
invoke-virtual {p0}, Lcom/baidu/crabsdk/sender/a;->isInterrupted()Z
move-result v0
if-nez v0, :cond_3f
iget v1, p0, Lcom/baidu/crabsdk/sender/a;->f:I
iget-object v0, p0, Lcom/baidu/crabsdk/sender/a;->c:Ljava/lang/ref/SoftReference;
invoke-virtual {v0}, Ljava/lang/ref/SoftReference;->get()Ljava/lang/Object;
move-result-object v0
if-nez v0, :cond_47
sput-boolean v4, Lcom/baidu/crabsdk/sender/a;->b:Z
:cond_3f
:goto_3f
sput-boolean v4, Lcom/baidu/crabsdk/sender/a;->b:Z
const-string v0, "anr watch thread is over!"
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->u(Ljava/lang/String;)I
goto :goto_1f
:cond_47
:try_start_47
iget-object v0, p0, Lcom/baidu/crabsdk/sender/a;->d:Ljava/lang/ref/SoftReference;
if-eqz v0, :cond_53
iget-object v0, p0, Lcom/baidu/crabsdk/sender/a;->d:Ljava/lang/ref/SoftReference;
invoke-virtual {v0}, Ljava/lang/ref/SoftReference;->get()Ljava/lang/Object;
move-result-object v0
if-nez v0, :cond_67
:cond_53
new-instance v2, Ljava/lang/ref/SoftReference;
new-instance v3, Landroid/os/Handler;
iget-object v0, p0, Lcom/baidu/crabsdk/sender/a;->c:Ljava/lang/ref/SoftReference;
invoke-virtual {v0}, Ljava/lang/ref/SoftReference;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/os/Looper;
invoke-direct {v3, v0}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
invoke-direct {v2, v3}, Ljava/lang/ref/SoftReference;-><init>(Ljava/lang/Object;)V
iput-object v2, p0, Lcom/baidu/crabsdk/sender/a;->d:Ljava/lang/ref/SoftReference;
:cond_67
iget-object v0, p0, Lcom/baidu/crabsdk/sender/a;->d:Ljava/lang/ref/SoftReference;
invoke-virtual {v0}, Ljava/lang/ref/SoftReference;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/os/Handler;
iget-object v2, p0, Lcom/baidu/crabsdk/sender/a;->h:Ljava/lang/Runnable;
invoke-virtual {v0, v2}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
iget v0, p0, Lcom/baidu/crabsdk/sender/a;->e:I
int-to-long v2, v0
invoke-static {v2, v3}, Ljava/lang/Thread;->sleep(J)V
:try_end_7a
.catch Ljava/lang/Exception; {:try_start_47 .. :try_end_7a} :catch_86
sget-boolean v0, Lcom/baidu/crabsdk/a;->H:Z
if-nez v0, :cond_a0
sput-boolean v4, Lcom/baidu/crabsdk/sender/a;->b:Z
const-string v0, "anr watch thread is breakdown!"
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->u(Ljava/lang/String;)I
goto :goto_3f
:catch_86
move-exception v0
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "AnrWatchThread Exception: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->t(Ljava/lang/String;)I
:cond_9d
:goto_9d
sput-boolean v4, Lcom/baidu/crabsdk/sender/a;->b:Z
goto :goto_3f
:cond_a0
iget v0, p0, Lcom/baidu/crabsdk/sender/a;->f:I
if-ne v0, v1, :cond_2d
const-string v0, "onAppNotResponding!"
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I
iget-object v0, p0, Lcom/baidu/crabsdk/sender/a;->a:Landroid/content/Context;
if-eqz v0, :cond_9d
sget-boolean v0, Lcom/baidu/crabsdk/a;->I:Z
if-nez v0, :cond_9d
invoke-direct {p0}, Lcom/baidu/crabsdk/sender/a;->a()V
goto :goto_9d
.end method