DexDiffPatchInternal.smali
.class public Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;
.super Lcom/tencent/tinker/lib/patch/BasePatchInternal;
# static fields
.field protected static final MAX_WAIT_COUNT:I = 0x78
.field protected static final TAG:Ljava/lang/String; = "Tinker.DexDiffPatchInternal"
.field protected static final WAIT_ASYN_OAT_TIME:I = 0x2710
.field private static classNDexInfo:Ljava/util/HashMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/HashMap",
"<",
"Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;",
"Ljava/io/File;",
">;"
}
.end annotation
.end field
.field private static isVmArt:Z
.field private static optFiles:Ljava/util/ArrayList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayList",
"<",
"Ljava/io/File;",
">;"
}
.end annotation
.end field
.field private static patchList:Ljava/util/ArrayList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayList",
"<",
"Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;",
">;"
}
.end annotation
.end field
# direct methods
.method static constructor <clinit>()V
.registers 1
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
sput-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
sput-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
sput-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-static {}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->isVmArt()Z
move-result v0
sput-boolean v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->isVmArt:Z
return-void
.end method
.method public constructor <init>()V
.registers 1
invoke-direct {p0}, Lcom/tencent/tinker/lib/patch/BasePatchInternal;-><init>()V
return-void
.end method
.method private static checkAllDexOptFile(Ljava/util/ArrayList;I)Z
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/ArrayList",
"<",
"Ljava/io/File;",
">;I)Z"
}
.end annotation
const/4 v2, 0x1
const/4 v1, 0x0
invoke-virtual {p0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v3
:cond_6
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_38
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/io/File;
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->isLegalFile(Ljava/io/File;)Z
move-result v4
if-nez v4, :cond_6
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->shouldAcceptEvenIfIllegal(Ljava/io/File;)Z
move-result v4
if-nez v4, :cond_6
const-string/jumbo v3, "Tinker.DexDiffPatchInternal"
const-string/jumbo v4, "parallel dex optimizer file %s is not exist, just wait %d times"
const/4 v5, 0x2
new-array v5, v5, [Ljava/lang/Object;
invoke-virtual {v0}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v0
aput-object v0, v5, v1
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
aput-object v0, v5, v2
invoke-static {v3, v4, v5}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
move v0, v1
:goto_37
return v0
:cond_38
move v0, v2
goto :goto_37
.end method
.method private static checkClassNDexFiles(Ljava/lang/String;)Z
.registers 12
const/4 v2, 0x0
const/4 v5, 0x1
const/4 v4, 0x0
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->isEmpty()Z
move-result v0
if-nez v0, :cond_f
sget-boolean v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->isVmArt:Z
if-nez v0, :cond_11
:cond_f
move v0, v4
:goto_10
return v0
:cond_11
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v6
move-object v3, v2
:goto_18
invoke-interface {v6}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_62
invoke-interface {v6}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;
new-instance v1, Ljava/io/File;
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v7, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
iget-object v8, v0, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->realName:Ljava/lang/String;
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-direct {v1, v7}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v7
sget-object v8, Lcom/tencent/tinker/loader/shareutil/ShareConstants;->CLASS_N_PATTERN:Ljava/util/regex/Pattern;
invoke-virtual {v8, v7}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
move-result-object v7
invoke-virtual {v7}, Ljava/util/regex/Matcher;->matches()Z
move-result v7
if-eqz v7, :cond_51
sget-object v7, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v7, v0, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_51
iget-object v7, v0, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
const-string/jumbo v8, "test.dex"
invoke-virtual {v7, v8}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v7
if-eqz v7, :cond_e6
move-object v10, v1
move-object v1, v0
move-object v0, v10
:goto_5f
move-object v2, v0
move-object v3, v1
goto :goto_18
:cond_62
if-eqz v3, :cond_75
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
sget-object v1, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v1}, Ljava/util/HashMap;->size()I
move-result v1
add-int/lit8 v1, v1, 0x1
invoke-static {v3, v1}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->changeTestDexToClassN(Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;I)Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;
move-result-object v1
invoke-virtual {v0, v1, v2}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_75
new-instance v2, Ljava/io/File;
const-string/jumbo v0, "tinker_classN.apk"
invoke-direct {v2, p0, v0}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_df
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v0}, Ljava/util/HashMap;->keySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v1
:cond_8d
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_e4
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;
iget-object v3, v0, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
iget-object v6, v0, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->destMd5InArt:Ljava/lang/String;
invoke-static {v2, v3, v6}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->verifyDexFileMd5(Ljava/io/File;Ljava/lang/String;Ljava/lang/String;)Z
move-result v3
if-nez v3, :cond_8d
const-string/jumbo v1, "Tinker.DexDiffPatchInternal"
const-string/jumbo v3, "verify dex file md5 error, entry name; %s, file len: %d"
const/4 v6, 0x2
new-array v6, v6, [Ljava/lang/Object;
iget-object v0, v0, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
aput-object v0, v6, v4
invoke-virtual {v2}, Ljava/io/File;->length()J
move-result-wide v8
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
aput-object v0, v6, v5
invoke-static {v1, v3, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
move v1, v4
:goto_be
if-nez v1, :cond_c3
invoke-static {v2}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->safeDeleteFile(Ljava/io/File;)Z
:cond_c3
:goto_c3
if-eqz v1, :cond_e1
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v0}, Ljava/util/HashMap;->values()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_cf
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_e1
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/io/File;
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->safeDeleteFile(Ljava/io/File;)Z
goto :goto_cf
:cond_df
move v1, v4
goto :goto_c3
:cond_e1
move v0, v1
goto/16 :goto_10
:cond_e4
move v1, v5
goto :goto_be
:cond_e6
move-object v0, v2
move-object v1, v3
goto/16 :goto_5f
.end method
.method private static dexOptimizeDexFiles(Landroid/content/Context;Ljava/util/List;Ljava/lang/String;Ljava/io/File;)Z
.registers 12
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/content/Context;",
"Ljava/util/List",
"<",
"Ljava/io/File;",
">;",
"Ljava/lang/String;",
"Ljava/io/File;",
")Z"
}
.end annotation
const/4 v2, 0x1
const/4 v1, 0x0
invoke-static {p0}, Lcom/tencent/tinker/lib/tinker/Tinker;->with(Landroid/content/Context;)Lcom/tencent/tinker/lib/tinker/Tinker;
move-result-object v3
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->clear()V
if-eqz p1, :cond_82
new-instance v4, Ljava/io/File;
invoke-direct {v4, p2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v4}, Ljava/io/File;->exists()Z
move-result v0
if-nez v0, :cond_2b
invoke-virtual {v4}, Ljava/io/File;->mkdirs()Z
move-result v0
if-nez v0, :cond_2b
const-string/jumbo v0, "Tinker.DexDiffPatchInternal"
const-string/jumbo v2, "patch recover, make optimizeDexDirectoryFile fail"
new-array v3, v1, [Ljava/lang/Object;
invoke-static {v0, v2, v3}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
move v0, v1
:goto_2a
return v0
:cond_2b
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v5
:goto_2f
invoke-interface {v5}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_4a
invoke-interface {v5}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/io/File;
invoke-static {v0, v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->optimizedPathFor(Ljava/io/File;Ljava/io/File;)Ljava/lang/String;
move-result-object v0
sget-object v6, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
new-instance v7, Ljava/io/File;
invoke-direct {v7, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v6, v7}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_2f
:cond_4a
const-string/jumbo v0, "Tinker.DexDiffPatchInternal"
const-string/jumbo v5, "patch recover, try to optimize dex file count:%d, optimizeDexDirectory:%s"
const/4 v6, 0x2
new-array v6, v6, [Ljava/lang/Object;
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v7
invoke-static {v7}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v6, v1
aput-object p2, v6, v2
invoke-static {v0, v5, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
new-instance v0, Ljava/util/Vector;
invoke-direct {v0}, Ljava/util/Vector;-><init>()V
new-array v5, v2, [Ljava/lang/Throwable;
new-instance v6, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal$1;
invoke-direct {v6, v0, v5}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal$1;-><init>(Ljava/util/List;[Ljava/lang/Throwable;)V
invoke-static {p1, v4, v6}, Lcom/tencent/tinker/loader/TinkerDexOptimizer;->optimizeAll(Ljava/util/Collection;Ljava/io/File;Lcom/tencent/tinker/loader/TinkerDexOptimizer$ResultCallback;)Z
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v4
if-nez v4, :cond_82
invoke-virtual {v3}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v2
aget-object v3, v5, v1
invoke-interface {v2, p3, v0, v3}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchDexOptFail(Ljava/io/File;Ljava/util/List;Ljava/lang/Throwable;)V
move v0, v1
goto :goto_2a
:cond_82
move v0, v2
goto :goto_2a
.end method
.method private static extractDexDiffInternals(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/io/File;I)Z
.registers 26
sget-object v4, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v4}, Ljava/util/ArrayList;->clear()V
sget-object v4, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
move-object/from16 v0, p2
invoke-static {v0, v4}, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->parseDexDiffPatchInfo(Ljava/lang/String;Ljava/util/ArrayList;)V
sget-object v4, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v4}, Ljava/util/ArrayList;->isEmpty()Z
move-result v4
if-eqz v4, :cond_29
const-string/jumbo v4, "Tinker.DexDiffPatchInternal"
const-string/jumbo v5, "extract patch list is empty! type:%s:"
const/4 v6, 0x1
new-array v6, v6, [Ljava/lang/Object;
const/4 v7, 0x0
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->getTypeString(I)Ljava/lang/String;
move-result-object v8
aput-object v8, v6, v7
invoke-static {v4, v5, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v4, 0x1
:goto_28
return v4
:cond_29
new-instance v4, Ljava/io/File;
move-object/from16 v0, p1
invoke-direct {v4, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v4}, Ljava/io/File;->exists()Z
move-result v5
if-nez v5, :cond_39
invoke-virtual {v4}, Ljava/io/File;->mkdirs()Z
:cond_39
invoke-static/range {p0 .. p0}, Lcom/tencent/tinker/lib/tinker/Tinker;->with(Landroid/content/Context;)Lcom/tencent/tinker/lib/tinker/Tinker;
move-result-object v12
const/4 v5, 0x0
const/4 v6, 0x0
:try_start_3f
invoke-virtual/range {p0 .. p0}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo;
move-result-object v4
if-nez v4, :cond_59
const-string/jumbo v4, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "applicationInfo == null!!!!"
const/4 v8, 0x0
new-array v8, v8, [Ljava/lang/Object;
invoke-static {v4, v7, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_51
.catch Ljava/lang/Throwable; {:try_start_3f .. :try_end_51} :catch_4bb
.catchall {:try_start_3f .. :try_end_51} :catchall_4aa
const/4 v4, 0x0
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v6}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
goto :goto_28
:cond_59
:try_start_59
iget-object v7, v4, Landroid/content/pm/ApplicationInfo;->sourceDir:Ljava/lang/String;
new-instance v4, Ljava/util/zip/ZipFile;
invoke-direct {v4, v7}, Ljava/util/zip/ZipFile;-><init>(Ljava/lang/String;)V
:try_end_60
.catch Ljava/lang/Throwable; {:try_start_59 .. :try_end_60} :catch_4bb
.catchall {:try_start_59 .. :try_end_60} :catchall_4aa
:try_start_60
new-instance v5, Ljava/util/zip/ZipFile;
move-object/from16 v0, p3
invoke-direct {v5, v0}, Ljava/util/zip/ZipFile;-><init>(Ljava/io/File;)V
:try_end_67
.catch Ljava/lang/Throwable; {:try_start_60 .. :try_end_67} :catch_4c3
.catchall {:try_start_60 .. :try_end_67} :catchall_4b2
:try_start_67
invoke-static/range {p1 .. p1}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->checkClassNDexFiles(Ljava/lang/String;)Z
move-result v6
if-eqz v6, :cond_88
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "class n dex file %s is already exist, and md5 match, just continue"
const/4 v8, 0x1
new-array v8, v8, [Ljava/lang/Object;
const/4 v9, 0x0
const-string/jumbo v10, "tinker_classN.apk"
aput-object v10, v8, v9
invoke-static {v6, v7, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_7f
.catch Ljava/lang/Throwable; {:try_start_67 .. :try_end_7f} :catch_d3
.catchall {:try_start_67 .. :try_end_7f} :catchall_1b2
const/4 v6, 0x1
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto :goto_28
:cond_88
:try_start_88
sget-object v6, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v6}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v13
:cond_8e
:goto_8e
invoke-interface {v13}, Ljava/util/Iterator;->hasNext()Z
move-result v6
if-eqz v6, :cond_48b
invoke-interface {v13}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v8
check-cast v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v14
iget-object v6, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->path:Ljava/lang/String;
const-string/jumbo v7, ""
invoke-virtual {v6, v7}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v6
if-eqz v6, :cond_115
iget-object v6, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object v11, v6
:goto_ac
iget-object v0, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->dexDiffMd5:Ljava/lang/String;
move-object/from16 v16, v0
iget-object v0, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->oldDexCrC:Ljava/lang/String;
move-object/from16 v17, v0
sget-boolean v6, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->isVmArt:Z
if-nez v6, :cond_134
iget-object v6, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->destMd5InDvm:Ljava/lang/String;
const-string/jumbo v7, "0"
invoke-virtual {v6, v7}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v6
if-eqz v6, :cond_134
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "patch dex %s is only for art, just continue"
const/4 v8, 0x1
new-array v8, v8, [Ljava/lang/Object;
const/4 v9, 0x0
aput-object v11, v8, v9
invoke-static {v6, v7, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_d2
.catch Ljava/lang/Throwable; {:try_start_88 .. :try_end_d2} :catch_d3
.catchall {:try_start_88 .. :try_end_d2} :catchall_1b2
goto :goto_8e
:catch_d3
move-exception v6
move-object/from16 v20, v6
move-object v6, v4
move-object/from16 v4, v20
:goto_d9
:try_start_d9
new-instance v7, Lcom/tencent/tinker/loader/TinkerRuntimeException;
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v9, "patch "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->getTypeString(I)Ljava/lang/String;
move-result-object v9
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
const-string/jumbo v9, " extract failed ("
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-virtual {v4}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v9
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
const-string/jumbo v9, ")."
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-direct {v7, v8, v4}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v7
:try_end_10d
.catchall {:try_start_d9 .. :try_end_10d} :catchall_10d
:catchall_10d
move-exception v4
:goto_10e
invoke-static {v6}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
throw v4
:cond_115
:try_start_115
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->path:Ljava/lang/String;
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string/jumbo v7, "/"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
move-object v11, v6
goto/16 :goto_ac
:cond_134
sget-boolean v6, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->isVmArt:Z
if-eqz v6, :cond_173
iget-object v6, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->destMd5InArt:Ljava/lang/String;
move-object v10, v6
:goto_13b
invoke-static {v10}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->checkIfMd5Valid(Ljava/lang/String;)Z
move-result v6
if-nez v6, :cond_177
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "meta file md5 invalid, type:%s, name: %s, md5: %s"
const/4 v9, 0x3
new-array v9, v9, [Ljava/lang/Object;
const/4 v11, 0x0
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->getTypeString(I)Ljava/lang/String;
move-result-object v13
aput-object v13, v9, v11
const/4 v11, 0x1
iget-object v8, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
aput-object v8, v9, v11
const/4 v8, 0x2
aput-object v10, v9, v8
invoke-static {v6, v7, v9}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/lib/patch/BasePatchInternal;->getMetaCorruptedCode(I)I
move-result v7
move-object/from16 v0, p3
invoke-interface {v6, v0, v7}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchPackageCheckFail(Ljava/io/File;I)V
:try_end_169
.catch Ljava/lang/Throwable; {:try_start_115 .. :try_end_169} :catch_d3
.catchall {:try_start_115 .. :try_end_169} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_173
:try_start_173
iget-object v6, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->destMd5InDvm:Ljava/lang/String;
move-object v10, v6
goto :goto_13b
:cond_177
new-instance v9, Ljava/io/File;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
move-object/from16 v0, p1
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->realName:Ljava/lang/String;
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-direct {v9, v6}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v9}, Ljava/io/File;->exists()Z
move-result v6
if-eqz v6, :cond_230
invoke-static {v9, v10}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->verifyDexFileMd5(Ljava/io/File;Ljava/lang/String;)Z
move-result v6
if-eqz v6, :cond_1ba
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "dex file %s is already exist, and md5 match, just continue"
const/4 v8, 0x1
new-array v8, v8, [Ljava/lang/Object;
const/4 v10, 0x0
invoke-virtual {v9}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v9
aput-object v9, v8, v10
invoke-static {v6, v7, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto/16 :goto_8e
:catchall_1b2
move-exception v6
move-object/from16 v20, v6
move-object v6, v4
move-object/from16 v4, v20
goto/16 :goto_10e
:cond_1ba
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v18, "have a mismatch corrupted dex "
move-object/from16 v0, v18
invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v9}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v18
move-object/from16 v0, v18
invoke-virtual {v7, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/16 v18, 0x0
move/from16 v0, v18
new-array v0, v0, [Ljava/lang/Object;
move-object/from16 v18, v0
move-object/from16 v0, v18
invoke-static {v6, v7, v0}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v9}, Ljava/io/File;->delete()Z
:goto_1e9
invoke-virtual {v5, v11}, Ljava/util/zip/ZipFile;->getEntry(Ljava/lang/String;)Ljava/util/zip/ZipEntry;
move-result-object v7
invoke-virtual {v4, v11}, Ljava/util/zip/ZipFile;->getEntry(Ljava/lang/String;)Ljava/util/zip/ZipEntry;
move-result-object v6
const-string/jumbo v18, "0"
invoke-virtual/range {v17 .. v18}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v18
if-eqz v18, :cond_276
if-nez v7, :cond_238
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v10, "patch entry is null. path:"
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v10, 0x0
new-array v10, v10, [Ljava/lang/Object;
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_226
.catch Ljava/lang/Throwable; {:try_start_173 .. :try_end_226} :catch_d3
.catchall {:try_start_173 .. :try_end_226} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_230
:try_start_230
invoke-virtual {v9}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v6
invoke-virtual {v6}, Ljava/io/File;->mkdirs()Z
goto :goto_1e9
:cond_238
invoke-static {v5, v7, v9, v8}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->extractDexFile(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;)Z
move-result v6
if-nez v6, :cond_8e
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v10, "Failed to extract raw patch file "
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v9}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v10
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v10, 0x0
new-array v10, v10, [Ljava/lang/Object;
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_26c
.catch Ljava/lang/Throwable; {:try_start_230 .. :try_end_26c} :catch_d3
.catchall {:try_start_230 .. :try_end_26c} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_276
:try_start_276
const-string/jumbo v18, "0"
move-object/from16 v0, v16
move-object/from16 v1, v18
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v18
if-eqz v18, :cond_33d
sget-boolean v7, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->isVmArt:Z
if-eqz v7, :cond_8e
if-nez v6, :cond_2bd
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v10, "apk entry is null. path:"
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v10, 0x0
new-array v10, v10, [Ljava/lang/Object;
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_2b3
.catch Ljava/lang/Throwable; {:try_start_276 .. :try_end_2b3} :catch_d3
.catchall {:try_start_276 .. :try_end_2b3} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_2bd
:try_start_2bd
invoke-virtual {v6}, Ljava/util/zip/ZipEntry;->getCrc()J
move-result-wide v14
invoke-static {v14, v15}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v7
move-object/from16 v0, v17
invoke-virtual {v7, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v14
if-nez v14, :cond_2f9
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v10, "apk entry %s crc is not equal, expect crc: %s, got crc: %s"
const/4 v13, 0x3
new-array v13, v13, [Ljava/lang/Object;
const/4 v14, 0x0
aput-object v11, v13, v14
const/4 v11, 0x1
aput-object v17, v13, v11
const/4 v11, 0x2
aput-object v7, v13, v11
invoke-static {v6, v10, v13}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_2ef
.catch Ljava/lang/Throwable; {:try_start_2bd .. :try_end_2ef} :catch_d3
.catchall {:try_start_2bd .. :try_end_2ef} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_2f9
:try_start_2f9
invoke-static {v4, v6, v9, v8}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->extractDexFile(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;)Z
invoke-static {v9, v10}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->verifyDexFileMd5(Ljava/io/File;Ljava/lang/String;)Z
move-result v6
if-nez v6, :cond_8e
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v10, "Failed to recover dex file when verify patched dex: "
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v9}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v10
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v10, 0x0
new-array v10, v10, [Ljava/lang/Object;
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
invoke-static {v9}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->safeDeleteFile(Ljava/io/File;)Z
:try_end_333
.catch Ljava/lang/Throwable; {:try_start_2f9 .. :try_end_333} :catch_d3
.catchall {:try_start_2f9 .. :try_end_333} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_33d
if-nez v7, :cond_373
:try_start_33f
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v10, "patch entry is null. path:"
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v10, 0x0
new-array v10, v10, [Ljava/lang/Object;
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_369
.catch Ljava/lang/Throwable; {:try_start_33f .. :try_end_369} :catch_d3
.catchall {:try_start_33f .. :try_end_369} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_373
:try_start_373
invoke-static/range {v16 .. v16}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->checkIfMd5Valid(Ljava/lang/String;)Z
move-result v18
if-nez v18, :cond_3ab
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "meta file md5 invalid, type:%s, name: %s, md5: %s"
const/4 v9, 0x3
new-array v9, v9, [Ljava/lang/Object;
const/4 v10, 0x0
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->getTypeString(I)Ljava/lang/String;
move-result-object v11
aput-object v11, v9, v10
const/4 v10, 0x1
iget-object v8, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
aput-object v8, v9, v10
const/4 v8, 0x2
aput-object v16, v9, v8
invoke-static {v6, v7, v9}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/lib/patch/BasePatchInternal;->getMetaCorruptedCode(I)I
move-result v7
move-object/from16 v0, p3
invoke-interface {v6, v0, v7}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchPackageCheckFail(Ljava/io/File;I)V
:try_end_3a1
.catch Ljava/lang/Throwable; {:try_start_373 .. :try_end_3a1} :catch_d3
.catchall {:try_start_373 .. :try_end_3a1} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_3ab
if-nez v6, :cond_3e1
:try_start_3ad
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v10, "apk entry is null. path:"
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v10, 0x0
new-array v10, v10, [Ljava/lang/Object;
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_3d7
.catch Ljava/lang/Throwable; {:try_start_3ad .. :try_end_3d7} :catch_d3
.catchall {:try_start_3ad .. :try_end_3d7} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_3e1
:try_start_3e1
invoke-virtual {v6}, Ljava/util/zip/ZipEntry;->getCrc()J
move-result-wide v18
invoke-static/range {v18 .. v19}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v16
invoke-virtual/range {v16 .. v17}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v18
if-nez v18, :cond_41b
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "apk entry %s crc is not equal, expect crc: %s, got crc: %s"
const/4 v10, 0x3
new-array v10, v10, [Ljava/lang/Object;
const/4 v13, 0x0
aput-object v11, v10, v13
const/4 v11, 0x1
aput-object v17, v10, v11
const/4 v11, 0x2
aput-object v16, v10, v11
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_411
.catch Ljava/lang/Throwable; {:try_start_3e1 .. :try_end_411} :catch_d3
.catchall {:try_start_3e1 .. :try_end_411} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_41b
:try_start_41b
invoke-static/range {v4 .. v9}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchDexFile(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/util/zip/ZipEntry;Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;Ljava/io/File;)V
invoke-static {v9, v10}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->verifyDexFileMd5(Ljava/io/File;Ljava/lang/String;)Z
move-result v6
if-nez v6, :cond_45f
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v10, "Failed to recover dex file when verify patched dex: "
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v9}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v10
invoke-virtual {v7, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v10, 0x0
new-array v10, v10, [Ljava/lang/Object;
invoke-static {v6, v7, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v6
iget-object v7, v8, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v6, v0, v9, v7, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
invoke-static {v9}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->safeDeleteFile(Ljava/io/File;)Z
:try_end_455
.catch Ljava/lang/Throwable; {:try_start_41b .. :try_end_455} :catch_d3
.catchall {:try_start_41b .. :try_end_455} :catchall_1b2
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_45f
:try_start_45f
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "success recover dex file: %s, size: %d, use time: %d"
const/4 v8, 0x3
new-array v8, v8, [Ljava/lang/Object;
const/4 v10, 0x0
invoke-virtual {v9}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v11
aput-object v11, v8, v10
const/4 v10, 0x1
invoke-virtual {v9}, Ljava/io/File;->length()J
move-result-wide v16
invoke-static/range {v16 .. v17}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v9
aput-object v9, v8, v10
const/4 v9, 0x2
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v10
sub-long/2addr v10, v14
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v10
aput-object v10, v8, v9
invoke-static {v6, v7, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto/16 :goto_8e
:cond_48b
move-object/from16 v0, p0
move-object/from16 v1, p3
move-object/from16 v2, p1
invoke-static {v0, v1, v2}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->mergeClassNDexFiles(Landroid/content/Context;Ljava/io/File;Ljava/lang/String;)Z
:try_end_494
.catch Ljava/lang/Throwable; {:try_start_45f .. :try_end_494} :catch_d3
.catchall {:try_start_45f .. :try_end_494} :catchall_1b2
move-result v6
if-nez v6, :cond_4a1
const/4 v6, 0x0
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
move v4, v6
goto/16 :goto_28
:cond_4a1
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeZip(Ljava/util/zip/ZipFile;)V
const/4 v4, 0x1
goto/16 :goto_28
:catchall_4aa
move-exception v4
move-object/from16 v20, v6
move-object v6, v5
move-object/from16 v5, v20
goto/16 :goto_10e
:catchall_4b2
move-exception v5
move-object/from16 v20, v5
move-object v5, v6
move-object v6, v4
move-object/from16 v4, v20
goto/16 :goto_10e
:catch_4bb
move-exception v4
move-object/from16 v20, v6
move-object v6, v5
move-object/from16 v5, v20
goto/16 :goto_d9
:catch_4c3
move-exception v5
move-object/from16 v20, v5
move-object v5, v6
move-object v6, v4
move-object/from16 v4, v20
goto/16 :goto_d9
.end method
.method private static extractDexFile(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;)Z
.registers 7
sget-boolean v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->isVmArt:Z
if-eqz v0, :cond_17
iget-object v0, p3, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->destMd5InArt:Ljava/lang/String;
:goto_6
iget-object v1, p3, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
iget-boolean v2, p3, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->isJarMode:Z
invoke-static {v1}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->isRawDexFile(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_1a
if-eqz v2, :cond_1a
invoke-static {p0, p1, p2, v0}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->extractDexToJar(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Ljava/lang/String;)Z
move-result v0
:goto_16
return v0
:cond_17
iget-object v0, p3, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->destMd5InDvm:Ljava/lang/String;
goto :goto_6
:cond_1a
const/4 v1, 0x1
invoke-static {p0, p1, p2, v0, v1}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->extract(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Ljava/lang/String;Z)Z
move-result v0
goto :goto_16
.end method
.method private static extractDexToJar(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Ljava/lang/String;)Z
.registers 12
const/4 v2, 0x0
const/4 v4, 0x0
move v0, v4
move v1, v4
:goto_4
const/4 v3, 0x2
if-ge v1, v3, :cond_bb
if-nez v0, :cond_bb
add-int/lit8 v5, v1, 0x1
const-string/jumbo v0, "Tinker.DexDiffPatchInternal"
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v3, "try Extracting "
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v3
invoke-virtual {v1, v3}, 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
new-array v3, v4, [Ljava/lang/Object;
invoke-static {v0, v1, v3}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_start_2b
new-instance v3, Ljava/util/zip/ZipOutputStream;
new-instance v0, Ljava/io/BufferedOutputStream;
new-instance v1, Ljava/io/FileOutputStream;
invoke-direct {v1, p2}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
invoke-direct {v0, v1}, Ljava/io/BufferedOutputStream;-><init>(Ljava/io/OutputStream;)V
invoke-direct {v3, v0}, Ljava/util/zip/ZipOutputStream;-><init>(Ljava/io/OutputStream;)V
:try_end_3a
.catchall {:try_start_2b .. :try_end_3a} :catchall_b2
:try_start_3a
new-instance v1, Ljava/io/BufferedInputStream;
invoke-virtual {p0, p1}, Ljava/util/zip/ZipFile;->getInputStream(Ljava/util/zip/ZipEntry;)Ljava/io/InputStream;
move-result-object v0
invoke-direct {v1, v0}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;)V
:try_end_43
.catchall {:try_start_3a .. :try_end_43} :catchall_bc
const/16 v0, 0x4000
:try_start_45
new-array v6, v0, [B
new-instance v0, Ljava/util/zip/ZipEntry;
const-string/jumbo v7, "classes.dex"
invoke-direct {v0, v7}, Ljava/util/zip/ZipEntry;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v0}, Ljava/util/zip/ZipOutputStream;->putNextEntry(Ljava/util/zip/ZipEntry;)V
invoke-virtual {v1, v6}, Ljava/io/BufferedInputStream;->read([B)I
move-result v0
:goto_56
const/4 v7, -0x1
if-eq v0, v7, :cond_62
const/4 v7, 0x0
invoke-virtual {v3, v6, v7, v0}, Ljava/util/zip/ZipOutputStream;->write([BII)V
invoke-virtual {v1, v6}, Ljava/io/BufferedInputStream;->read([B)I
move-result v0
goto :goto_56
:cond_62
invoke-virtual {v3}, Ljava/util/zip/ZipOutputStream;->closeEntry()V
:try_end_65
.catchall {:try_start_45 .. :try_end_65} :catchall_c0
invoke-static {v1}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
invoke-static {v3}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
invoke-static {p2, p3}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->verifyDexFileMd5(Ljava/io/File;Ljava/lang/String;)Z
move-result v0
const-string/jumbo v1, "Tinker.DexDiffPatchInternal"
const-string/jumbo v3, "isExtractionSuccessful: %b"
const/4 v6, 0x1
new-array v6, v6, [Ljava/lang/Object;
invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v7
aput-object v7, v6, v4
invoke-static {v1, v3, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
if-nez v0, :cond_af
invoke-virtual {p2}, Ljava/io/File;->delete()Z
move-result v1
if-eqz v1, :cond_8f
invoke-virtual {p2}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_af
:cond_8f
const-string/jumbo v1, "Tinker.DexDiffPatchInternal"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v6, "Failed to delete corrupted dex "
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {p2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v6
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
new-array v6, v4, [Ljava/lang/Object;
invoke-static {v1, v3, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_af
move v1, v5
goto/16 :goto_4
:catchall_b2
move-exception v0
move-object v1, v2
:goto_b4
invoke-static {v1}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
invoke-static {v2}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
throw v0
:cond_bb
return v0
:catchall_bc
move-exception v0
move-object v1, v2
move-object v2, v3
goto :goto_b4
:catchall_c0
move-exception v0
move-object v2, v3
goto :goto_b4
.end method
.method private static mergeClassNDexFiles(Landroid/content/Context;Ljava/io/File;Ljava/lang/String;)Z
.registers 19
sget-object v2, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v2}, Ljava/util/ArrayList;->isEmpty()Z
move-result v2
if-nez v2, :cond_c
sget-boolean v2, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->isVmArt:Z
if-nez v2, :cond_e
:cond_c
const/4 v2, 0x1
:goto_d
return v2
:cond_e
new-instance v9, Ljava/io/File;
const-string/jumbo v2, "tinker_classN.apk"
move-object/from16 v0, p2
invoke-direct {v9, v0, v2}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
sget-object v2, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v2}, Ljava/util/HashMap;->isEmpty()Z
move-result v2
if-eqz v2, :cond_3b
const-string/jumbo v2, "Tinker.DexDiffPatchInternal"
const-string/jumbo v3, "classNDexInfo size: %d, no need to merge classN dex files"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
sget-object v6, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v6}, Ljava/util/HashMap;->size()I
move-result v6
invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v6
aput-object v6, v4, v5
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v2, 0x1
goto :goto_d
:cond_3b
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v10
const/4 v8, 0x1
const/4 v3, 0x0
:try_start_41
new-instance v7, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipOutputStream;
new-instance v2, Ljava/io/BufferedOutputStream;
new-instance v4, Ljava/io/FileOutputStream;
invoke-direct {v4, v9}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
invoke-direct {v2, v4}, Ljava/io/BufferedOutputStream;-><init>(Ljava/io/OutputStream;)V
invoke-direct {v7, v2}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipOutputStream;-><init>(Ljava/io/OutputStream;)V
:try_end_50
.catch Ljava/lang/Throwable; {:try_start_41 .. :try_end_50} :catch_184
.catchall {:try_start_41 .. :try_end_50} :catchall_17e
:try_start_50
sget-object v2, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v2}, Ljava/util/HashMap;->keySet()Ljava/util/Set;
move-result-object v2
invoke-interface {v2}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v12
:goto_5a
invoke-interface {v12}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_124
invoke-interface {v12}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;
sget-object v3, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v3, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/io/File;
iget-boolean v4, v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->isJarMode:Z
:try_end_70
.catch Ljava/lang/Throwable; {:try_start_50 .. :try_end_70} :catch_95
.catchall {:try_start_50 .. :try_end_70} :catchall_10d
if-eqz v4, :cond_112
const/4 v6, 0x0
const/4 v4, 0x0
:try_start_74
new-instance v5, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipFile;
invoke-direct {v5, v3}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipFile;-><init>(Ljava/io/File;)V
:try_end_79
.catchall {:try_start_74 .. :try_end_79} :catchall_103
:try_start_79
const-string/jumbo v3, "classes.dex"
invoke-virtual {v5, v3}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipFile;->getEntry(Ljava/lang/String;)Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;
move-result-object v3
new-instance v6, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
invoke-direct {v6, v3, v2}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;-><init>(Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;Ljava/lang/String;)V
invoke-virtual {v5, v3}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipFile;->getInputStream(Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;)Ljava/io/InputStream;
:try_end_8a
.catchall {:try_start_79 .. :try_end_8a} :catchall_187
move-result-object v3
:try_start_8b
invoke-static {v6, v3, v7}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipUtil;->extractTinkerEntry(Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;Ljava/io/InputStream;Lcom/tencent/tinker/ziputils/ziputil/TinkerZipOutputStream;)V
:try_end_8e
.catchall {:try_start_8b .. :try_end_8e} :catchall_18c
:try_start_8e
invoke-static {v3}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
invoke-static {v5}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
:try_end_94
.catch Ljava/lang/Throwable; {:try_start_8e .. :try_end_94} :catch_95
.catchall {:try_start_8e .. :try_end_94} :catchall_10d
goto :goto_5a
:catch_95
move-exception v2
move-object v3, v7
:goto_97
:try_start_97
const-string/jumbo v4, "Tinker.DexDiffPatchInternal"
const-string/jumbo v5, "merge classN file"
const/4 v6, 0x0
new-array v6, v6, [Ljava/lang/Object;
invoke-static {v4, v2, v5, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->printErrStackTrace(Ljava/lang/String;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_a3
.catchall {:try_start_97 .. :try_end_a3} :catchall_181
const/4 v2, 0x0
invoke-static {v3}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
move v3, v2
:goto_a8
if-eqz v3, :cond_e7
sget-object v2, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v2}, Ljava/util/HashMap;->keySet()Ljava/util/Set;
move-result-object v2
invoke-interface {v2}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v4
:cond_b4
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_e7
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;
iget-object v5, v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
iget-object v6, v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->destMd5InArt:Ljava/lang/String;
invoke-static {v9, v5, v6}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->verifyDexFileMd5(Ljava/io/File;Ljava/lang/String;Ljava/lang/String;)Z
move-result v5
if-nez v5, :cond_b4
const/4 v3, 0x0
const-string/jumbo v4, "Tinker.DexDiffPatchInternal"
const-string/jumbo v5, "verify dex file md5 error, entry name; %s, file len: %d"
const/4 v6, 0x2
new-array v6, v6, [Ljava/lang/Object;
const/4 v7, 0x0
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
aput-object v2, v6, v7
const/4 v2, 0x1
invoke-virtual {v9}, Ljava/io/File;->length()J
move-result-wide v12
invoke-static {v12, v13}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v7
aput-object v7, v6, v2
invoke-static {v4, v5, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_e7
if-eqz v3, :cond_129
sget-object v2, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->classNDexInfo:Ljava/util/HashMap;
invoke-virtual {v2}, Ljava/util/HashMap;->values()Ljava/util/Collection;
move-result-object v2
invoke-interface {v2}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v4
:goto_f3
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_14a
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/io/File;
invoke-static {v2}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->safeDeleteFile(Ljava/io/File;)Z
goto :goto_f3
:catchall_103
move-exception v2
move-object v3, v4
move-object v4, v6
:goto_106
:try_start_106
invoke-static {v3}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
invoke-static {v4}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
throw v2
:try_end_10d
.catch Ljava/lang/Throwable; {:try_start_106 .. :try_end_10d} :catch_95
.catchall {:try_start_106 .. :try_end_10d} :catchall_10d
:catchall_10d
move-exception v2
:goto_10e
invoke-static {v7}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
throw v2
:cond_112
:try_start_112
new-instance v4, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;
iget-object v5, v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
invoke-direct {v4, v5}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;-><init>(Ljava/lang/String;)V
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->newOrPatchedDexCrC:Ljava/lang/String;
invoke-static {v2}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v14
invoke-static {v4, v3, v14, v15, v7}, Lcom/tencent/tinker/ziputils/ziputil/TinkerZipUtil;->extractLargeModifyFile(Lcom/tencent/tinker/ziputils/ziputil/TinkerZipEntry;Ljava/io/File;JLcom/tencent/tinker/ziputils/ziputil/TinkerZipOutputStream;)V
:try_end_122
.catch Ljava/lang/Throwable; {:try_start_112 .. :try_end_122} :catch_95
.catchall {:try_start_112 .. :try_end_122} :catchall_10d
goto/16 :goto_5a
:cond_124
invoke-static {v7}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
move v3, v8
goto :goto_a8
:cond_129
const-string/jumbo v2, "Tinker.DexDiffPatchInternal"
const-string/jumbo v4, "merge classN dex error, try delete temp file"
const/4 v5, 0x0
new-array v5, v5, [Ljava/lang/Object;
invoke-static {v2, v4, v5}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-static {v9}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->safeDeleteFile(Ljava/io/File;)Z
invoke-static/range {p0 .. p0}, Lcom/tencent/tinker/lib/tinker/Tinker;->with(Landroid/content/Context;)Lcom/tencent/tinker/lib/tinker/Tinker;
move-result-object v2
invoke-virtual {v2}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v2
invoke-virtual {v9}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v4
const/4 v5, 0x7
move-object/from16 v0, p1
invoke-interface {v2, v0, v9, v4, v5}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:cond_14a
const-string/jumbo v2, "Tinker.DexDiffPatchInternal"
const-string/jumbo v4, "merge classN dex file %s, result: %b, size: %d, use: %dms"
const/4 v5, 0x4
new-array v5, v5, [Ljava/lang/Object;
const/4 v6, 0x0
invoke-virtual {v9}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x1
invoke-static {v3}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x2
invoke-virtual {v9}, Ljava/io/File;->length()J
move-result-wide v8
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x3
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v8
sub-long/2addr v8, v10
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v7
aput-object v7, v5, v6
invoke-static {v2, v4, v5}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
move v2, v3
goto/16 :goto_d
:catchall_17e
move-exception v2
move-object v7, v3
goto :goto_10e
:catchall_181
move-exception v2
move-object v7, v3
goto :goto_10e
:catch_184
move-exception v2
goto/16 :goto_97
:catchall_187
move-exception v2
move-object v3, v4
move-object v4, v5
goto/16 :goto_106
:catchall_18c
move-exception v2
move-object v4, v5
goto/16 :goto_106
.end method
.method private static patchDexExtractViaDexDiff(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)Z
.registers 12
const/4 v0, 0x0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v2, "/"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v2, "dex"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v2, "/"
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
const/4 v2, 0x3
invoke-static {p0, v1, p2, p3, v2}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->extractDexDiffInternals(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/io/File;I)Z
move-result v2
if-nez v2, :cond_36
const-string/jumbo v1, "Tinker.DexDiffPatchInternal"
const-string/jumbo v2, "patch recover, extractDiffInternals fail"
new-array v3, v0, [Ljava/lang/Object;
invoke-static {v1, v2, v3}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_35
return v0
:cond_36
new-instance v2, Ljava/io/File;
invoke-direct {v2, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v2
new-instance v3, Ljava/util/ArrayList;
invoke-direct {v3}, Ljava/util/ArrayList;-><init>()V
if-eqz v2, :cond_77
array-length v4, v2
move v1, v0
:goto_48
if-ge v1, v4, :cond_77
aget-object v5, v2, v1
invoke-virtual {v5}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5}, Ljava/io/File;->isFile()Z
move-result v7
if-eqz v7, :cond_74
const-string/jumbo v7, ".dex"
invoke-virtual {v6, v7}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v7
if-nez v7, :cond_71
const-string/jumbo v7, ".jar"
invoke-virtual {v6, v7}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v7
if-nez v7, :cond_71
const-string/jumbo v7, ".apk"
invoke-virtual {v6, v7}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v6
if-eqz v6, :cond_74
:cond_71
invoke-interface {v3, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:cond_74
add-int/lit8 v1, v1, 0x1
goto :goto_48
:cond_77
const-string/jumbo v1, "Tinker.DexDiffPatchInternal"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v4, "legal files to do dexopt: "
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
new-array v0, v0, [Ljava/lang/Object;
invoke-static {v1, v2, v0}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, "/"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, "odex"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, "/"
invoke-virtual {v0, v1}, 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 {p0, v3, v0, p3}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->dexOptimizeDexFiles(Landroid/content/Context;Ljava/util/List;Ljava/lang/String;Ljava/io/File;)Z
move-result v0
goto/16 :goto_35
.end method
.method private static patchDexFile(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/util/zip/ZipEntry;Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;Ljava/io/File;)V
.registers 13
const/4 v2, 0x0
:try_start_1
new-instance v5, Ljava/io/BufferedInputStream;
invoke-virtual {p0, p2}, Ljava/util/zip/ZipFile;->getInputStream(Ljava/util/zip/ZipEntry;)Ljava/io/InputStream;
move-result-object v0
invoke-direct {v5, v0}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;)V
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_b6
if-eqz p3, :cond_8a
:try_start_c
new-instance v4, Ljava/io/BufferedInputStream;
invoke-virtual {p1, p3}, Ljava/util/zip/ZipFile;->getInputStream(Ljava/util/zip/ZipEntry;)Ljava/io/InputStream;
move-result-object v0
invoke-direct {v4, v0}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;)V
:try_end_15
.catchall {:try_start_c .. :try_end_15} :catchall_b9
:goto_15
:try_start_15
iget-object v0, p4, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->rawName:Ljava/lang/String;
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->isRawDexFile(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_21
iget-boolean v1, p4, Lcom/tencent/tinker/loader/shareutil/ShareDexDiffPatchInfo;->isJarMode:Z
:try_end_1f
.catchall {:try_start_15 .. :try_end_1f} :catchall_80
if-eqz v1, :cond_ad
:cond_21
:try_start_21
new-instance v3, Ljava/util/zip/ZipOutputStream;
new-instance v1, Ljava/io/BufferedOutputStream;
new-instance v6, Ljava/io/FileOutputStream;
invoke-direct {v6, p5}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
invoke-direct {v1, v6}, Ljava/io/BufferedOutputStream;-><init>(Ljava/io/OutputStream;)V
invoke-direct {v3, v1}, Ljava/util/zip/ZipOutputStream;-><init>(Ljava/io/OutputStream;)V
:try_end_30
.catchall {:try_start_21 .. :try_end_30} :catchall_bc
:try_start_30
new-instance v1, Ljava/util/zip/ZipEntry;
const-string/jumbo v6, "classes.dex"
invoke-direct {v1, v6}, Ljava/util/zip/ZipEntry;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v1}, Ljava/util/zip/ZipOutputStream;->putNextEntry(Ljava/util/zip/ZipEntry;)V
:try_end_3b
.catchall {:try_start_30 .. :try_end_3b} :catchall_7a
if-nez v0, :cond_a4
:try_start_3d
new-instance v1, Ljava/util/zip/ZipInputStream;
invoke-direct {v1, v5}, Ljava/util/zip/ZipInputStream;-><init>(Ljava/io/InputStream;)V
:try_end_42
.catchall {:try_start_3d .. :try_end_42} :catchall_be
:cond_42
:try_start_42
invoke-virtual {v1}, Ljava/util/zip/ZipInputStream;->getNextEntry()Ljava/util/zip/ZipEntry;
move-result-object v0
if-eqz v0, :cond_55
const-string/jumbo v2, "classes.dex"
invoke-virtual {v0}, Ljava/util/zip/ZipEntry;->getName()Ljava/lang/String;
move-result-object v6
invoke-virtual {v2, v6}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_42
:cond_55
if-nez v0, :cond_8c
new-instance v0, Lcom/tencent/tinker/loader/TinkerRuntimeException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v6, "can\'t recognize zip dex format file:"
invoke-virtual {v2, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {p5}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v6
invoke-virtual {v2, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v0, v2}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_75
.catchall {:try_start_42 .. :try_end_75} :catchall_75
:catchall_75
move-exception v0
:goto_76
:try_start_76
invoke-static {v1}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
throw v0
:try_end_7a
.catchall {:try_start_76 .. :try_end_7a} :catchall_7a
:catchall_7a
move-exception v0
move-object v2, v3
:goto_7c
:try_start_7c
invoke-static {v2}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
throw v0
:try_end_80
.catchall {:try_start_7c .. :try_end_80} :catchall_80
:catchall_80
move-exception v0
move-object v2, v4
move-object v1, v5
:goto_83
invoke-static {v1}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
invoke-static {v2}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
throw v0
:cond_8a
move-object v4, v2
goto :goto_15
:cond_8c
:try_start_8c
new-instance v0, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;
invoke-direct {v0, v1, v4}, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;-><init>(Ljava/io/InputStream;Ljava/io/InputStream;)V
invoke-virtual {v0, v3}, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;->executeAndSaveTo(Ljava/io/OutputStream;)V
:try_end_94
.catchall {:try_start_8c .. :try_end_94} :catchall_75
:try_start_94
invoke-static {v1}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
:goto_97
invoke-virtual {v3}, Ljava/util/zip/ZipOutputStream;->closeEntry()V
:try_end_9a
.catchall {:try_start_94 .. :try_end_9a} :catchall_7a
:try_start_9a
invoke-static {v3}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
:try_end_9d
.catchall {:try_start_9a .. :try_end_9d} :catchall_80
:goto_9d
invoke-static {v5}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
invoke-static {v4}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
return-void
:cond_a4
:try_start_a4
new-instance v0, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;
invoke-direct {v0, v5, v4}, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;-><init>(Ljava/io/InputStream;Ljava/io/InputStream;)V
invoke-virtual {v0, v3}, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;->executeAndSaveTo(Ljava/io/OutputStream;)V
:try_end_ac
.catchall {:try_start_a4 .. :try_end_ac} :catchall_7a
goto :goto_97
:cond_ad
:try_start_ad
new-instance v0, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;
invoke-direct {v0, v5, v4}, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;-><init>(Ljava/io/InputStream;Ljava/io/InputStream;)V
invoke-virtual {v0, p5}, Lcom/tencent/tinker/commons/dexpatcher/DexPatchApplier;->executeAndSaveTo(Ljava/io/File;)V
:try_end_b5
.catchall {:try_start_ad .. :try_end_b5} :catchall_80
goto :goto_9d
:catchall_b6
move-exception v0
move-object v1, v2
goto :goto_83
:catchall_b9
move-exception v0
move-object v1, v5
goto :goto_83
:catchall_bc
move-exception v0
goto :goto_7c
:catchall_be
move-exception v0
move-object v1, v2
goto :goto_76
.end method
.method protected static tryRecoverDexFiles(Lcom/tencent/tinker/lib/tinker/Tinker;Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;Landroid/content/Context;Ljava/lang/String;Ljava/io/File;)Z
.registers 14
const/4 v1, 0x1
const/4 v8, 0x0
invoke-virtual {p0}, Lcom/tencent/tinker/lib/tinker/Tinker;->isEnabledForDex()Z
move-result v0
if-nez v0, :cond_15
const-string/jumbo v0, "Tinker.DexDiffPatchInternal"
const-string/jumbo v2, "patch recover, dex is not enabled"
new-array v3, v8, [Ljava/lang/Object;
invoke-static {v0, v2, v3}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
move v0, v1
:goto_14
return v0
:cond_15
invoke-virtual {p1}, Lcom/tencent/tinker/loader/shareutil/ShareSecurityCheck;->getMetaContentMap()Ljava/util/HashMap;
move-result-object v0
const-string/jumbo v2, "assets/dex_meta.txt"
invoke-virtual {v0, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
if-nez v0, :cond_31
const-string/jumbo v0, "Tinker.DexDiffPatchInternal"
const-string/jumbo v2, "patch recover, dex is not contained"
new-array v3, v8, [Ljava/lang/Object;
invoke-static {v0, v2, v3}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
move v0, v1
goto :goto_14
:cond_31
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
invoke-static {p2, p3, v0, p4}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchDexExtractViaDexDiff(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)Z
move-result v0
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
sub-long v2, v4, v2
const-string/jumbo v4, "Tinker.DexDiffPatchInternal"
const-string/jumbo v5, "recover dex result:%b, cost:%d"
const/4 v6, 0x2
new-array v6, v6, [Ljava/lang/Object;
invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v7
aput-object v7, v6, v8
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
aput-object v2, v6, v1
invoke-static {v4, v5, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_14
.end method
.method protected static waitAndCheckDexOptFile(Ljava/io/File;Lcom/tencent/tinker/lib/tinker/Tinker;)Z
.registers 15
const/4 v2, 0x0
const/16 v0, 0x78
const/4 v12, 0x2
const/4 v3, 0x1
const/4 v4, 0x0
sget-object v1, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
invoke-virtual {v1}, Ljava/util/ArrayList;->isEmpty()Z
move-result v1
if-eqz v1, :cond_10
move v0, v3
:goto_f
return v0
:cond_10
sget-object v1, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v1}, Ljava/util/ArrayList;->size()I
move-result v1
mul-int/lit8 v1, v1, 0x1e
if-le v1, v0, :cond_179
:goto_1a
const-string/jumbo v1, "Tinker.DexDiffPatchInternal"
const-string/jumbo v5, "raw dex count: %d, dex opt dex count: %d, final wait times: %d"
const/4 v6, 0x3
new-array v6, v6, [Ljava/lang/Object;
sget-object v7, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->patchList:Ljava/util/ArrayList;
invoke-virtual {v7}, Ljava/util/ArrayList;->size()I
move-result v7
invoke-static {v7}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v6, v4
sget-object v7, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
invoke-virtual {v7}, Ljava/util/ArrayList;->size()I
move-result v7
invoke-static {v7}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v6, v3
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v7
aput-object v7, v6, v12
invoke-static {v1, v5, v6}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
move v1, v4
:goto_45
if-ge v1, v0, :cond_77
sget-object v5, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
add-int/lit8 v6, v1, 0x1
invoke-static {v5, v6}, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->checkAllDexOptFile(Ljava/util/ArrayList;I)Z
move-result v5
if-nez v5, :cond_56
const-wide/16 v6, 0x2710
:try_start_53
invoke-static {v6, v7}, Ljava/lang/Thread;->sleep(J)V
:try_end_56
.catch Ljava/lang/InterruptedException; {:try_start_53 .. :try_end_56} :catch_59
:cond_56
:goto_56
add-int/lit8 v1, v1, 0x1
goto :goto_45
:catch_59
move-exception v5
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v8, "thread sleep InterruptedException e:"
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
new-array v7, v4, [Ljava/lang/Object;
invoke-static {v6, v5, v7}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_56
:cond_77
new-instance v5, Ljava/util/ArrayList;
invoke-direct {v5}, Ljava/util/ArrayList;-><init>()V
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v1
:cond_82
:goto_82
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_ca
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/io/File;
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "check dex optimizer file exist: %s, size %d"
new-array v8, v12, [Ljava/lang/Object;
invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v9
aput-object v9, v8, v4
invoke-virtual {v0}, Ljava/io/File;->length()J
move-result-wide v10
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v9
aput-object v9, v8, v3
invoke-static {v6, v7, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->isLegalFile(Ljava/io/File;)Z
move-result v6
if-nez v6, :cond_82
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->shouldAcceptEvenIfIllegal(Ljava/io/File;)Z
move-result v6
if-nez v6, :cond_82
const-string/jumbo v6, "Tinker.DexDiffPatchInternal"
const-string/jumbo v7, "final parallel dex optimizer file %s is not exist, return false"
new-array v8, v3, [Ljava/lang/Object;
invoke-virtual {v0}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v9
aput-object v9, v8, v4
invoke-static {v6, v7, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-interface {v5, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_82
:cond_ca
invoke-interface {v5}, Ljava/util/List;->isEmpty()Z
move-result v0
if-nez v0, :cond_e2
invoke-virtual {p1}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v0
new-instance v1, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v2, "checkDexOptExist failed"
invoke-direct {v1, v2}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;)V
invoke-interface {v0, p0, v5, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchDexOptFail(Ljava/io/File;Ljava/util/List;Ljava/lang/Throwable;)V
move v0, v4
goto/16 :goto_f
:cond_e2
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x15
if-lt v0, v1, :cond_171
sget-object v0, Lcom/tencent/tinker/lib/patch/DexDiffPatchInternal;->optFiles:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v6
move-object v1, v2
:cond_ef
:goto_ef
invoke-interface {v6}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_14e
invoke-interface {v6}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/io/File;
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->shouldAcceptEvenIfIllegal(Ljava/io/File;)Z
move-result v7
if-nez v7, :cond_ef
const-string/jumbo v7, "Tinker.DexDiffPatchInternal"
const-string/jumbo v8, "check dex optimizer file format: %s, size %d"
new-array v9, v12, [Ljava/lang/Object;
invoke-virtual {v0}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v10
aput-object v10, v9, v4
invoke-virtual {v0}, Ljava/io/File;->length()J
move-result-wide v10
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v10
aput-object v10, v9, v3
invoke-static {v7, v8, v9}, Lcom/tencent/tinker/lib/util/TinkerLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_start_11c
invoke-static {v0}, Lcom/tencent/tinker/loader/shareutil/ShareElfFile;->getFileTypeByMagic(Ljava/io/File;)I
:try_end_11f
.catch Ljava/io/IOException; {:try_start_11c .. :try_end_11f} :catch_174
move-result v7
if-ne v7, v3, :cond_177
:try_start_122
new-instance v7, Lcom/tencent/tinker/loader/shareutil/ShareElfFile;
invoke-direct {v7, v0}, Lcom/tencent/tinker/loader/shareutil/ShareElfFile;-><init>(Ljava/io/File;)V
:try_end_127
.catch Ljava/lang/Throwable; {:try_start_122 .. :try_end_127} :catch_12d
.catchall {:try_start_122 .. :try_end_127} :catchall_149
invoke-static {v7}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
move-object v0, v1
:goto_12b
move-object v1, v0
goto :goto_ef
:catch_12d
move-exception v1
:try_start_12e
const-string/jumbo v7, "Tinker.DexDiffPatchInternal"
const-string/jumbo v8, "final parallel dex optimizer file %s is not elf format, return false"
const/4 v9, 0x1
new-array v9, v9, [Ljava/lang/Object;
const/4 v10, 0x0
invoke-virtual {v0}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v11
aput-object v11, v9, v10
invoke-static {v7, v8, v9}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-interface {v5, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:try_end_144
.catchall {:try_start_12e .. :try_end_144} :catchall_149
invoke-static {v2}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
move-object v0, v1
goto :goto_12b
:catchall_149
move-exception v0
invoke-static {v2}, Lcom/tencent/tinker/commons/util/StreamUtil;->closeQuietly(Ljava/lang/Object;)V
throw v0
:cond_14e
invoke-interface {v5}, Ljava/util/List;->isEmpty()Z
move-result v0
if-nez v0, :cond_171
if-nez v1, :cond_168
new-instance v0, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v1, "checkDexOptFormat failed"
invoke-direct {v0, v1}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;)V
:goto_15e
invoke-virtual {p1}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v1
invoke-interface {v1, p0, v5, v0}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchDexOptFail(Ljava/io/File;Ljava/util/List;Ljava/lang/Throwable;)V
move v0, v4
goto/16 :goto_f
:cond_168
new-instance v0, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v2, "checkDexOptFormat failed"
invoke-direct {v0, v2, v1}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_15e
:cond_171
move v0, v3
goto/16 :goto_f
:catch_174
move-exception v0
goto/16 :goto_ef
:cond_177
move-object v0, v1
goto :goto_12b
:cond_179
move v0, v1
goto/16 :goto_1a
.end method