BsDiffPatchInternal.smali
.class public Lcom/tencent/tinker/lib/patch/BsDiffPatchInternal;
.super Lcom/tencent/tinker/lib/patch/BasePatchInternal;
# static fields
.field private static final TAG:Ljava/lang/String; = "Tinker.BsDiffPatchInternal"
# direct methods
.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 extractBsDiffInternals(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/io/File;I)Z
.registers 23
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
move-object/from16 v0, p2
invoke-static {v0, v2}, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->parseDiffPatchInfo(Ljava/lang/String;Ljava/util/ArrayList;)V
invoke-virtual {v2}, Ljava/util/ArrayList;->isEmpty()Z
move-result v3
if-eqz v3, :cond_25
const-string/jumbo v2, "Tinker.BsDiffPatchInternal"
const-string/jumbo v3, "extract patch list is empty! type:%s:"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->getTypeString(I)Ljava/lang/String;
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_24
return v2
:cond_25
new-instance v3, Ljava/io/File;
move-object/from16 v0, p1
invoke-direct {v3, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v3}, Ljava/io/File;->exists()Z
move-result v4
if-nez v4, :cond_35
invoke-virtual {v3}, Ljava/io/File;->mkdirs()Z
:cond_35
invoke-static/range {p0 .. p0}, Lcom/tencent/tinker/lib/tinker/Tinker;->with(Landroid/content/Context;)Lcom/tencent/tinker/lib/tinker/Tinker;
move-result-object v7
invoke-virtual/range {p0 .. p0}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo;
move-result-object v5
if-nez v5, :cond_4d
const-string/jumbo v2, "Tinker.BsDiffPatchInternal"
const-string/jumbo v3, "applicationInfo == null!!!!"
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
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, 0x0
goto :goto_24
:cond_4d
const/4 v4, 0x0
const/4 v3, 0x0
:try_start_4f
iget-object v5, v5, Landroid/content/pm/ApplicationInfo;->sourceDir:Ljava/lang/String;
new-instance v6, Ljava/util/zip/ZipFile;
invoke-direct {v6, v5}, Ljava/util/zip/ZipFile;-><init>(Ljava/lang/String;)V
:try_end_56
.catch Ljava/lang/Throwable; {:try_start_4f .. :try_end_56} :catch_35a
.catchall {:try_start_4f .. :try_end_56} :catchall_351
:try_start_56
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_5d
.catch Ljava/lang/Throwable; {:try_start_56 .. :try_end_5d} :catch_35d
.catchall {:try_start_56 .. :try_end_5d} :catchall_356
:try_start_5d
invoke-virtual {v2}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v8
:cond_61
:goto_61
invoke-interface {v8}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_348
invoke-interface {v8}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v10
iget-object v3, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->path:Ljava/lang/String;
const-string/jumbo v4, ""
invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v3
if-eqz v3, :cond_b9
iget-object v3, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
:goto_7e
iget-object v9, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->md5:Ljava/lang/String;
invoke-static {v9}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->checkIfMd5Valid(Ljava/lang/String;)Z
move-result v4
if-nez v4, :cond_d6
const-string/jumbo v3, "Tinker.BsDiffPatchInternal"
const-string/jumbo v4, "meta file md5 mismatch, type:%s, name: %s, md5: %s"
const/4 v8, 0x3
new-array v8, v8, [Ljava/lang/Object;
const/4 v9, 0x0
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->getTypeString(I)Ljava/lang/String;
move-result-object v10
aput-object v10, v8, v9
const/4 v9, 0x1
iget-object v10, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
aput-object v10, v8, v9
const/4 v9, 0x2
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->md5:Ljava/lang/String;
aput-object v2, v8, v9
invoke-static {v3, v4, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v7}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v2
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/lib/patch/BasePatchInternal;->getMetaCorruptedCode(I)I
move-result v3
move-object/from16 v0, p3
invoke-interface {v2, v0, v3}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchPackageCheckFail(Ljava/io/File;I)V
:try_end_b0
.catch Ljava/lang/Throwable; {:try_start_5d .. :try_end_b0} :catch_12f
.catchall {:try_start_5d .. :try_end_b0} :catchall_1d7
const/4 v2, 0x0
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
goto/16 :goto_24
:cond_b9
:try_start_b9
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
iget-object v4, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->path:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string/jumbo v4, "/"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
invoke-virtual {v3, v4}, 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
goto :goto_7e
:cond_d6
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
iget-object v12, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->path:Ljava/lang/String;
invoke-virtual {v4, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const-string/jumbo v12, "/"
invoke-virtual {v4, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
iget-object v12, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
invoke-virtual {v4, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
new-instance v12, Ljava/io/File;
new-instance v13, Ljava/lang/StringBuilder;
invoke-direct {v13}, Ljava/lang/StringBuilder;-><init>()V
move-object/from16 v0, p1
invoke-virtual {v13, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v13
invoke-virtual {v13, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-direct {v12, v4}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v12}, Ljava/io/File;->exists()Z
move-result v4
if-eqz v4, :cond_1cf
invoke-static {v12}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->getMD5(Ljava/io/File;)Ljava/lang/String;
move-result-object v4
invoke-virtual {v9, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v4
if-eqz v4, :cond_170
const-string/jumbo v2, "Tinker.BsDiffPatchInternal"
const-string/jumbo v3, "bsdiff file %s is already exist, and md5 match, just continue"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v9, 0x0
invoke-virtual {v12}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v10
aput-object v10, v4, v9
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_12d
.catch Ljava/lang/Throwable; {:try_start_b9 .. :try_end_12d} :catch_12f
.catchall {:try_start_b9 .. :try_end_12d} :catchall_1d7
goto/16 :goto_61
:catch_12f
move-exception v2
move-object v3, v5
move-object v4, v6
:goto_132
:try_start_132
new-instance v5, Lcom/tencent/tinker/loader/TinkerRuntimeException;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v7, "patch "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->getTypeString(I)Ljava/lang/String;
move-result-object v7
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string/jumbo v7, " extract failed ("
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v2}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v7
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
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-direct {v5, v6, v2}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v5
:try_end_166
.catchall {:try_start_132 .. :try_end_166} :catchall_166
:catchall_166
move-exception v2
move-object v5, v3
move-object v6, v4
:goto_169
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 v2
:cond_170
:try_start_170
const-string/jumbo v4, "Tinker.BsDiffPatchInternal"
new-instance v13, Ljava/lang/StringBuilder;
invoke-direct {v13}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v14, "have a mismatch corrupted dex "
invoke-virtual {v13, v14}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v13
invoke-virtual {v12}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v14
invoke-virtual {v13, v14}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v13
invoke-virtual {v13}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v13
const/4 v14, 0x0
new-array v14, v14, [Ljava/lang/Object;
invoke-static {v4, v13, v14}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v12}, Ljava/io/File;->delete()Z
:goto_194
iget-object v4, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->patchMd5:Ljava/lang/String;
invoke-virtual {v5, v3}, Ljava/util/zip/ZipFile;->getEntry(Ljava/lang/String;)Ljava/util/zip/ZipEntry;
move-result-object v13
if-nez v13, :cond_1d9
const-string/jumbo v4, "Tinker.BsDiffPatchInternal"
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v9, "patch entry is null. path:"
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-virtual {v8, v3}, 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
const/4 v8, 0x0
new-array v8, v8, [Ljava/lang/Object;
invoke-static {v4, v3, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v7}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v3, v0, v12, v2, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_1c6
.catch Ljava/lang/Throwable; {:try_start_170 .. :try_end_1c6} :catch_12f
.catchall {:try_start_170 .. :try_end_1c6} :catchall_1d7
const/4 v2, 0x0
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
goto/16 :goto_24
:cond_1cf
:try_start_1cf
invoke-virtual {v12}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v4
invoke-virtual {v4}, Ljava/io/File;->mkdirs()Z
goto :goto_194
:catchall_1d7
move-exception v2
goto :goto_169
:cond_1d9
const-string/jumbo v14, "0"
invoke-virtual {v4, v14}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v14
if-eqz v14, :cond_220
const/4 v3, 0x0
invoke-static {v5, v13, v12, v9, v3}, Lcom/tencent/tinker/lib/patch/BsDiffPatchInternal;->extract(Ljava/util/zip/ZipFile;Ljava/util/zip/ZipEntry;Ljava/io/File;Ljava/lang/String;Z)Z
move-result v3
if-nez v3, :cond_61
const-string/jumbo v3, "Tinker.BsDiffPatchInternal"
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v8, "Failed to extract file "
invoke-virtual {v4, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v12}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v8
invoke-virtual {v4, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
const/4 v8, 0x0
new-array v8, v8, [Ljava/lang/Object;
invoke-static {v3, v4, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v7}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v3, v0, v12, v2, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_217
.catch Ljava/lang/Throwable; {:try_start_1cf .. :try_end_217} :catch_12f
.catchall {:try_start_1cf .. :try_end_217} :catchall_1d7
const/4 v2, 0x0
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
goto/16 :goto_24
:cond_220
:try_start_220
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->checkIfMd5Valid(Ljava/lang/String;)Z
move-result v14
if-nez v14, :cond_257
const-string/jumbo v3, "Tinker.BsDiffPatchInternal"
const-string/jumbo v8, "meta file md5 mismatch, 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 v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
aput-object v2, v9, v10
const/4 v2, 0x2
aput-object v4, v9, v2
invoke-static {v3, v8, v9}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v7}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v2
invoke-static/range {p4 .. p4}, Lcom/tencent/tinker/lib/patch/BasePatchInternal;->getMetaCorruptedCode(I)I
move-result v3
move-object/from16 v0, p3
invoke-interface {v2, v0, v3}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchPackageCheckFail(Ljava/io/File;I)V
:try_end_24e
.catch Ljava/lang/Throwable; {:try_start_220 .. :try_end_24e} :catch_12f
.catchall {:try_start_220 .. :try_end_24e} :catchall_1d7
const/4 v2, 0x0
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
goto/16 :goto_24
:cond_257
:try_start_257
invoke-virtual {v6, v3}, Ljava/util/zip/ZipFile;->getEntry(Ljava/lang/String;)Ljava/util/zip/ZipEntry;
move-result-object v14
if-nez v14, :cond_290
const-string/jumbo v4, "Tinker.BsDiffPatchInternal"
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v9, "apk entry is null. path:"
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-virtual {v8, v3}, 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
const/4 v8, 0x0
new-array v8, v8, [Ljava/lang/Object;
invoke-static {v4, v3, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v7}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v3, v0, v12, v2, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_287
.catch Ljava/lang/Throwable; {:try_start_257 .. :try_end_287} :catch_12f
.catchall {:try_start_257 .. :try_end_287} :catchall_1d7
const/4 v2, 0x0
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
goto/16 :goto_24
:cond_290
:try_start_290
iget-object v4, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->rawCrc:Ljava/lang/String;
invoke-virtual {v14}, Ljava/util/zip/ZipEntry;->getCrc()J
move-result-wide v16
invoke-static/range {v16 .. v17}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v15
invoke-virtual {v15, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v16
if-nez v16, :cond_2cb
const-string/jumbo v8, "Tinker.BsDiffPatchInternal"
const-string/jumbo v9, "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 v11, 0x0
aput-object v3, v10, v11
const/4 v3, 0x1
aput-object v4, v10, v3
const/4 v3, 0x2
aput-object v15, v10, v3
invoke-static {v8, v9, v10}, Lcom/tencent/tinker/lib/util/TinkerLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v7}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v3, v0, v12, v2, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
:try_end_2c2
.catch Ljava/lang/Throwable; {:try_start_290 .. :try_end_2c2} :catch_12f
.catchall {:try_start_290 .. :try_end_2c2} :catchall_1d7
const/4 v2, 0x0
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
goto/16 :goto_24
:cond_2cb
const/4 v4, 0x0
const/4 v3, 0x0
:try_start_2cd
invoke-virtual {v6, v14}, Ljava/util/zip/ZipFile;->getInputStream(Ljava/util/zip/ZipEntry;)Ljava/io/InputStream;
move-result-object v4
invoke-virtual {v5, v13}, Ljava/util/zip/ZipFile;->getInputStream(Ljava/util/zip/ZipEntry;)Ljava/io/InputStream;
move-result-object v3
invoke-static {v4, v3, v12}, Lcom/tencent/tinker/bsdiff/BSPatch;->patchFast(Ljava/io/InputStream;Ljava/io/InputStream;Ljava/io/File;)I
:try_end_2d8
.catchall {:try_start_2cd .. :try_end_2d8} :catchall_31e
:try_start_2d8
invoke-static {v4}, 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 {v12, v9}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->verifyFileMd5(Ljava/io/File;Ljava/lang/String;)Z
move-result v3
if-nez v3, :cond_326
const-string/jumbo v3, "Tinker.BsDiffPatchInternal"
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v8, "Failed to recover diff file "
invoke-virtual {v4, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v12}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v8
invoke-virtual {v4, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
const/4 v8, 0x0
new-array v8, v8, [Ljava/lang/Object;
invoke-static {v3, v4, v8}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
invoke-virtual {v7}, Lcom/tencent/tinker/lib/tinker/Tinker;->getPatchReporter()Lcom/tencent/tinker/lib/reporter/PatchReporter;
move-result-object v3
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/ShareBsDiffPatchInfo;->name:Ljava/lang/String;
move-object/from16 v0, p3
move/from16 v1, p4
invoke-interface {v3, v0, v12, v2, v1}, Lcom/tencent/tinker/lib/reporter/PatchReporter;->onPatchTypeExtractFail(Ljava/io/File;Ljava/io/File;Ljava/lang/String;I)V
invoke-static {v12}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->safeDeleteFile(Ljava/io/File;)Z
:try_end_315
.catch Ljava/lang/Throwable; {:try_start_2d8 .. :try_end_315} :catch_12f
.catchall {:try_start_2d8 .. :try_end_315} :catchall_1d7
const/4 v2, 0x0
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
goto/16 :goto_24
:catchall_31e
move-exception v2
:try_start_31f
invoke-static {v4}, 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
throw v2
:cond_326
const-string/jumbo v2, "Tinker.BsDiffPatchInternal"
const-string/jumbo v3, "success recover bsdiff file: %s, use time: %d"
const/4 v4, 0x2
new-array v4, v4, [Ljava/lang/Object;
const/4 v9, 0x0
invoke-virtual {v12}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v12
aput-object v12, v4, v9
const/4 v9, 0x1
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v12
sub-long v10, v12, v10
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v10
aput-object v10, v4, v9
invoke-static {v2, v3, v4}, Lcom/tencent/tinker/lib/util/TinkerLog;->w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_346
.catch Ljava/lang/Throwable; {:try_start_31f .. :try_end_346} :catch_12f
.catchall {:try_start_31f .. :try_end_346} :catchall_1d7
goto/16 :goto_61
:cond_348
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
const/4 v2, 0x1
goto/16 :goto_24
:catchall_351
move-exception v2
move-object v5, v3
move-object v6, v4
goto/16 :goto_169
:catchall_356
move-exception v2
move-object v5, v3
goto/16 :goto_169
:catch_35a
move-exception v2
goto/16 :goto_132
:catch_35d
move-exception v2
move-object v4, v6
goto/16 :goto_132
.end method
.method private static patchLibraryExtractViaBsDiff(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)Z
.registers 6
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, "lib"
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
const/4 v1, 0x5
invoke-static {p0, v0, p2, p3, v1}, Lcom/tencent/tinker/lib/patch/BsDiffPatchInternal;->extractBsDiffInternals(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Ljava/io/File;I)Z
move-result v0
return v0
.end method
.method protected static tryRecoverLibraryFiles(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;->isEnabledForNativeLib()Z
move-result v0
if-nez v0, :cond_15
const-string/jumbo v0, "Tinker.BsDiffPatchInternal"
const-string/jumbo v2, "patch recover, library 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/so_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.BsDiffPatchInternal"
const-string/jumbo v2, "patch recover, library 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/BsDiffPatchInternal;->patchLibraryExtractViaBsDiff(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.BsDiffPatchInternal"
const-string/jumbo v5, "recover lib 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