NativeHandler.smali

.class Lxcrash/NativeHandler;
.super Ljava/lang/Object;
.source "SourceFile"


# static fields
.field private static final DUMP_TRACE_FROM_DUMP_TRACE:I = 0x2

.field private static final DUMP_TRACE_FROM_SIGQUIT:I = 0x1

.field private static final instance:Lxcrash/NativeHandler;


# instance fields
.field private anrCallback:Lxcrash/f;

.field private anrCheckProcessState:Z

.field private anrEnable:Z

.field private anrTimeoutMs:J

.field private crashCallback:Lxcrash/f;

.field private crashRethrow:Z

.field private ctx:Landroid/content/Context;

.field private dumpTraceCallBack:Lxcrash/f;

.field private initNativeLibOk:Z


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .line 38
    new-instance v0, Lxcrash/NativeHandler;

    invoke-direct {v0}, Lxcrash/NativeHandler;-><init>()V

    sput-object v0, Lxcrash/NativeHandler;->instance:Lxcrash/NativeHandler;

    return-void
.end method

.method private constructor <init>()V
    .registers 3

    .line 53
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    const-wide/16 v0, 0x3a98

    .line 41
    iput-wide v0, p0, Lxcrash/NativeHandler;->anrTimeoutMs:J

    const/4 v0, 0x0

    .line 51
    iput-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z

    return-void
.end method

