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