c.smali
.class public final Lcom/baidu/crabsdk/b/c;
.super Ljava/lang/Object;
# static fields
.field private static a:Landroid/content/Context;
.field private static b:Ljava/lang/String;
.field private static c:I
.field private static d:Ljava/lang/Thread;
# direct methods
.method static constructor <clinit>()V
.registers 1
const-string v0, "data/anr/traces.txt"
sput-object v0, Lcom/baidu/crabsdk/b/c;->b:Ljava/lang/String;
const/4 v0, 0x5
sput v0, Lcom/baidu/crabsdk/b/c;->c:I
const/4 v0, 0x0
sput-object v0, Lcom/baidu/crabsdk/b/c;->d:Ljava/lang/Thread;
return-void
.end method
.method private static a(Ljava/util/Map;)V
.registers 12
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Map",
"<",
"Ljava/lang/String;",
"Ljava/lang/Object;",
">;)V"
}
.end annotation
const/4 v2, 0x1
const/4 v1, 0x0
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
:try_start_7
const-string v0, "time"
invoke-interface {p0, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
if-nez v0, :cond_12
:cond_11
:goto_11
return-void
:cond_12
const/4 v3, 0x5
invoke-virtual {v0, v3}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v5
new-instance v0, Ljava/io/File;
const-string v3, "/"
invoke-direct {v0, v3}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime;
move-result-object v3
const-string v6, "logcat -d -v time"
const/4 v7, 0x0
invoke-virtual {v3, v6, v7, v0}, Ljava/lang/Runtime;->exec(Ljava/lang/String;[Ljava/lang/String;Ljava/io/File;)Ljava/lang/Process;
move-result-object v0
new-instance v6, Ljava/io/BufferedReader;
new-instance v3, Ljava/io/InputStreamReader;
invoke-virtual {v0}, Ljava/lang/Process;->getInputStream()Ljava/io/InputStream;
move-result-object v0
invoke-direct {v3, v0}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;)V
const/16 v0, 0x2000
invoke-direct {v6, v3, v0}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;I)V
invoke-static {}, Lcom/baidu/crabsdk/b/o;->I()Ljava/lang/String;
move-result-object v7
move v0, v2
move v2, v1
:goto_3f
invoke-virtual {v6}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v8
if-eqz v8, :cond_11
add-int/lit8 v3, v2, 0x1
const v9, 0x7fffffff
if-ge v2, v9, :cond_11
if-eqz v0, :cond_55
invoke-virtual {v8, v5}, Ljava/lang/String;->compareTo(Ljava/lang/String;)I
move-result v2
if-ltz v2, :cond_c1
move v0, v1
:cond_55
const-string v2, "Input event dispatching timed out"
invoke-virtual {v8, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_64
const-string v2, "type"
const-string v9, "Input event dispatching timed out"
invoke-interface {p0, v2, v9}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_64
const-string v2, "Timeout executing service"
invoke-virtual {v8, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_73
const-string v2, "type"
const-string v9, "Timeout executing service"
invoke-interface {p0, v2, v9}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_73
const-string v2, "Activity pause timed out"
invoke-virtual {v8, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_82
const-string v2, "type"
const-string v9, "Activity pause timed out"
invoke-interface {p0, v2, v9}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_82
const-string v2, "Reason:"
invoke-virtual {v8, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_a0
const-string v2, "Reason:"
invoke-virtual {v8, v2}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v2
array-length v9, v2
const/4 v10, 0x2
if-ne v9, v10, :cond_a0
const-string v9, "reason"
const/4 v10, 0x1
aget-object v2, v2, v10
invoke-virtual {v2}, Ljava/lang/String;->trim()Ljava/lang/String;
move-result-object v2
invoke-interface {p0, v9, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_a0
const-string v2, "ActivityManager"
invoke-virtual {v8, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_ae
invoke-virtual {v8, v7}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_b7
:cond_ae
invoke-virtual {v4, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v8, "\n"
invoke-virtual {v2, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:try_end_b7
.catch Ljava/lang/Exception; {:try_start_7 .. :try_end_b7} :catch_b9
:cond_b7
move v2, v3
goto :goto_3f
:catch_b9
move-exception v0
const-string v1, "putAnrLogcat"
invoke-static {v1, v0}, Lcom/baidu/crabsdk/c/a;->a(Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_11
:cond_c1
move v2, v3
goto/16 :goto_3f
.end method
.method private static a(Ljava/lang/String;)Z
.registers 7
const/4 v5, 0x4
const/4 v1, 0x1
const/4 v0, 0x0
new-array v3, v5, [Ljava/lang/String;
const-string v2, "android."
aput-object v2, v3, v0
const-string v2, "java."
aput-object v2, v3, v1
const/4 v2, 0x2
const-string v4, "dalvik."
aput-object v4, v3, v2
const/4 v2, 0x3
const-string v4, "com.android."
aput-object v4, v3, v2
move v2, v0
:goto_18
if-ge v2, v5, :cond_26
aget-object v4, v3, v2
invoke-virtual {p0, v4}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v4
if-eqz v4, :cond_23
:goto_22
return v0
:cond_23
add-int/lit8 v2, v2, 0x1
goto :goto_18
:cond_26
move v0, v1
goto :goto_22
.end method
.method public static d(Landroid/content/Context;)V
.registers 2
const-string v0, "init AnrCollector"
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I
const-string v0, "===Anr init!==="
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I
sput-object p0, Lcom/baidu/crabsdk/b/c;->a:Landroid/content/Context;
invoke-static {}, Lcom/baidu/crabsdk/sender/e;->ab()Z
move-result v0
if-eqz v0, :cond_21
const-string v0, "===Anr watchThread start!==="
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I
:try_start_17
new-instance v0, Lcom/baidu/crabsdk/sender/a;
invoke-direct {v0, p0}, Lcom/baidu/crabsdk/sender/a;-><init>(Landroid/content/Context;)V
sput-object v0, Lcom/baidu/crabsdk/b/c;->d:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->start()V
:try_end_21
.catch Ljava/lang/Exception; {:try_start_17 .. :try_end_21} :catch_22
:cond_21
:goto_21
return-void
:catch_22
move-exception v0
const-string v0, "Anr watchThread start failed !!"
invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->t(Ljava/lang/String;)I
goto :goto_21
.end method
.method public static v()Ljava/lang/Thread;
.registers 1
sget-object v0, Lcom/baidu/crabsdk/b/c;->d:Ljava/lang/Thread;
return-object v0
.end method
.method public static w()Ljava/util/Map;
.registers 16
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Map",
"<",
"Ljava/lang/String;",
"Ljava/lang/Object;",
">;"
}
.end annotation
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
const-string v3, "N/A"
const-string v7, "N/A"
new-instance v9, Ljava/util/ArrayList;
invoke-direct {v9}, Ljava/util/ArrayList;-><init>()V
new-instance v10, Ljava/util/ArrayList;
invoke-direct {v10}, Ljava/util/ArrayList;-><init>()V
const-string v2, "N/A"
const-string v5, "N/A"
const-string v4, "N/A"
const/4 v8, 0x0
const/4 v6, 0x0
:try_start_1b
new-instance v0, Ljava/io/FileInputStream;
sget-object v11, Lcom/baidu/crabsdk/b/c;->b:Ljava/lang/String;
invoke-direct {v0, v11}, Ljava/io/FileInputStream;-><init>(Ljava/lang/String;)V
new-instance v11, Ljava/io/BufferedReader;
new-instance v12, Ljava/io/InputStreamReader;
invoke-direct {v12, v0}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;)V
invoke-direct {v11, v12}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;)V
invoke-virtual {v11}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v0
invoke-static {}, Lcom/baidu/crabsdk/b/o;->I()Ljava/lang/String;
move-result-object v12
:goto_34
if-eqz v0, :cond_18e
const-string v13, "-----"
invoke-virtual {v0, v13}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v13
if-eqz v13, :cond_71
const-string v13, "-----"
invoke-virtual {v0, v13}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v13
if-eqz v13, :cond_71
const-string v13, " pid "
invoke-virtual {v0, v13}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v13
if-eqz v13, :cond_71
const-string v13, " at "
invoke-virtual {v0, v13}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v13
if-eqz v13, :cond_71
add-int/lit8 v6, v6, 0x1
sget v13, Lcom/baidu/crabsdk/b/c;->c:I
if-le v6, v13, :cond_61
invoke-virtual {v11}, Ljava/io/BufferedReader;->close()V
const/4 v0, 0x0
:goto_60
return-object v0
:cond_61
const-string v13, "----- pid | at | -----$"
invoke-virtual {v0, v13}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v13
array-length v14, v13
const/4 v15, 0x3
if-lt v14, v15, :cond_71
const/4 v7, 0x1
aget-object v3, v13, v7
const/4 v7, 0x2
aget-object v7, v13, v7
:cond_71
invoke-virtual {v0, v12}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v13
if-eqz v13, :cond_188
const-string v6, "apiType"
const-string v12, "ANR"
invoke-interface {v1, v6, v12}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v6, "errorType"
const-string v12, "ANR"
invoke-interface {v1, v6, v12}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v6, "pid"
invoke-interface {v1, v6, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v6, "time"
invoke-interface {v1, v6, v7}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
:goto_94
if-eqz v0, :cond_ac
const-string v7, "DALVIK THREADS"
invoke-virtual {v0, v7}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v7
if-nez v7, :cond_ac
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v7, "\n"
invoke-virtual {v0, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v0
goto :goto_94
:cond_ac
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
const-string v0, "anrMsg"
invoke-interface {v1, v0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
invoke-virtual {v10, v2}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
new-instance v12, Ljava/lang/StringBuilder;
invoke-direct {v12}, Ljava/lang/StringBuilder;-><init>()V
move v0, v8
:goto_c3
invoke-virtual {v11}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v6
if-eqz v6, :cond_18e
const-string v8, "----- end "
invoke-virtual {v6, v8}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v8
if-nez v8, :cond_18e
const-string v8, "prio"
invoke-virtual {v6, v8}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v8
if-eqz v8, :cond_162
const-string v8, "tid"
invoke-virtual {v6, v8}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v8
if-eqz v8, :cond_162
const/4 v8, 0x1
if-le v0, v8, :cond_eb
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v9, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
:cond_eb
invoke-virtual {v12}, Ljava/lang/StringBuilder;->length()I
move-result v0
if-lez v0, :cond_f8
invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v10, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
:cond_f8
const/4 v0, 0x0
invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->setLength(I)V
const/4 v0, 0x0
invoke-virtual {v12, v0}, Ljava/lang/StringBuilder;->setLength(I)V
const/4 v0, 0x0
invoke-virtual {v12, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
const-string v13, "\n"
invoke-virtual {v8, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v8, "\".*\""
invoke-static {v8}, Ljava/util/regex/Pattern;->compile(Ljava/lang/String;)Ljava/util/regex/Pattern;
move-result-object v8
invoke-virtual {v8, v6}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
move-result-object v8
invoke-virtual {v8}, Ljava/util/regex/Matcher;->find()Z
move-result v13
if-eqz v13, :cond_126
invoke-virtual {v8}, Ljava/util/regex/Matcher;->group()Ljava/lang/String;
move-result-object v6
const-string v8, "\""
const-string v13, ""
invoke-virtual {v6, v8, v13}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v6
:cond_126
invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string v8, "\n"
invoke-virtual {v6, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:try_end_12f
.catch Ljava/io/IOException; {:try_start_1b .. :try_end_12f} :catch_130
goto :goto_c3
:catch_130
move-exception v0
const-string v4, "\u8bfb\u53d6traces.txt\u6587\u4ef6\u5931\u8d25!"
invoke-static {v4, v0}, Lcom/baidu/crabsdk/c/a;->a(Ljava/lang/String;Ljava/lang/Throwable;)I
:try_start_136
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v0
invoke-virtual {v0}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Thread;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v4
if-eqz v4, :cond_260
array-length v0, v4
if-lez v0, :cond_260
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const/4 v0, 0x0
:goto_14d
array-length v6, v4
if-ge v0, v6, :cond_269
aget-object v6, v4, v0
invoke-virtual {v6}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string v7, "\n"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:try_end_15f
.catch Ljava/lang/Exception; {:try_start_136 .. :try_end_15f} :catch_2d1
add-int/lit8 v0, v0, 0x1
goto :goto_14d
:cond_162
:try_start_162
const-string v8, " at "
invoke-virtual {v6, v8}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v8
if-eqz v8, :cond_17d
const-string v8, " at "
const-string v13, ""
invoke-virtual {v6, v8, v13}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v8
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
const-string v13, "\n"
invoke-virtual {v8, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
add-int/lit8 v0, v0, 0x1
:cond_17d
invoke-virtual {v12, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string v8, "\n"
invoke-virtual {v6, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
goto/16 :goto_c3
:cond_188
invoke-virtual {v11}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v0
goto/16 :goto_34
:cond_18e
invoke-virtual {v9}, Ljava/util/ArrayList;->size()I
move-result v0
if-lez v0, :cond_1bc
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v9}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v7
:goto_19d
invoke-interface {v7}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_1b3
invoke-interface {v7}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v8, "###"
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
goto :goto_19d
:cond_1b3
const-string v0, "threadList"
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-interface {v1, v0, v6}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_1bc
invoke-virtual {v10}, Ljava/util/ArrayList;->size()I
move-result v0
if-lez v0, :cond_1ea
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v10}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v7
:goto_1cb
invoke-interface {v7}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_1e1
invoke-interface {v7}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v8, "###"
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
goto :goto_1cb
:cond_1e1
const-string v0, "traceList"
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-interface {v1, v0, v6}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_1ea
invoke-virtual {v9}, Ljava/util/ArrayList;->size()I
move-result v0
if-lez v0, :cond_25a
invoke-virtual {v9}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v6
:cond_1f4
invoke-interface {v6}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_25a
invoke-interface {v6}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
const-string v7, "main\n"
invoke-virtual {v0, v7}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v7
if-eqz v7, :cond_1f4
const-string v6, "mainThread"
invoke-interface {v1, v6, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v6, "\n"
invoke-virtual {v0, v6}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v6
const/4 v0, 0x1
:goto_214
array-length v7, v6
if-ge v0, v7, :cond_2de
aget-object v7, v6, v0
invoke-static {v7}, Lcom/baidu/crabsdk/b/c;->a(Ljava/lang/String;)Z
move-result v7
if-eqz v7, :cond_263
aget-object v0, v6, v0
:goto_221
const-string v5, "N/A"
invoke-virtual {v0, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v5
if-eqz v5, :cond_2db
array-length v5, v6
const/4 v7, 0x1
if-le v5, v7, :cond_2db
const/4 v0, 0x1
aget-object v0, v6, v0
move-object v5, v0
:goto_231
array-length v0, v6
add-int/lit8 v0, v0, -0x1
:goto_234
if-lez v0, :cond_2d8
aget-object v7, v6, v0
invoke-static {v7}, Lcom/baidu/crabsdk/b/c;->a(Ljava/lang/String;)Z
move-result v7
if-eqz v7, :cond_266
aget-object v0, v6, v0
:goto_240
const-string v4, "N/A"
invoke-virtual {v0, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v4
if-eqz v4, :cond_250
array-length v4, v6
if-lez v4, :cond_250
array-length v0, v6
add-int/lit8 v0, v0, -0x1
aget-object v0, v6, v0
:cond_250
const-string v4, "errorLine"
invoke-interface {v1, v4, v5}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v4, "errorOriLine"
invoke-interface {v1, v4, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_25a
invoke-virtual {v11}, Ljava/io/BufferedReader;->close()V
invoke-static {v1}, Lcom/baidu/crabsdk/b/c;->a(Ljava/util/Map;)V
:try_end_260
.catch Ljava/io/IOException; {:try_start_162 .. :try_end_260} :catch_130
:cond_260
:goto_260
move-object v0, v1
goto/16 :goto_60
:cond_263
add-int/lit8 v0, v0, 0x1
goto :goto_214
:cond_266
add-int/lit8 v0, v0, -0x1
goto :goto_234
:cond_269
:try_start_269
const-string v0, "apiType"
const-string v6, "ANR"
invoke-interface {v1, v0, v6}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "errorType"
const-string v6, "ANR"
invoke-interface {v1, v0, v6}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "pid"
invoke-interface {v1, v0, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "time"
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v6
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v3
invoke-interface {v1, v0, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "anrMsg"
invoke-interface {v1, v0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "threadList"
invoke-static {}, Lcom/baidu/crabsdk/b/r;->O()Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
new-instance v0, Ljava/lang/StringBuilder;
const-string v2, "\u7531\u4e8e\u7cfb\u7edf\u539f\u56e0\uff0cAndroid7.0\u4ee5\u4e0a\u65e0\u6743\u9650\u8bfb\u53d6\"data/anr/traces.txt\"\n\n"
invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v2}, 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
const-string v2, "traceList"
invoke-interface {v1, v2, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "mainThread"
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "errorLine"
const/4 v2, 0x0
aget-object v2, v4, v2
invoke-virtual {v2}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v0, "errorOriLine"
const/4 v2, 0x0
aget-object v2, v4, v2
invoke-virtual {v2}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_2d0
.catch Ljava/lang/Exception; {:try_start_269 .. :try_end_2d0} :catch_2d1
goto :goto_260
:catch_2d1
move-exception v0
const-string v2, "7.0+\u5c01\u88c5anr\u6570\u636e\u5931\u8d25!"
invoke-static {v2, v0}, Lcom/baidu/crabsdk/c/a;->a(Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_260
:cond_2d8
move-object v0, v4
goto/16 :goto_240
:cond_2db
move-object v5, v0
goto/16 :goto_231
:cond_2de
move-object v0, v5
goto/16 :goto_221
.end method