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