b.smali
.class final Lxcrash/b;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field private static final o:Lxcrash/b;
# instance fields
.field a:Landroid/content/Context;
.field b:I
.field c:Ljava/lang/String;
.field d:Ljava/lang/String;
.field e:Ljava/lang/String;
.field f:Ljava/lang/String;
.field g:Z
.field h:I
.field i:I
.field j:I
.field k:Z
.field l:Z
.field m:Lxcrash/f;
.field n:Landroid/os/FileObserver;
.field private final p:Ljava/util/Date;
.field private final q:Ljava/util/regex/Pattern;
.field private final r:Ljava/util/regex/Pattern;
.field private final s:J
.field private t:J
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 45
new-instance v0, Lxcrash/b;
invoke-direct {v0}, Lxcrash/b;-><init>()V
sput-object v0, Lxcrash/b;->o:Lxcrash/b;
return-void
.end method
.method private constructor <init>()V
.registers 3
.line 68
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 47
new-instance v0, Ljava/util/Date;
invoke-direct {v0}, Ljava/util/Date;-><init>()V
iput-object v0, p0, Lxcrash/b;->p:Ljava/util/Date;
const-string v0, "^-----\\spid\\s(\\d+)\\sat\\s(.*)\\s-----$"
.line 48
invoke-static {v0}, Ljava/util/regex/Pattern;->compile(Ljava/lang/String;)Ljava/util/regex/Pattern;
move-result-object v0
iput-object v0, p0, Lxcrash/b;->q:Ljava/util/regex/Pattern;
const-string v0, "^Cmd\\sline:\\s+(.*)$"
.line 49
invoke-static {v0}, Ljava/util/regex/Pattern;->compile(Ljava/lang/String;)Ljava/util/regex/Pattern;
move-result-object v0
iput-object v0, p0, Lxcrash/b;->r:Ljava/util/regex/Pattern;
const-wide/16 v0, 0x3a98
.line 50
iput-wide v0, p0, Lxcrash/b;->s:J
const-wide/16 v0, 0x0
.line 65
iput-wide v0, p0, Lxcrash/b;->t:J
const/4 v0, 0x0
.line 66
iput-object v0, p0, Lxcrash/b;->n:Landroid/os/FileObserver;
return-void
.end method
.method private a(Ljava/lang/String;J)Ljava/lang/String;
.registers 15
.line 255
new-instance v0, Ljava/text/SimpleDateFormat;
sget-object v1, Ljava/util/Locale;->US:Ljava/util/Locale;
const-string v2, "yyyy-MM-dd HH:mm:ss"
invoke-direct {v0, v2, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
.line 256
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const/4 v2, 0x0
.line 260
:try_start_f
new-instance v3, Ljava/io/BufferedReader;
new-instance v4, Ljava/io/FileReader;
invoke-direct {v4, p1}, Ljava/io/FileReader;-><init>(Ljava/lang/String;)V
invoke-direct {v3, v4}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;)V
:try_end_19
.catch Ljava/lang/Exception; {:try_start_f .. :try_end_19} :catch_c3
.catchall {:try_start_f .. :try_end_19} :catchall_bc
const/4 p1, 0x1
const/4 v4, 0x0
.line 261
:cond_1b
:goto_1b
:try_start_1b
invoke-virtual {v3}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v5
if-eqz v5, :cond_af
const/16 v6, 0xa
if-nez v4, :cond_9d
const-string v7, "----- pid "
.line 262
invoke-virtual {v5, v7}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v7
if-eqz v7, :cond_9d
.line 265
iget-object v7, p0, Lxcrash/b;->q:Ljava/util/regex/Pattern;
invoke-virtual {v7, v5}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
move-result-object v5
.line 266
invoke-virtual {v5}, Ljava/util/regex/Matcher;->find()Z
move-result v7
if-eqz v7, :cond_1b
invoke-virtual {v5}, Ljava/util/regex/Matcher;->groupCount()I
move-result v7
const/4 v8, 0x2
if-ne v7, v8, :cond_1b
.line 269
invoke-virtual {v5, p1}, Ljava/util/regex/Matcher;->group(I)Ljava/lang/String;
move-result-object v7
.line 270
invoke-virtual {v5, v8}, Ljava/util/regex/Matcher;->group(I)Ljava/lang/String;
move-result-object v5
if-eqz v7, :cond_1b
if-eqz v5, :cond_1b
.line 274
iget v8, p0, Lxcrash/b;->b:I
invoke-static {v7}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result v7
if-ne v8, v7, :cond_1b
.line 277
invoke-virtual {v0, v5}, Ljava/text/SimpleDateFormat;->parse(Ljava/lang/String;)Ljava/util/Date;
move-result-object v5
if-eqz v5, :cond_1b
.line 281
invoke-virtual {v5}, Ljava/util/Date;->getTime()J
move-result-wide v7
sub-long/2addr v7, p2
.line 282
invoke-static {v7, v8}, Ljava/lang/Math;->abs(J)J
move-result-wide v7
const-wide/16 v9, 0x3a98
cmp-long v5, v7, v9
if-gtz v5, :cond_1b
.line 287
invoke-virtual {v3}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object v5
if-eqz v5, :cond_af
.line 291
iget-object v7, p0, Lxcrash/b;->r:Ljava/util/regex/Pattern;
invoke-virtual {v7, v5}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
move-result-object v7
.line 292
invoke-virtual {v7}, Ljava/util/regex/Matcher;->find()Z
move-result v8
if-eqz v8, :cond_1b
invoke-virtual {v7}, Ljava/util/regex/Matcher;->groupCount()I
move-result v8
if-ne v8, p1, :cond_1b
.line 295
invoke-virtual {v7, p1}, Ljava/util/regex/Matcher;->group(I)Ljava/lang/String;
move-result-object v7
if-eqz v7, :cond_1b
.line 296
iget-object v8, p0, Lxcrash/b;->c:Ljava/lang/String;
invoke-virtual {v7, v8}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v7
if-eqz v7, :cond_1b
.line 302
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
const-string v4, "Mode: Watching /data/anr/*\n"
.line 303
invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const/4 v4, 0x1
goto/16 :goto_1b
:cond_9d
if-eqz v4, :cond_1b
const-string v7, "----- end "
.line 309
invoke-virtual {v5, v7}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v7
if-nez v7, :cond_af
.line 312
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
goto/16 :goto_1b
.line 316
:cond_af
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
:try_end_b3
.catch Ljava/lang/Exception; {:try_start_1b .. :try_end_b3} :catch_ba
.catchall {:try_start_1b .. :try_end_b3} :catchall_b7
.line 322
:try_start_b3
invoke-virtual {v3}, Ljava/io/BufferedReader;->close()V
:try_end_b6
.catch Ljava/lang/Exception; {:try_start_b3 .. :try_end_b6} :catch_b6
:catch_b6
return-object p1
:catchall_b7
move-exception p1
move-object v2, v3
goto :goto_bd
:catch_ba
nop
goto :goto_c4
:catchall_bc
move-exception p1
:goto_bd
if-eqz v2, :cond_c2
:try_start_bf
invoke-virtual {v2}, Ljava/io/BufferedReader;->close()V
:try_end_c2
.catch Ljava/lang/Exception; {:try_start_bf .. :try_end_c2} :catch_c2
.line 324
:catch_c2
:cond_c2
throw p1
:catch_c3
move-object v3, v2
:goto_c4
if-eqz v3, :cond_c9
.line 322
:try_start_c6
invoke-virtual {v3}, Ljava/io/BufferedReader;->close()V
:try_end_c9
.catch Ljava/lang/Exception; {:try_start_c6 .. :try_end_c9} :catch_c9
:catch_c9
:cond_c9
return-object v2
.end method
.method static a()Lxcrash/b;
.registers 1
.line 72
sget-object v0, Lxcrash/b;->o:Lxcrash/b;
return-object v0
.end method
.method static synthetic a(Lxcrash/b;Ljava/lang/String;)V
.registers 13
const-string v0, "xcrash"
.line 1135
new-instance v1, Ljava/util/Date;
invoke-direct {v1}, Ljava/util/Date;-><init>()V
.line 1138
invoke-virtual {v1}, Ljava/util/Date;->getTime()J
move-result-wide v2
iget-wide v4, p0, Lxcrash/b;->t:J
sub-long/2addr v2, v4
const-wide/16 v4, 0x3a98
cmp-long v6, v2, v4
if-ltz v6, :cond_15b
.line 1143
iget-boolean v2, p0, Lxcrash/b;->g:Z
if-eqz v2, :cond_20
.line 1144
iget-object v2, p0, Lxcrash/b;->a:Landroid/content/Context;
invoke-static {v2, p1, v4, v5}, Lxcrash/l;->a(Landroid/content/Context;Ljava/lang/String;J)Z
move-result v2
if-eqz v2, :cond_15b
.line 1150
:cond_20
invoke-virtual {v1}, Ljava/util/Date;->getTime()J
move-result-wide v2
invoke-direct {p0, p1, v2, v3}, Lxcrash/b;->a(Ljava/lang/String;J)Ljava/lang/String;
move-result-object p1
.line 1151
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_15b
.line 1156
invoke-virtual {v1}, Ljava/util/Date;->getTime()J
move-result-wide v2
iput-wide v2, p0, Lxcrash/b;->t:J
.line 1159
invoke-static {}, Lxcrash/e;->a()Lxcrash/e;
move-result-object v2
invoke-virtual {v2}, Lxcrash/e;->b()Z
move-result v2
if-eqz v2, :cond_15b
const/4 v2, 0x0
.line 1234
:try_start_3f
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
iget-object v4, p0, Lxcrash/b;->p:Ljava/util/Date;
const-string v5, "anr"
iget-object v6, p0, Lxcrash/b;->d:Ljava/lang/String;
iget-object v7, p0, Lxcrash/b;->e:Ljava/lang/String;
invoke-static {v4, v1, v5, v6, v7}, Lxcrash/l;->a(Ljava/util/Date;Ljava/util/Date;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, "pid: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v4, p0, Lxcrash/b;->b:I
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v4, " >>> "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, p0, Lxcrash/b;->c:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, " <<<\n\n--- --- --- --- --- --- --- --- --- --- --- --- --- --- --- ---\n"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, "\n+++ +++ +++ +++ +++ +++ +++ +++ +++ +++ +++ +++ +++ +++ +++ +++\n\n"
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
:try_end_78
.catch Ljava/lang/Exception; {:try_start_3f .. :try_end_78} :catch_79
goto :goto_84
:catch_79
move-exception p1
.line 1168
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object v3
const-string v4, "AnrHandler getEmergency failed"
invoke-interface {v3, v0, v4, p1}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
move-object p1, v2
.line 1174
:goto_84
:try_start_84
sget-object v3, Ljava/util/Locale;->US:Ljava/util/Locale;
const-string v4, "%s/%s_%020d_%s__%s%s"
const/4 v5, 0x6
new-array v5, v5, [Ljava/lang/Object;
const/4 v6, 0x0
iget-object v7, p0, Lxcrash/b;->f:Ljava/lang/String;
aput-object v7, v5, v6
const/4 v6, 0x1
const-string v7, "tombstone"
aput-object v7, v5, v6
const/4 v6, 0x2
invoke-virtual {v1}, Ljava/util/Date;->getTime()J
move-result-wide v7
const-wide/16 v9, 0x3e8
mul-long v7, v7, v9
invoke-static {v7, v8}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
aput-object v1, v5, v6
const/4 v1, 0x3
iget-object v6, p0, Lxcrash/b;->e:Ljava/lang/String;
aput-object v6, v5, v1
const/4 v1, 0x4
iget-object v6, p0, Lxcrash/b;->c:Ljava/lang/String;
aput-object v6, v5, v1
const/4 v1, 0x5
const-string v6, ".anr.xcrash"
aput-object v6, v5, v1
invoke-static {v3, v4, v5}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
.line 1175
invoke-static {}, Lxcrash/e;->a()Lxcrash/e;
move-result-object v3
invoke-virtual {v3, v1}, Lxcrash/e;->a(Ljava/lang/String;)Ljava/io/File;
move-result-object v1
:try_end_bf
.catch Ljava/lang/Exception; {:try_start_84 .. :try_end_bf} :catch_c0
goto :goto_cb
:catch_c0
move-exception v1
.line 1177
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object v3
const-string v4, "AnrHandler createLogFile failed"
invoke-interface {v3, v0, v4, v1}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
move-object v1, v2
:goto_cb
if-eqz v1, :cond_14d
.line 1184
:try_start_cd
new-instance v3, Ljava/io/RandomAccessFile;
const-string v4, "rws"
invoke-direct {v3, v1, v4}, Ljava/io/RandomAccessFile;-><init>(Ljava/io/File;Ljava/lang/String;)V
:try_end_d4
.catch Ljava/lang/Exception; {:try_start_cd .. :try_end_d4} :catch_132
.catchall {:try_start_cd .. :try_end_d4} :catchall_130
const-string v4, "UTF-8"
if-eqz p1, :cond_e2
.line 1188
:try_start_d8
invoke-virtual {p1, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v5
invoke-virtual {v3, v5}, Ljava/io/RandomAccessFile;->write([B)V
:try_end_df
.catch Ljava/lang/Exception; {:try_start_d8 .. :try_end_df} :catch_e0
.catchall {:try_start_d8 .. :try_end_df} :catchall_145
goto :goto_e2
:catch_e0
move-exception v4
goto :goto_134
.line 1195
:cond_e2
:goto_e2
:try_start_e2
iget p1, p0, Lxcrash/b;->j:I
if-gtz p1, :cond_ee
iget p1, p0, Lxcrash/b;->h:I
if-gtz p1, :cond_ee
iget p1, p0, Lxcrash/b;->i:I
if-lez p1, :cond_ff
.line 1196
:cond_ee
iget p1, p0, Lxcrash/b;->j:I
iget v5, p0, Lxcrash/b;->h:I
iget v6, p0, Lxcrash/b;->i:I
invoke-static {p1, v5, v6}, Lxcrash/l;->a(III)Ljava/lang/String;
move-result-object p1
invoke-virtual {p1, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p1
invoke-virtual {v3, p1}, Ljava/io/RandomAccessFile;->write([B)V
.line 1200
:cond_ff
iget-boolean p1, p0, Lxcrash/b;->k:Z
if-eqz p1, :cond_10e
.line 1201
invoke-static {}, Lxcrash/l;->f()Ljava/lang/String;
move-result-object p1
invoke-virtual {p1, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p1
invoke-virtual {v3, p1}, Ljava/io/RandomAccessFile;->write([B)V
.line 1205
:cond_10e
iget-boolean p1, p0, Lxcrash/b;->l:Z
if-eqz p1, :cond_11d
.line 1206
invoke-static {}, Lxcrash/l;->e()Ljava/lang/String;
move-result-object p1
invoke-virtual {p1, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p1
invoke-virtual {v3, p1}, Ljava/io/RandomAccessFile;->write([B)V
.line 1210
:cond_11d
invoke-static {}, Lxcrash/l;->d()Ljava/lang/String;
move-result-object p1
invoke-virtual {p1, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p1
invoke-virtual {v3, p1}, Ljava/io/RandomAccessFile;->write([B)V
:try_end_128
.catch Ljava/lang/Exception; {:try_start_e2 .. :try_end_128} :catch_12d
.catchall {:try_start_e2 .. :try_end_128} :catchall_145
.line 1216
:try_start_128
invoke-virtual {v3}, Ljava/io/RandomAccessFile;->close()V
:try_end_12b
.catch Ljava/lang/Exception; {:try_start_128 .. :try_end_12b} :catch_12b
:catch_12b
move-object p1, v2
goto :goto_14d
:catch_12d
move-exception v4
move-object p1, v2
goto :goto_134
:catchall_130
move-exception p0
goto :goto_147
:catch_132
move-exception v4
move-object v3, v2
.line 1212
:goto_134
:try_start_134
invoke-static {}, Lxcrash/m;->d()Lxcrash/h;
move-result-object v5
const-string v6, "AnrHandler write log file failed"
invoke-interface {v5, v0, v6, v4}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_13d
.catchall {:try_start_134 .. :try_end_13d} :catchall_145
if-eqz v3, :cond_14d
.line 1216
:try_start_13f
invoke-virtual {v3}, Ljava/io/RandomAccessFile;->close()V
:try_end_142
.catch Ljava/lang/Exception; {:try_start_13f .. :try_end_142} :catch_143
goto :goto_14d
:catch_143
nop
goto :goto_14d
:catchall_145
move-exception p0
move-object v2, v3
:goto_147
if-eqz v2, :cond_14c
:try_start_149
invoke-virtual {v2}, Ljava/io/RandomAccessFile;->close()V
:try_end_14c
.catch Ljava/lang/Exception; {:try_start_149 .. :try_end_14c} :catch_14c
.line 1218
:catch_14c
:cond_14c
throw p0
.line 1225
:cond_14d
:goto_14d
iget-object p0, p0, Lxcrash/b;->m:Lxcrash/f;
if-eqz p0, :cond_15b
if-nez v1, :cond_154
goto :goto_158
.line 1227
:cond_154
:try_start_154
invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v2
:goto_158
invoke-interface {p0, v2, p1}, Lxcrash/f;->a(Ljava/lang/String;Ljava/lang/String;)V
:try_end_15b
.catch Ljava/lang/Exception; {:try_start_154 .. :try_end_15b} :catch_15b
:catch_15b
:cond_15b
return-void
.end method