MHMessageHandler.smali
.class public Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;
.super Ljava/lang/Object;
# interfaces
.implements Lcom/tencent/tinker/loader/hotplug/interceptor/HandlerMessageInterceptor$MessageHandler;
# static fields
.field private static final LAUNCH_ACTIVITY:I
.field private static final TAG:Ljava/lang/String; = "Tinker.MHMsgHndlr"
# instance fields
.field private final mContext:Landroid/content/Context;
# direct methods
.method static constructor <clinit>()V
.registers 3
const/16 v0, 0x64
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v2, 0x1b
if-ge v1, v2, :cond_1b
:try_start_8
const-string/jumbo v1, "android.app.ActivityThread$H"
invoke-static {v1}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
move-result-object v1
const-string/jumbo v2, "LAUNCH_ACTIVITY"
invoke-static {v1, v2}, Lcom/tencent/tinker/loader/shareutil/ShareReflectUtil;->findField(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v1
const/4 v2, 0x0
invoke-virtual {v1, v2}, Ljava/lang/reflect/Field;->getInt(Ljava/lang/Object;)I
:try_end_1a
.catch Ljava/lang/Throwable; {:try_start_8 .. :try_end_1a} :catch_1e
move-result v0
:cond_1b
:goto_1b
sput v0, Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;->LAUNCH_ACTIVITY:I
return-void
:catch_1e
move-exception v1
goto :goto_1b
.end method
.method public constructor <init>(Landroid/content/Context;)V
.registers 4
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
move-object v1, p1
:goto_4
instance-of v0, v1, Landroid/content/ContextWrapper;
if-eqz v0, :cond_11
move-object v0, v1
check-cast v0, Landroid/content/ContextWrapper;
invoke-virtual {v0}, Landroid/content/ContextWrapper;->getBaseContext()Landroid/content/Context;
move-result-object p1
if-nez p1, :cond_14
:cond_11
iput-object v1, p0, Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;->mContext:Landroid/content/Context;
return-void
:cond_14
move-object v1, p1
goto :goto_4
.end method
.method private copyInstanceFields(Ljava/lang/Object;Ljava/lang/Object;)V
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(TT;TT;)V"
}
.end annotation
if-eqz p1, :cond_4
if-nez p2, :cond_5
:cond_4
return-void
:cond_5
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
:goto_9
const-class v1, Ljava/lang/Object;
invoke-virtual {v0, v1}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_4
invoke-virtual {v0}, Ljava/lang/Class;->getDeclaredFields()[Ljava/lang/reflect/Field;
move-result-object v2
array-length v3, v2
const/4 v1, 0x0
:goto_17
if-ge v1, v3, :cond_42
aget-object v4, v2, v1
invoke-virtual {v4}, Ljava/lang/reflect/Field;->isSynthetic()Z
move-result v5
if-eqz v5, :cond_24
:cond_21
:goto_21
add-int/lit8 v1, v1, 0x1
goto :goto_17
:cond_24
invoke-virtual {v4}, Ljava/lang/reflect/Field;->getModifiers()I
move-result v5
invoke-static {v5}, Ljava/lang/reflect/Modifier;->isStatic(I)Z
move-result v5
if-nez v5, :cond_21
invoke-virtual {v4}, Ljava/lang/reflect/Field;->isAccessible()Z
move-result v5
if-nez v5, :cond_38
const/4 v5, 0x1
invoke-virtual {v4, v5}, Ljava/lang/reflect/Field;->setAccessible(Z)V
:cond_38
:try_start_38
invoke-virtual {v4, p1}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v5
invoke-virtual {v4, p2, v5}, Ljava/lang/reflect/Field;->set(Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_3f
.catch Ljava/lang/Throwable; {:try_start_38 .. :try_end_3f} :catch_40
goto :goto_21
:catch_40
move-exception v4
goto :goto_21
:cond_42
invoke-virtual {v0}, Ljava/lang/Class;->getSuperclass()Ljava/lang/Class;
move-result-object v0
goto :goto_9
.end method
.method private fixActivityScreenOrientation(Ljava/lang/Object;I)V
.registers 9
const/4 v0, 0x2
const/4 v1, -0x1
if-ne p2, v1, :cond_5
move p2, v0
:cond_5
:try_start_5
const-string/jumbo v0, "token"
invoke-static {p1, v0}, Lcom/tencent/tinker/loader/shareutil/ShareReflectUtil;->findField(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v0
invoke-virtual {v0, p1}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
const-string/jumbo v1, "android.app.ActivityManagerNative"
invoke-static {v1}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
move-result-object v1
const-string/jumbo v2, "getDefault"
const/4 v3, 0x0
new-array v3, v3, [Ljava/lang/Class;
invoke-static {v1, v2, v3}, Lcom/tencent/tinker/loader/shareutil/ShareReflectUtil;->findMethod(Ljava/lang/Class;Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v1
const/4 v2, 0x0
const/4 v3, 0x0
new-array v3, v3, [Ljava/lang/Object;
invoke-virtual {v1, v2, v3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
const-string/jumbo v2, "setRequestedOrientation"
const/4 v3, 0x2
new-array v3, v3, [Ljava/lang/Class;
const/4 v4, 0x0
const-class v5, Landroid/os/IBinder;
aput-object v5, v3, v4
const/4 v4, 0x1
sget-object v5, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
aput-object v5, v3, v4
invoke-static {v1, v2, v3}, Lcom/tencent/tinker/loader/shareutil/ShareReflectUtil;->findMethod(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v2
const/4 v3, 0x2
new-array v3, v3, [Ljava/lang/Object;
const/4 v4, 0x0
aput-object v0, v3, v4
const/4 v0, 0x1
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
aput-object v4, v3, v0
invoke-virtual {v2, v1, v3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
:try_end_4d
.catch Ljava/lang/Throwable; {:try_start_5 .. :try_end_4d} :catch_4e
:goto_4d
return-void
:catch_4e
move-exception v0
const-string/jumbo v1, "Tinker.MHMsgHndlr"
const-string/jumbo v2, "Failed to fix screen orientation."
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_4d
.end method
.method private fixStubActivityInfo(Landroid/content/pm/ActivityInfo;Landroid/content/pm/ActivityInfo;)V
.registers 3
invoke-direct {p0, p2, p1}, Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;->copyInstanceFields(Ljava/lang/Object;Ljava/lang/Object;)V
return-void
.end method
# virtual methods
.method public handleMessage(Landroid/os/Message;)Z
.registers 9
const/4 v6, 0x0
iget v0, p1, Landroid/os/Message;->what:I
sget v1, Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;->LAUNCH_ACTIVITY:I
if-ne v0, v1, :cond_2e
:try_start_7
iget-object v3, p1, Landroid/os/Message;->obj:Ljava/lang/Object;
if-nez v3, :cond_2f
const-string/jumbo v0, "Tinker.MHMsgHndlr"
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v2, "msg: ["
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
iget v2, p1, Landroid/os/Message;->what:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v2, "] has no \'obj\' value."
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:cond_2e
:goto_2e
return v6
:cond_2f
const-string/jumbo v0, "intent"
invoke-static {v3, v0}, Lcom/tencent/tinker/loader/shareutil/ShareReflectUtil;->findField(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v0
invoke-virtual {v0, v3}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/content/Intent;
if-nez v0, :cond_53
const-string/jumbo v0, "Tinker.MHMsgHndlr"
const-string/jumbo v1, "cannot fetch intent from message received by mH."
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_47
.catch Ljava/lang/Throwable; {:try_start_7 .. :try_end_47} :catch_48
goto :goto_2e
:catch_48
move-exception v0
const-string/jumbo v1, "Tinker.MHMsgHndlr"
const-string/jumbo v2, "exception in handleMessage."
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_2e
:cond_53
:try_start_53
iget-object v1, p0, Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;->mContext:Landroid/content/Context;
invoke-virtual {v1}, Landroid/content/Context;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v1
invoke-static {v0, v1}, Lcom/tencent/tinker/loader/shareutil/ShareIntentUtil;->fixIntentClassLoader(Landroid/content/Intent;Ljava/lang/ClassLoader;)V
const-string/jumbo v1, "tinker_iek_old_component"
invoke-virtual {v0, v1}, Landroid/content/Intent;->getParcelableExtra(Ljava/lang/String;)Landroid/os/Parcelable;
move-result-object v1
check-cast v1, Landroid/content/ComponentName;
if-nez v1, :cond_8d
const-string/jumbo v1, "Tinker.MHMsgHndlr"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v3, "oldComponent was null, start "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v0}, Landroid/content/Intent;->getComponent()Landroid/content/ComponentName;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v2, " next."
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
invoke-static {v1, v0}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_2e
:cond_8d
const-string/jumbo v2, "activityInfo"
invoke-static {v3, v2}, Lcom/tencent/tinker/loader/shareutil/ShareReflectUtil;->findField(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v2
invoke-virtual {v2, v3}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Landroid/content/pm/ActivityInfo;
if-eqz v2, :cond_2e
invoke-virtual {v1}, Landroid/content/ComponentName;->getClassName()Ljava/lang/String;
move-result-object v4
invoke-static {v4}, Lcom/tencent/tinker/loader/hotplug/IncrementComponentManager;->queryActivityInfo(Ljava/lang/String;)Landroid/content/pm/ActivityInfo;
move-result-object v4
if-nez v4, :cond_c6
const-string/jumbo v0, "Tinker.MHMsgHndlr"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v3, "Failed to query target activity\'s info, perhaps the target is not hotpluged component. Target: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v1}, Landroid/content/ComponentName;->getClassName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
goto/16 :goto_2e
:cond_c6
iget v5, v4, Landroid/content/pm/ActivityInfo;->screenOrientation:I
invoke-direct {p0, v3, v5}, Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;->fixActivityScreenOrientation(Ljava/lang/Object;I)V
invoke-direct {p0, v2, v4}, Lcom/tencent/tinker/loader/hotplug/handler/MHMessageHandler;->fixStubActivityInfo(Landroid/content/pm/ActivityInfo;Landroid/content/pm/ActivityInfo;)V
invoke-virtual {v0, v1}, Landroid/content/Intent;->setComponent(Landroid/content/ComponentName;)Landroid/content/Intent;
const-string/jumbo v1, "tinker_iek_old_component"
invoke-virtual {v0, v1}, Landroid/content/Intent;->removeExtra(Ljava/lang/String;)V
:try_end_d7
.catch Ljava/lang/Throwable; {:try_start_53 .. :try_end_d7} :catch_48
goto/16 :goto_2e
.end method