ThrowableCustomHandler.smali
.class public Lorg/acdd/android/compat/ThrowableCustomHandler;
.super Ljava/lang/Object;
.source "ThrowableCustomHandler.java"
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 18
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private static getActivityName(Landroid/os/Message;)Ljava/lang/String;
.registers 4
.prologue
.line 68
const-string v1, ""
.line 70
:try_start_2
iget-object v0, p0, Landroid/os/Message;->obj:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
const-string v2, "activityInfo"
invoke-virtual {v0, v2}, Ljava/lang/Class;->getDeclaredField(Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v0
.line 71
const/4 v2, 0x1
invoke-virtual {v0, v2}, Ljava/lang/reflect/Field;->setAccessible(Z)V
.line 72
iget-object v2, p0, Landroid/os/Message;->obj:Ljava/lang/Object;
invoke-virtual {v0, v2}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/content/pm/ActivityInfo;
.line 73
if-eqz v0, :cond_22
.line 74
iget-object v0, v0, Landroid/content/pm/ActivityInfo;->name:Ljava/lang/String;
:try_end_1e
.catch Ljava/lang/Throwable; {:try_start_2 .. :try_end_1e} :catch_1f
.line 78
:goto_1e
return-object v0
.line 76
:catch_1f
move-exception v0
move-object v0, v1
goto :goto_1e
:cond_22
move-object v0, v1
goto :goto_1e
.end method
.method private static handleActivityDestroyException(Ljava/lang/Throwable;Landroid/os/Message;)Z
.registers 5
.prologue
const/4 v0, 0x0
.line 143
iget v1, p1, Landroid/os/Message;->what:I
sget v2, Lorg/acdd/hack/AndroidHack;->DESTROY_ACTIVITY:I
if-ne v1, v2, :cond_20
if-eqz p0, :cond_20
.line 145
invoke-virtual {p0}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
move-result-object v1
.line 146
if-eqz v1, :cond_20
.line 147
const-string v2, "but the ViewAncestor is attached to"
invoke-virtual {v1, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_1f
const-string v2, "not attached to window manager"
.line 148
invoke-virtual {v1, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v1
if-eqz v1, :cond_20
:cond_1f
const/4 v0, 0x1
.line 151
:cond_20
return v0
.end method
.method private static handleActivityIsRunningException(Ljava/lang/Throwable;Landroid/os/Message;)Z
.registers 8
.prologue
.line 113
iget v0, p1, Landroid/os/Message;->what:I
sget v1, Lorg/acdd/hack/AndroidHack;->LAUNCH_ACTIVITY:I
if-ne v0, v1, :cond_3c
if-eqz p0, :cond_3c
.line 115
invoke-virtual {p0}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "is your activity running"
invoke-virtual {v0, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_3c
.line 117
:try_start_14
invoke-static {p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->getActivityName(Landroid/os/Message;)Ljava/lang/String;
move-result-object v0
.line 118
invoke-static {}, Lorg/acdd/framework/ACDD;->getInstance()Lorg/acdd/framework/ACDD;
move-result-object v1
const-string v2, "4013"
new-instance v3, Ljava/lang/RuntimeException;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "activity name:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, 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-direct {v3, v0, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
invoke-virtual {v1, v2, v3}, Lorg/acdd/framework/ACDD;->reportCrash(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_39
.catch Ljava/lang/Throwable; {:try_start_14 .. :try_end_39} :catch_3b
.line 120
const/4 v0, 0x1
.line 124
:goto_3a
return v0
.line 121
:catch_3b
move-exception v0
.line 124
:cond_3c
const/4 v0, 0x0
goto :goto_3a
.end method
.method private static handleActivityLaunchException(Ljava/lang/Throwable;Landroid/os/Message;)Z
.registers 8
.prologue
.line 82
if-eqz p1, :cond_30
iget v0, p1, Landroid/os/Message;->what:I
sget v1, Lorg/acdd/hack/AndroidHack;->LAUNCH_ACTIVITY:I
if-ne v0, v1, :cond_30
.line 85
:try_start_8
invoke-static {p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->getActivityName(Landroid/os/Message;)Ljava/lang/String;
move-result-object v0
.line 86
invoke-static {}, Lorg/acdd/framework/ACDD;->getInstance()Lorg/acdd/framework/ACDD;
move-result-object v1
const-string v2, "4033"
new-instance v3, Ljava/lang/RuntimeException;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "activity name:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, 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-direct {v3, v0, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
invoke-virtual {v1, v2, v3}, Lorg/acdd/framework/ACDD;->reportCrash(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_2d
.catch Ljava/lang/Throwable; {:try_start_8 .. :try_end_2d} :catch_2f
.line 88
const/4 v0, 0x1
.line 92
:goto_2e
return v0
.line 89
:catch_2f
move-exception v0
.line 92
:cond_30
const/4 v0, 0x0
goto :goto_2e
.end method
.method private static handleActivityReadParcelException(Ljava/lang/Throwable;Landroid/os/Message;)Z
.registers 8
.prologue
.line 128
iget v0, p1, Landroid/os/Message;->what:I
sget v1, Lorg/acdd/hack/AndroidHack;->LAUNCH_ACTIVITY:I
if-ne v0, v1, :cond_3c
if-eqz p0, :cond_3c
.line 130
invoke-virtual {p0}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "Could not read input channel file descriptors from parcel"
invoke-virtual {v0, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_3c
.line 132
:try_start_14
invoke-static {p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->getActivityName(Landroid/os/Message;)Ljava/lang/String;
move-result-object v0
.line 133
invoke-static {}, Lorg/acdd/framework/ACDD;->getInstance()Lorg/acdd/framework/ACDD;
move-result-object v1
const-string v2, "4013"
new-instance v3, Ljava/lang/RuntimeException;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "activity name:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, 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-direct {v3, v0, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
invoke-virtual {v1, v2, v3}, Lorg/acdd/framework/ACDD;->reportCrash(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_39
.catch Ljava/lang/Throwable; {:try_start_14 .. :try_end_39} :catch_3b
.line 135
const/4 v0, 0x1
.line 139
:goto_3a
return v0
.line 136
:catch_3b
move-exception v0
.line 139
:cond_3c
const/4 v0, 0x0
goto :goto_3a
.end method
.method private static handleBadNotification(Ljava/lang/Throwable;)Z
.registers 3
.prologue
.line 172
if-eqz p0, :cond_1a
.line 173
invoke-virtual {p0}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "Bad notification posted"
invoke-virtual {v0, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_1a
.line 175
:try_start_e
invoke-static {}, Lorg/acdd/framework/ACDD;->getInstance()Lorg/acdd/framework/ACDD;
move-result-object v0
const-string v1, "4013"
invoke-virtual {v0, v1, p0}, Lorg/acdd/framework/ACDD;->reportCrash(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_17
.catch Ljava/lang/Throwable; {:try_start_e .. :try_end_17} :catch_19
.line 176
const/4 v0, 0x1
.line 180
:goto_18
return v0
.line 177
:catch_19
move-exception v0
.line 180
:cond_1a
const/4 v0, 0x0
goto :goto_18
.end method
.method private static handleEnterAnimationComplete(Ljava/lang/Throwable;Landroid/os/Message;Ljava/lang/Object;)Z
.registers 9
.prologue
const/4 v2, 0x0
.line 96
if-eqz p1, :cond_55
iget v0, p1, Landroid/os/Message;->what:I
sget v1, Lorg/acdd/hack/AndroidHack;->ENTER_ANIMATION_COMPLETE:I
if-ne v0, v1, :cond_55
if-eqz p2, :cond_55
.line 99
const-string v1, ""
.line 101
:try_start_d
invoke-virtual {p2}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
const-string v2, "getActivity"
const/4 v3, 0x1
new-array v3, v3, [Ljava/lang/Class;
const/4 v4, 0x0
const-class v5, Landroid/os/IBinder;
aput-object v5, v3, v4
invoke-virtual {v0, v2, v3}, Ljava/lang/Class;->getDeclaredMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v0
.line 102
const/4 v2, 0x1
invoke-virtual {v0, v2}, Ljava/lang/reflect/Method;->setAccessible(Z)V
.line 103
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
iget-object v4, p1, Landroid/os/Message;->obj:Ljava/lang/Object;
aput-object v4, v2, v3
invoke-virtual {v0, p2, v2}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/app/Activity;
.line 104
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
:try_end_38
.catch Ljava/lang/Throwable; {:try_start_d .. :try_end_38} :catch_52
move-result-object v0
.line 107
:goto_39
new-instance v1, Ljava/lang/RuntimeException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "activity Name: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, 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-direct {v1, v0, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.line 105
:catch_52
move-exception v0
move-object v0, v1
goto :goto_39
.line 109
:cond_55
return v2
.end method
.method private static handleIDefendServiceException(Ljava/lang/Throwable;)Z
.registers 7
.prologue
const/4 v0, 0x0
.line 155
if-eqz p0, :cond_25
instance-of v1, p0, Ljava/lang/NullPointerException;
if-eqz v1, :cond_25
.line 156
invoke-virtual {p0}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v2
.line 157
if-eqz v2, :cond_25
.line 158
array-length v3, v2
move v1, v0
:goto_f
if-ge v1, v3, :cond_25
aget-object v4, v2, v1
.line 159
if-nez v4, :cond_18
.line 158
:cond_15
add-int/lit8 v1, v1, 0x1
goto :goto_f
.line 162
:cond_18
invoke-virtual {v4}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v4
const-string v5, "IDefendService"
invoke-virtual {v4, v5}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v4
if-eqz v4, :cond_15
.line 163
const/4 v0, 0x1
.line 168
:cond_25
return v0
.end method
.method private static handleNullPointerException(Ljava/lang/Throwable;Landroid/os/Message;)Z
.registers 8
.prologue
.line 55
if-eqz p0, :cond_2e
instance-of v0, p0, Ljava/lang/NullPointerException;
if-eqz v0, :cond_2e
.line 57
:try_start_6
invoke-static {p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->getActivityName(Landroid/os/Message;)Ljava/lang/String;
move-result-object v0
.line 58
invoke-static {}, Lorg/acdd/framework/ACDD;->getInstance()Lorg/acdd/framework/ACDD;
move-result-object v1
const-string v2, "4035"
new-instance v3, Ljava/lang/RuntimeException;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "activity name:"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, 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-direct {v3, v0, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
invoke-virtual {v1, v2, v3}, Lorg/acdd/framework/ACDD;->reportCrash(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_2b
.catch Ljava/lang/Throwable; {:try_start_6 .. :try_end_2b} :catch_2d
.line 60
const/4 v0, 0x1
.line 64
:goto_2c
return v0
.line 61
:catch_2d
move-exception v0
.line 64
:cond_2e
const/4 v0, 0x0
goto :goto_2c
.end method
.method public static onHandleMessageException(Ljava/lang/Throwable;Landroid/os/Message;Ljava/lang/Object;)Z
.registers 6
.prologue
const/4 v0, 0x1
.line 20
sget-boolean v1, Lorg/acdd/android/compat/AppBuildConfig;->DEBUG:Z
if-eqz v1, :cond_7
.line 21
const/4 v0, 0x0
.line 51
:cond_6
:goto_6
return v0
.line 24
:cond_7
invoke-static {p0, p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleActivityIsRunningException(Ljava/lang/Throwable;Landroid/os/Message;)Z
move-result v1
if-nez v1, :cond_6
.line 27
invoke-static {p0, p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleActivityReadParcelException(Ljava/lang/Throwable;Landroid/os/Message;)Z
move-result v1
if-nez v1, :cond_6
.line 30
invoke-static {p0, p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleActivityLaunchException(Ljava/lang/Throwable;Landroid/os/Message;)Z
move-result v1
if-nez v1, :cond_6
.line 33
invoke-static {p0}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleIDefendServiceException(Ljava/lang/Throwable;)Z
move-result v1
if-nez v1, :cond_6
.line 36
invoke-static {p0, p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleActivityDestroyException(Ljava/lang/Throwable;Landroid/os/Message;)Z
move-result v1
if-nez v1, :cond_6
.line 39
invoke-static {p0, p1}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleNullPointerException(Ljava/lang/Throwable;Landroid/os/Message;)Z
move-result v1
if-nez v1, :cond_6
.line 42
invoke-static {p0, p1, p2}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleEnterAnimationComplete(Ljava/lang/Throwable;Landroid/os/Message;Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_6
.line 45
if-eqz p0, :cond_43
instance-of v1, p0, Ljava/lang/SecurityException;
if-eqz v1, :cond_43
.line 47
invoke-virtual {p0}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
move-result-object v1
const-string v2, "cannot kill pkg"
invoke-virtual {v1, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v1
if-nez v1, :cond_6
.line 51
:cond_43
invoke-static {p0}, Lorg/acdd/android/compat/ThrowableCustomHandler;->handleBadNotification(Ljava/lang/Throwable;)Z
move-result v0
goto :goto_6
.end method