SharePatchInfo.smali
.class public Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
.super Ljava/lang/Object;
# static fields
.field public static final DEFAULT_DIR:Ljava/lang/String; = "odex"
.field public static final FINGER_PRINT:Ljava/lang/String; = "print"
.field public static final MAX_EXTRACT_ATTEMPTS:I = 0x2
.field public static final NEW_VERSION:Ljava/lang/String; = "new"
.field public static final OAT_DIR:Ljava/lang/String; = "dir"
.field public static final OLD_VERSION:Ljava/lang/String; = "old"
.field private static final TAG:Ljava/lang/String; = "Tinker.PatchInfo"
# instance fields
.field public fingerPrint:Ljava/lang/String;
.field public newVersion:Ljava/lang/String;
.field public oatDir:Ljava/lang/String;
.field public oldVersion:Ljava/lang/String;
# direct methods
.method public constructor <init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.registers 5
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
iput-object p2, p0, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
iput-object p3, p0, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->fingerPrint:Ljava/lang/String;
iput-object p4, p0, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir:Ljava/lang/String;
return-void
.end method
.method private static readAndCheckProperty(Ljava/io/File;)Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
.registers 13
const/4 v1, 0x0
const/4 v0, 0x0
move-object v6, v0
move-object v3, v0
move-object v4, v0
move-object v5, v0
move v8, v1
:goto_7
const/4 v2, 0x2
if-ge v1, v2, :cond_a6
if-nez v8, :cond_a6
add-int/lit8 v7, v1, 0x1
new-instance v1, Ljava/util/Properties;
invoke-direct {v1}, Ljava/util/Properties;-><init>()V
:try_start_13
new-instance v2, Ljava/io/FileInputStream;
invoke-direct {v2, p0}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
:try_end_18
.catch Ljava/io/IOException; {:try_start_13 .. :try_end_18} :catch_41
.catchall {:try_start_13 .. :try_end_18} :catchall_62
:try_start_18
invoke-virtual {v1, v2}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V
const-string/jumbo v9, "old"
invoke-virtual {v1, v9}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v5
const-string/jumbo v9, "new"
invoke-virtual {v1, v9}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
const-string/jumbo v9, "print"
invoke-virtual {v1, v9}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
const-string/jumbo v9, "dir"
invoke-virtual {v1, v9}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String;
:try_end_36
.catch Ljava/io/IOException; {:try_start_18 .. :try_end_36} :catch_b0
.catchall {:try_start_18 .. :try_end_36} :catchall_ae
move-result-object v1
invoke-static {v2}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeQuietly(Ljava/lang/Object;)V
:goto_3a
if-eqz v5, :cond_b2
if-nez v4, :cond_69
move-object v6, v1
move v1, v7
goto :goto_7
:catch_41
move-exception v1
move-object v2, v0
:goto_43
:try_start_43
const-string/jumbo v9, "Tinker.PatchInfo"
new-instance v10, Ljava/lang/StringBuilder;
invoke-direct {v10}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v11, "read property failed, e:"
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v10
invoke-virtual {v10, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v9, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_5d
.catchall {:try_start_43 .. :try_end_5d} :catchall_ae
invoke-static {v2}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeQuietly(Ljava/lang/Object;)V
move-object v1, v6
goto :goto_3a
:catchall_62
move-exception v1
move-object v2, v0
move-object v0, v1
:goto_65
invoke-static {v2}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeQuietly(Ljava/lang/Object;)V
throw v0
:cond_69
const-string/jumbo v2, ""
invoke-virtual {v5, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-nez v2, :cond_78
invoke-static {v5}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->checkIfMd5Valid(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_7e
:cond_78
invoke-static {v4}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->checkIfMd5Valid(Ljava/lang/String;)Z
move-result v2
if-nez v2, :cond_a0
:cond_7e
const-string/jumbo v2, "Tinker.PatchInfo"
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v9, "path info file corrupted:"
invoke-virtual {v6, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {p0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v9
invoke-virtual {v6, v9}, 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-static {v2, v6}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
move-object v6, v1
move v1, v7
goto/16 :goto_7
:cond_a0
const/4 v2, 0x1
move-object v6, v1
move v8, v2
move v1, v7
goto/16 :goto_7
:cond_a6
if-eqz v8, :cond_ad
new-instance v0, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
invoke-direct {v0, v5, v4, v3, v6}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_ad
return-object v0
:catchall_ae
move-exception v0
goto :goto_65
:catch_b0
move-exception v1
goto :goto_43
:cond_b2
move-object v6, v1
move v1, v7
goto/16 :goto_7
.end method
.method public static readAndCheckPropertyWithLock(Ljava/io/File;Ljava/io/File;)Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
.registers 7
const/4 v0, 0x0
if-eqz p0, :cond_5
if-nez p1, :cond_6
:cond_5
:goto_5
return-object v0
:cond_6
invoke-virtual {p1}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v1
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_13
invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z
:cond_13
:try_start_13
invoke-static {p1}, Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;->getFileLock(Ljava/io/File;)Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;
:try_end_16
.catch Ljava/lang/Exception; {:try_start_13 .. :try_end_16} :catch_2c
.catchall {:try_start_13 .. :try_end_16} :catchall_4b
move-result-object v1
:try_start_17
invoke-static {p0}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->readAndCheckProperty(Ljava/io/File;)Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
:try_end_1a
.catch Ljava/lang/Exception; {:try_start_17 .. :try_end_1a} :catch_50
.catchall {:try_start_17 .. :try_end_1a} :catchall_39
move-result-object v0
if-eqz v1, :cond_5
:try_start_1d
invoke-virtual {v1}, Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;->close()V
:try_end_20
.catch Ljava/io/IOException; {:try_start_1d .. :try_end_20} :catch_21
goto :goto_5
:catch_21
move-exception v1
const-string/jumbo v2, "Tinker.PatchInfo"
const-string/jumbo v3, "releaseInfoLock error"
invoke-static {v2, v3, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_5
:catch_2c
move-exception v1
move-object v4, v1
move-object v1, v0
move-object v0, v4
:goto_30
:try_start_30
new-instance v2, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v3, "readAndCheckPropertyWithLock fail"
invoke-direct {v2, v3, v0}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
:try_end_39
.catchall {:try_start_30 .. :try_end_39} :catchall_39
:catchall_39
move-exception v0
:goto_3a
if-eqz v1, :cond_3f
:try_start_3c
invoke-virtual {v1}, Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;->close()V
:try_end_3f
.catch Ljava/io/IOException; {:try_start_3c .. :try_end_3f} :catch_40
:cond_3f
:goto_3f
throw v0
:catch_40
move-exception v1
const-string/jumbo v2, "Tinker.PatchInfo"
const-string/jumbo v3, "releaseInfoLock error"
invoke-static {v2, v3, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_3f
:catchall_4b
move-exception v1
move-object v4, v1
move-object v1, v0
move-object v0, v4
goto :goto_3a
:catch_50
move-exception v0
goto :goto_30
.end method
.method private static rewritePatchInfoFile(Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;)Z
.registers 10
const/4 v0, 0x1
const/4 v1, 0x0
if-eqz p0, :cond_6
if-nez p1, :cond_8
:cond_6
move v0, v1
:cond_7
:goto_7
return v0
:cond_8
iget-object v2, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->fingerPrint:Ljava/lang/String;
invoke-static {v2}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->isNullOrNil(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_14
sget-object v2, Landroid/os/Build;->FINGERPRINT:Ljava/lang/String;
iput-object v2, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->fingerPrint:Ljava/lang/String;
:cond_14
iget-object v2, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir:Ljava/lang/String;
invoke-static {v2}, Lcom/tencent/tinker/loader/shareutil/ShareTinkerInternals;->isNullOrNil(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_21
const-string/jumbo v2, "odex"
iput-object v2, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir:Ljava/lang/String;
:cond_21
const-string/jumbo v2, "Tinker.PatchInfo"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v4, "rewritePatchInfoFile file path:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {p0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string/jumbo v4, " , oldVer:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion: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, ", newVer:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion: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, ", fingerprint:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->fingerPrint: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, ", oatDir:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir: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
invoke-static {v2, v3}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
invoke-virtual {p0}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v2
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v3
if-nez v3, :cond_80
invoke-virtual {v2}, Ljava/io/File;->mkdirs()Z
:cond_80
move v2, v1
move v3, v1
:goto_82
const/4 v4, 0x2
if-ge v2, v4, :cond_129
if-nez v3, :cond_129
add-int/lit8 v5, v2, 0x1
new-instance v2, Ljava/util/Properties;
invoke-direct {v2}, Ljava/util/Properties;-><init>()V
const-string/jumbo v3, "old"
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
invoke-virtual {v2, v3, v4}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string/jumbo v3, "new"
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
invoke-virtual {v2, v3, v4}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string/jumbo v3, "print"
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->fingerPrint:Ljava/lang/String;
invoke-virtual {v2, v3, v4}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string/jumbo v3, "dir"
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oatDir:Ljava/lang/String;
invoke-virtual {v2, v3, v4}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const/4 v4, 0x0
:try_start_af
new-instance v3, Ljava/io/FileOutputStream;
const/4 v6, 0x0
invoke-direct {v3, p0, v6}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
:try_end_b5
.catch Ljava/lang/Exception; {:try_start_af .. :try_end_b5} :catch_101
.catchall {:try_start_af .. :try_end_b5} :catchall_121
:try_start_b5
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v6, "from old version:"
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
iget-object v6, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const-string/jumbo v6, " to new version:"
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
iget-object v6, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
invoke-virtual {v4, v6}, 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-virtual {v2, v3, v4}, Ljava/util/Properties;->store(Ljava/io/OutputStream;Ljava/lang/String;)V
:try_end_db
.catch Ljava/lang/Exception; {:try_start_b5 .. :try_end_db} :catch_130
.catchall {:try_start_b5 .. :try_end_db} :catchall_12e
invoke-static {v3}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeQuietly(Ljava/lang/Object;)V
:goto_de
invoke-static {p0}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->readAndCheckProperty(Ljava/io/File;)Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;
move-result-object v2
if-eqz v2, :cond_127
iget-object v3, v2, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
iget-object v4, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->oldVersion:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v3
if-eqz v3, :cond_127
iget-object v2, v2, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
iget-object v3, p1, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->newVersion:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_127
move v2, v0
:goto_f9
if-nez v2, :cond_fe
invoke-virtual {p0}, Ljava/io/File;->delete()Z
:cond_fe
move v3, v2
move v2, v5
goto :goto_82
:catch_101
move-exception v2
move-object v3, v4
:goto_103
:try_start_103
const-string/jumbo v4, "Tinker.PatchInfo"
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v7, "write property failed, e:"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, v2}, 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
invoke-static {v4, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_11d
.catchall {:try_start_103 .. :try_end_11d} :catchall_12e
invoke-static {v3}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeQuietly(Ljava/lang/Object;)V
goto :goto_de
:catchall_121
move-exception v0
move-object v3, v4
:goto_123
invoke-static {v3}, Lcom/tencent/tinker/loader/shareutil/SharePatchFileUtil;->closeQuietly(Ljava/lang/Object;)V
throw v0
:cond_127
move v2, v1
goto :goto_f9
:cond_129
if-nez v3, :cond_7
move v0, v1
goto/16 :goto_7
:catchall_12e
move-exception v0
goto :goto_123
:catch_130
move-exception v2
goto :goto_103
.end method
.method public static rewritePatchInfoFileWithLock(Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;Ljava/io/File;)Z
.registers 7
if-eqz p0, :cond_6
if-eqz p1, :cond_6
if-nez p2, :cond_8
:cond_6
const/4 v0, 0x0
:cond_7
:goto_7
return v0
:cond_8
invoke-virtual {p2}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v0
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v1
if-nez v1, :cond_15
invoke-virtual {v0}, Ljava/io/File;->mkdirs()Z
:cond_15
const/4 v1, 0x0
:try_start_16
invoke-static {p2}, Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;->getFileLock(Ljava/io/File;)Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;
move-result-object v1
invoke-static {p0, p1}, Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;->rewritePatchInfoFile(Ljava/io/File;Lcom/tencent/tinker/loader/shareutil/SharePatchInfo;)Z
:try_end_1d
.catch Ljava/lang/Exception; {:try_start_16 .. :try_end_1d} :catch_2f
.catchall {:try_start_16 .. :try_end_1d} :catchall_39
move-result v0
if-eqz v1, :cond_7
:try_start_20
invoke-virtual {v1}, Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;->close()V
:try_end_23
.catch Ljava/io/IOException; {:try_start_20 .. :try_end_23} :catch_24
goto :goto_7
:catch_24
move-exception v1
const-string/jumbo v2, "Tinker.PatchInfo"
const-string/jumbo v3, "releaseInfoLock error"
invoke-static {v2, v3, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_7
:catch_2f
move-exception v0
:try_start_30
new-instance v2, Lcom/tencent/tinker/loader/TinkerRuntimeException;
const-string/jumbo v3, "rewritePatchInfoFileWithLock fail"
invoke-direct {v2, v3, v0}, Lcom/tencent/tinker/loader/TinkerRuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
:try_end_39
.catchall {:try_start_30 .. :try_end_39} :catchall_39
:catchall_39
move-exception v0
if-eqz v1, :cond_3f
:try_start_3c
invoke-virtual {v1}, Lcom/tencent/tinker/loader/shareutil/ShareFileLockHelper;->close()V
:try_end_3f
.catch Ljava/io/IOException; {:try_start_3c .. :try_end_3f} :catch_40
:cond_3f
:goto_3f
throw v0
:catch_40
move-exception v1
const-string/jumbo v2, "Tinker.PatchInfo"
const-string/jumbo v3, "releaseInfoLock error"
invoke-static {v2, v3, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_3f
.end method