.method private static crashCallback(Ljava/lang/String;Ljava/lang/String;ZZLjava/lang/String;)V
    .registers 6

    .line 202
    invoke-static {p0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v0

    if-nez v0, :cond_32

    if-eqz p2, :cond_17

    .line 206
    invoke-static {p3, p4}, Lxcrash/NativeHandler;->getStacktraceByThreadName(ZLjava/lang/String;)Ljava/lang/String;

    move-result-object p2

    .line 207
    invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result p3

    if-nez p3, :cond_17

    const-string p3, "java stacktrace"

    .line 208
    invoke-static {p0, p3, p2}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z

    .line 213
    :cond_17
    invoke-static {}, Lxcrash/l;->c()Ljava/lang/String;

    move-result-object p2

    const-string p3, "memory info"

    invoke-static {p0, p3, p2}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z

    .line 216
    invoke-static {}, Lxcrash/a;->a()Lxcrash/a;

    move-result-object p2

    .line 1109
    iget-boolean p2, p2, Lxcrash/a;->b:Z

    if-eqz p2, :cond_2b

    const-string p2, "yes"

    goto :goto_2d

    :cond_2b
    const-string p2, "no"

    :goto_2d
    const-string p3, "foreground"

    .line 216
    invoke-static {p0, p3, p2}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z

    .line 219
    :cond_32
    invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;

    move-result-object p2

    iget-object p2, p2, Lxcrash/NativeHandler;->crashCallback:Lxcrash/f;

    if-eqz p2, :cond_4a

    .line 222
    :try_start_3a
    invoke-interface {p2, p0, p1}, Lxcrash/f;->a(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_3d
    .catch Ljava/lang/Exception; {:try_start_3a .. :try_end_3d} :catch_3e

    goto :goto_4a

    :catch_3e
    move-exception p0

    .line 224
    invoke-static {}, Lxcrash/m;->d()Lxcrash/h;

    move-result-object p1

    const-string p2, "xcrash"

    const-string p3, "NativeHandler native crash callback.onCrash failed"

    invoke-interface {p1, p2, p3, p0}, Lxcrash/h;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 228
    :cond_4a
    :goto_4a
    invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;

    move-result-object p0

    iget-boolean p0, p0, Lxcrash/NativeHandler;->crashRethrow:Z

    if-nez p0, :cond_59

    .line 229
    invoke-static {}, Lxcrash/a;->a()Lxcrash/a;

    move-result-object p0

    invoke-virtual {p0}, Lxcrash/a;->b()V

    :cond_59
    return-void
.end method

.method static getInstance()Lxcrash/NativeHandler;
    .registers 1

    .line 57
    sget-object v0, Lxcrash/NativeHandler;->instance:Lxcrash/NativeHandler;

    return-object v0
.end method

.method private static getStacktraceByThreadName(ZLjava/lang/String;)Ljava/lang/String;
    .registers 7

    .line 182
    :try_start_0
    invoke-static {}, Ljava/lang/Thread;->getAllStackTraces()Ljava/util/Map;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;

    move-result-object v0

    :cond_c
    invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z

    move-result v1

    if-eqz v1, :cond_6e

    invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Ljava/util/Map$Entry;

    .line 183
    invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Ljava/lang/Thread;

    if-eqz p0, :cond_2c

    .line 184
    invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;

    move-result-object v3

    const-string v4, "main"

    invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v3

    if-nez v3, :cond_38

    :cond_2c
    if-nez p0, :cond_c

    invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;

    move-result-object v2

    invoke-virtual {v2, p1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z

    move-result v2

    if-eqz v2, :cond_c

    .line 185
    :cond_38
    new-instance p0, Ljava/lang/StringBuilder;

    invoke-direct {p0}, Ljava/lang/StringBuilder;-><init>()V

    .line 186
    invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;

    move-result-object p1

    check-cast p1, [Ljava/lang/StackTraceElement;

    array-length v0, p1

    const/4 v1, 0x0

    :goto_45
    if-ge v1, v0, :cond_5d

    aget-object v2, p1, v1

    const-string v3, "    at "

    .line 187
    invoke-virtual {p0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-virtual {p0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v2, "\n"

    invoke-virtual {p0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    add-int/lit8 v1, v1, 0x1

    goto :goto_45

    .line 189
    :cond_5d
    invoke-virtual {p0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object p0
    :try_end_61
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_61} :catch_62

    return-object p0

    :catch_62
    move-exception p0

    .line 193
    invoke-static {}, Lxcrash/m;->d()Lxcrash/h;

    move-result-object p1

    const-string v0, "xcrash"

    const-string v1, "NativeHandler getStacktraceByThreadName failed"

    invoke-interface {p1, v0, v1, p0}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    :cond_6e
    const/4 p0, 0x0

    return-object p0
.end method

.method private static native nativeDumpTrace()V
.end method

.method private static native nativeInit(ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZZIIIZZZZZI[Ljava/lang/String;ZZIIIZZZ)I
.end method

.method static native nativeNotifyAppCrashed()V
.end method

.method private static native nativeNotifyJavaCrashed()V
.end method

.method private static native nativeTestCrash(I)V
.end method

.method private static traceCallback(Ljava/lang/String;Ljava/lang/String;J)V
    .registers 7

    .line 244
    invoke-static {p0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v0

    if-eqz v0, :cond_7

    return-void

    .line 248
    :cond_7
    invoke-static {}, Lxcrash/l;->c()Ljava/lang/String;

    move-result-object v0

    const-string v1, "memory info"

    invoke-static {p0, v1, v0}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z

    .line 251
    invoke-static {}, Lxcrash/a;->a()Lxcrash/a;

    move-result-object v0

    .line 2109
    iget-boolean v0, v0, Lxcrash/a;->b:Z

    if-eqz v0, :cond_1b

    const-string v0, "yes"

    goto :goto_1d

    :cond_1b
    const-string v0, "no"

    :goto_1d
    const-string v1, "foreground"

    .line 251
    invoke-static {p0, v1, v0}, Lxcrash/j;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Z

    const-wide/16 v0, 0x2

    cmp-long v2, p2, v0

    if-eqz v2, :cond_4f

    .line 254
    invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;

    move-result-object v0

    iget-boolean v0, v0, Lxcrash/NativeHandler;->anrCheckProcessState:Z

    if-eqz v0, :cond_4f

    .line 255
    invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;

    move-result-object v0

    iget-object v0, v0, Lxcrash/NativeHandler;->ctx:Landroid/content/Context;

    invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;

    move-result-object v1

    iget-wide v1, v1, Lxcrash/NativeHandler;->anrTimeoutMs:J

    invoke-static {v0, p0, v1, v2}, Lxcrash/l;->a(Landroid/content/Context;Ljava/lang/String;J)Z

    move-result v0

    if-nez v0, :cond_4f

    .line 256
    invoke-static {}, Lxcrash/e;->a()Lxcrash/e;

    move-result-object p1

    new-instance p2, Ljava/io/File;

    invoke-direct {p2, p0}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    invoke-virtual {p1, p2}, Lxcrash/e;->a(Ljava/io/File;)Z

    return-void

    .line 262
    :cond_4f
    invoke-static {}, Lxcrash/e;->a()Lxcrash/e;

    move-result-object v0

    invoke-virtual {v0}, Lxcrash/e;->b()Z

    move-result v0

    if-nez v0, :cond_5a

    return-void

    .line 267
    :cond_5a
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const/4 v1, 0x0

    invoke-virtual {p0}, Ljava/lang/String;->length()I

    move-result v2

    add-int/lit8 v2, v2, -0xd

    invoke-virtual {p0, v1, v2}, Ljava/lang/String;->substring(II)Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v1, ".anr.xcrash"

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 268
    new-instance v1, Ljava/io/File;

    invoke-direct {v1, p0}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    .line 269
    new-instance p0, Ljava/io/File;

    invoke-direct {p0, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    .line 270
    invoke-virtual {v1, p0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z

    move-result p0

    if-nez p0, :cond_8e

    .line 271
    invoke-static {}, Lxcrash/e;->a()Lxcrash/e;

    move-result-object p0

    invoke-virtual {p0, v1}, Lxcrash/e;->a(Ljava/io/File;)Z

    return-void

    :cond_8e
    const-wide/16 v1, 0x1

    cmp-long p0, p2, v1

    if-nez p0, :cond_9b

    .line 276
    invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;

    move-result-object p0

    iget-object p0, p0, Lxcrash/NativeHandler;->anrCallback:Lxcrash/f;

    goto :goto_a1

    .line 277
    :cond_9b
    invoke-static {}, Lxcrash/NativeHandler;->getInstance()Lxcrash/NativeHandler;

    move-result-object p0

    iget-object p0, p0, Lxcrash/NativeHandler;->dumpTraceCallBack:Lxcrash/f;

    :goto_a1
    if-eqz p0, :cond_b3

    .line 281
    :try_start_a3
    invoke-interface {p0, v0, p1}, Lxcrash/f;->a(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_a6
    .catch Ljava/lang/Exception; {:try_start_a3 .. :try_end_a6} :catch_a7

    return-void

    :catch_a7
    move-exception p0

    .line 283
    invoke-static {}, Lxcrash/m;->d()Lxcrash/h;

    move-result-object p1

    const-string p2, "xcrash"

    const-string p3, "NativeHandler ANR callback.onCrash failed"

    invoke-interface {p1, p2, p3, p0}, Lxcrash/h;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    :cond_b3
    return-void
.end method


# virtual methods
.method dumpTrace(Lxcrash/f;)Z
    .registers 3

    .line 166
    iget-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z

    if-eqz v0, :cond_f

    iget-boolean v0, p0, Lxcrash/NativeHandler;->anrEnable:Z

    if-eqz v0, :cond_f

    .line 167
    iput-object p1, p0, Lxcrash/NativeHandler;->dumpTraceCallBack:Lxcrash/f;

    .line 168
    invoke-static {}, Lxcrash/NativeHandler;->nativeDumpTrace()V

    const/4 p1, 0x1

    return p1

    :cond_f
    const/4 p1, 0x0

    return p1
.end method

.method initialize(Landroid/content/Context;Lxcrash/g;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZZIIIZZZZZI[Ljava/lang/String;Lxcrash/f;ZZZIIIZZLxcrash/f;Z)I
    .registers 65

    move-object/from16 v1, p0

    const-string v2, "NativeHandler init failed"

    const-string v3, "xcrash"

    if-nez p2, :cond_19

    .line 91
    :try_start_8
    invoke-static {v3}, Ljava/lang/System;->loadLibrary(Ljava/lang/String;)V
    :try_end_b
    .catchall {:try_start_8 .. :try_end_b} :catchall_c

    goto :goto_19

    :catchall_c
    move-exception v0

    move-object v2, v0

    .line 93
    invoke-static {}, Lxcrash/m;->d()Lxcrash/h;

    move-result-object v0

    const-string v4, "NativeHandler System.loadLibrary failed"

    invoke-interface {v0, v3, v4, v2}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    const/4 v0, -0x2

    return v0

    :cond_19
    :goto_19
    move-object/from16 v0, p1

    .line 105
    iput-object v0, v1, Lxcrash/NativeHandler;->ctx:Landroid/content/Context;

    move/from16 v15, p7

    .line 106
    iput-boolean v15, v1, Lxcrash/NativeHandler;->crashRethrow:Z

    move-object/from16 v4, p18

    .line 107
    iput-object v4, v1, Lxcrash/NativeHandler;->crashCallback:Lxcrash/f;

    move/from16 v14, p19

    .line 108
    iput-boolean v14, v1, Lxcrash/NativeHandler;->anrEnable:Z

    move/from16 v4, p21

    .line 109
    iput-boolean v4, v1, Lxcrash/NativeHandler;->anrCheckProcessState:Z

    move-object/from16 v4, p27

    .line 110
    iput-object v4, v1, Lxcrash/NativeHandler;->anrCallback:Lxcrash/f;

    if-eqz p20, :cond_36

    const-wide/16 v4, 0x3a98

    goto :goto_38

    :cond_36
    const-wide/16 v4, 0x7530

    .line 111
    :goto_38
    iput-wide v4, v1, Lxcrash/NativeHandler;->anrTimeoutMs:J

    const/16 v35, -0x3

    .line 115
    :try_start_3c
    sget v4, Landroid/os/Build$VERSION;->SDK_INT:I

    sget-object v5, Landroid/os/Build$VERSION;->RELEASE:Ljava/lang/String;

    .line 118
    invoke-static {}, Lxcrash/l;->b()Ljava/lang/String;

    move-result-object v6

    sget-object v7, Landroid/os/Build;->MANUFACTURER:Ljava/lang/String;

    sget-object v8, Landroid/os/Build;->BRAND:Ljava/lang/String;

    sget-object v9, Landroid/os/Build;->MODEL:Ljava/lang/String;

    sget-object v10, Landroid/os/Build;->FINGERPRINT:Ljava/lang/String;

    .line 125
    invoke-virtual/range {p1 .. p1}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo;

    move-result-object v0

    iget-object v13, v0, Landroid/content/pm/ApplicationInfo;->nativeLibraryDir:Ljava/lang/String;

    move-object/from16 v11, p3

    move-object/from16 v12, p4

    move-object/from16 v14, p5

    move/from16 v15, p6

    move/from16 v16, p7

    move/from16 v17, p8

    move/from16 v18, p9

    move/from16 v19, p10

    move/from16 v20, p11

    move/from16 v21, p12

    move/from16 v22, p13

    move/from16 v23, p14

    move/from16 v24, p15

    move/from16 v25, p16

    move-object/from16 v26, p17

    move/from16 v27, p19

    move/from16 v28, p20

    move/from16 v29, p22

    move/from16 v30, p23

    move/from16 v31, p24

    move/from16 v32, p25

    move/from16 v33, p26

    move/from16 v34, p28

    .line 115
    invoke-static/range {v4 .. v34}, Lxcrash/NativeHandler;->nativeInit(ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZZIIIZZZZZI[Ljava/lang/String;ZZIIIZZZ)I

    move-result v0

    if-eqz v0, :cond_8e

    .line 148
    invoke-static {}, Lxcrash/m;->d()Lxcrash/h;

    move-result-object v0

    invoke-interface {v0, v3, v2}, Lxcrash/h;->b(Ljava/lang/String;Ljava/lang/String;)V

    return v35

    :cond_8e
    const/4 v0, 0x1

    .line 151
    iput-boolean v0, v1, Lxcrash/NativeHandler;->initNativeLibOk:Z
    :try_end_91
    .catchall {:try_start_3c .. :try_end_91} :catchall_93

    const/4 v0, 0x0

    return v0

    :catchall_93
    move-exception v0

    .line 154
    invoke-static {}, Lxcrash/m;->d()Lxcrash/h;

    move-result-object v4

    invoke-interface {v4, v3, v2, v0}, Lxcrash/h;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return v35
.end method

.method notifyJavaCrashed()V
    .registers 2

    .line 160
    iget-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z

    if-eqz v0, :cond_b

    iget-boolean v0, p0, Lxcrash/NativeHandler;->anrEnable:Z

    if-eqz v0, :cond_b

    .line 161
    invoke-static {}, Lxcrash/NativeHandler;->nativeNotifyJavaCrashed()V

    :cond_b
    return-void
.end method

.method testNativeCrash(Z)V
    .registers 3

    .line 175
    iget-boolean v0, p0, Lxcrash/NativeHandler;->initNativeLibOk:Z

    if-eqz v0, :cond_7

    .line 176
    invoke-static {p1}, Lxcrash/NativeHandler;->nativeTestCrash(I)V

    :cond_7
    return-void
.end method