.class Lcom/tencent/smtt/sdk/am; .super Ljava/lang/Object; # static fields .field public static a:Ljava/lang/ThreadLocal; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/lang/ThreadLocal<", "Ljava/lang/Integer;", ">;" } .end annotation .end field .field static b:Z .field private static c:Lcom/tencent/smtt/sdk/am; .field private static final h:Ljava/util/concurrent/locks/Lock; .field private static final i:Ljava/util/concurrent/locks/Lock; .field private static k:Ljava/nio/channels/FileLock; .field private static l:Landroid/os/Handler; .field private static final m:[[Ljava/lang/Long; .field private static n:Z # instance fields .field private d:I .field private e:Ljava/nio/channels/FileLock; .field private f:Ljava/io/FileOutputStream; .field private g:Z .field private j:Z # direct methods .method static constructor ()V .locals 10 new-instance v0, Ljava/util/concurrent/locks/ReentrantLock; invoke-direct {v0}, Ljava/util/concurrent/locks/ReentrantLock;->()V sput-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; new-instance v0, Ljava/util/concurrent/locks/ReentrantLock; invoke-direct {v0}, Ljava/util/concurrent/locks/ReentrantLock;->()V sput-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; const/4 v0, 0x0 sput-object v0, Lcom/tencent/smtt/sdk/am;->k:Ljava/nio/channels/FileLock; new-instance v1, Lcom/tencent/smtt/sdk/an; invoke-direct {v1}, Lcom/tencent/smtt/sdk/an;->()V sput-object v1, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; sput-object v0, Lcom/tencent/smtt/sdk/am;->l:Landroid/os/Handler; const/4 v0, 0x7 new-array v0, v0, [[Ljava/lang/Long; const/4 v1, 0x2 new-array v2, v1, [Ljava/lang/Long; const-wide/16 v3, 0x6345 invoke-static {v3, v4}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 const/4 v4, 0x0 aput-object v3, v2, v4 const-wide/32 v5, 0xaedee0 invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 const/4 v5, 0x1 aput-object v3, v2, v5 aput-object v2, v0, v4 new-array v2, v1, [Ljava/lang/Long; const-wide/16 v6, 0x635c invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v4 const-wide/32 v6, 0xb73fa0 invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v5 aput-object v2, v0, v5 new-array v2, v1, [Ljava/lang/Long; const-wide/16 v6, 0x635d invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v4 const-wide/32 v6, 0xaf4f9c invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v5 aput-object v2, v0, v1 new-array v2, v1, [Ljava/lang/Long; const-wide/16 v8, 0x635e invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v4 invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v5 const/4 v3, 0x3 aput-object v2, v0, v3 new-array v2, v1, [Ljava/lang/Long; const-wide/16 v8, 0x635f invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v4 const-wide/32 v8, 0xb74fa0 invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v5 const/4 v3, 0x4 aput-object v2, v0, v3 new-array v2, v1, [Ljava/lang/Long; const-wide/16 v8, 0x6360 invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v4 invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v3 aput-object v3, v2, v5 const/4 v3, 0x5 aput-object v2, v0, v3 new-array v1, v1, [Ljava/lang/Long; const-wide/16 v2, 0x6362 invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v2 aput-object v2, v1, v4 invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v2 aput-object v2, v1, v5 const/4 v2, 0x6 aput-object v1, v0, v2 sput-object v0, Lcom/tencent/smtt/sdk/am;->m:[[Ljava/lang/Long; sput-boolean v4, Lcom/tencent/smtt/sdk/am;->b:Z sput-boolean v4, Lcom/tencent/smtt/sdk/am;->n:Z return-void .end method .method private constructor ()V .locals 2 invoke-direct {p0}, Ljava/lang/Object;->()V const/4 v0, 0x0 iput v0, p0, Lcom/tencent/smtt/sdk/am;->d:I iput-boolean v0, p0, Lcom/tencent/smtt/sdk/am;->g:Z iput-boolean v0, p0, Lcom/tencent/smtt/sdk/am;->j:Z sget-object v0, Lcom/tencent/smtt/sdk/am;->l:Landroid/os/Handler; if-nez v0, :cond_0 new-instance v0, Lcom/tencent/smtt/sdk/ao; invoke-static {}, Lcom/tencent/smtt/sdk/al;->a()Lcom/tencent/smtt/sdk/al; move-result-object v1 invoke-virtual {v1}, Lcom/tencent/smtt/sdk/al;->getLooper()Landroid/os/Looper; move-result-object v1 invoke-direct {v0, p0, v1}, Lcom/tencent/smtt/sdk/ao;->(Lcom/tencent/smtt/sdk/am;Landroid/os/Looper;)V sput-object v0, Lcom/tencent/smtt/sdk/am;->l:Landroid/os/Handler; :cond_0 return-void .end method .method private A(Landroid/content/Context;)V .locals 2 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--deleteOldCore" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p1 const/4 v0, 0x0 invoke-static {p1, v0}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V return-void .end method .method private B(Landroid/content/Context;)V .locals 2 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--renameShareDir" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->r(Landroid/content/Context;)Ljava/io/File; move-result-object v0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object v1 if-eqz v0, :cond_1 if-nez v1, :cond_0 goto :goto_0 :cond_0 invoke-virtual {v0, v1}, Ljava/io/File;->renameTo(Ljava/io/File;)Z const/4 v0, 0x0 invoke-direct {p0, p1, v0}, Lcom/tencent/smtt/sdk/am;->f(Landroid/content/Context;Z)V :cond_1 :goto_0 return-void .end method .method private C(Landroid/content/Context;)V .locals 2 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--renameTbsCoreCopyDir" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->t(Landroid/content/Context;)Ljava/io/File; move-result-object v0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object v1 if-eqz v0, :cond_1 if-nez v1, :cond_0 goto :goto_0 :cond_0 invoke-virtual {v0, v1}, Ljava/io/File;->renameTo(Ljava/io/File;)Z const/4 v0, 0x0 invoke-direct {p0, p1, v0}, Lcom/tencent/smtt/sdk/am;->f(Landroid/content/Context;Z)V :cond_1 :goto_0 return-void .end method .method private D(Landroid/content/Context;)V .locals 3 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--clearNewTbsCore" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->r(Landroid/content/Context;)Ljava/io/File; move-result-object v0 const/4 v1, 0x0 if-eqz v0, :cond_0 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const/4 v2, 0x5 invoke-virtual {v0, v1, v2}, Lcom/tencent/smtt/sdk/ai;->b(II)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const/4 v1, -0x1 invoke-virtual {v0, v1}, Lcom/tencent/smtt/sdk/ai;->c(I)V const-string v0, "TbsInstaller::clearNewTbsCore forceSysWebViewInner!" invoke-static {p1, v0}, Lcom/tencent/smtt/sdk/QbSdk;->a(Landroid/content/Context;Ljava/lang/String;)V return-void .end method .method static declared-synchronized a()Lcom/tencent/smtt/sdk/am; .locals 3 const-class v0, Lcom/tencent/smtt/sdk/am; monitor-enter v0 :try_start_0 sget-object v1, Lcom/tencent/smtt/sdk/am;->c:Lcom/tencent/smtt/sdk/am; if-nez v1, :cond_1 const-class v1, Lcom/tencent/smtt/sdk/am; monitor-enter v1 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 sget-object v2, Lcom/tencent/smtt/sdk/am;->c:Lcom/tencent/smtt/sdk/am; if-nez v2, :cond_0 new-instance v2, Lcom/tencent/smtt/sdk/am; invoke-direct {v2}, Lcom/tencent/smtt/sdk/am;->()V sput-object v2, Lcom/tencent/smtt/sdk/am;->c:Lcom/tencent/smtt/sdk/am; :cond_0 monitor-exit v1 goto :goto_0 :catchall_0 move-exception v2 monitor-exit v1 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :try_start_2 throw v2 :cond_1 :goto_0 sget-object v1, Lcom/tencent/smtt/sdk/am;->c:Lcom/tencent/smtt/sdk/am; :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_1 monitor-exit v0 return-object v1 :catchall_1 move-exception v1 monitor-exit v0 throw v1 .end method .method private a(ILjava/lang/String;Landroid/content/Context;)V .locals 4 new-instance p1, Ljava/io/File; invoke-direct {p1, p2}, Ljava/io/File;->(Ljava/lang/String;)V invoke-virtual {p1}, Ljava/io/File;->delete()Z const-string p1, "TbsInstaller" new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v1, "Local tbs apk(" invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p2, ") is deleted!" invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 const/4 v0, 0x1 invoke-static {p1, p2, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V const-string p1, "tbs" const/4 p2, 0x0 invoke-virtual {p3, p1, p2}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p1 new-instance p2, Ljava/io/File; const-string p3, "core_unzip_tmp" invoke-direct {p2, p1, p3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {p2}, Ljava/io/File;->canRead()Z move-result p1 if-eqz p1, :cond_3 new-instance p1, Ljava/io/File; const-string p3, "tbs.conf" invoke-direct {p1, p2, p3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V new-instance p2, Ljava/util/Properties; invoke-direct {p2}, Ljava/util/Properties;->()V const/4 p3, 0x0 :try_start_0 new-instance v1, Ljava/io/FileInputStream; invoke-direct {v1, p1}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v2, Ljava/io/BufferedInputStream; invoke-direct {v2, v1}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_3 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 invoke-virtual {p2, v2}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V new-instance v1, Ljava/io/FileOutputStream; invoke-direct {v1, p1}, Ljava/io/FileOutputStream;->(Ljava/io/File;)V new-instance p1, Ljava/io/BufferedOutputStream; invoke-direct {p1, v1}, Ljava/io/BufferedOutputStream;->(Ljava/io/OutputStream;)V :try_end_1 .catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_1} :catch_2 .catchall {:try_start_1 .. :try_end_1} :catchall_2 :try_start_2 const-string v1, "tbs_local_installation" const-string v3, "true" invoke-virtual {p2, v1, v3}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object; invoke-virtual {p2, p1, p3}, Ljava/util/Properties;->store(Ljava/io/OutputStream;Ljava/lang/String;)V const-string p2, "TbsInstaller" const-string p3, "TBS_LOCAL_INSTALLATION is set!" invoke-static {p2, p3, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V :try_end_2 .catch Ljava/lang/Throwable; {:try_start_2 .. :try_end_2} :catch_1 .catchall {:try_start_2 .. :try_end_2} :catchall_0 :try_start_3 invoke-virtual {p1}, Ljava/io/BufferedOutputStream;->close()V :try_end_3 .catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_0 goto :goto_0 :catch_0 move-exception p1 invoke-virtual {p1}, Ljava/io/IOException;->printStackTrace()V :goto_0 :try_start_4 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_5 goto :goto_6 :catchall_0 move-exception p2 move-object p3, p1 goto :goto_3 :catch_1 move-exception p2 move-object p3, p1 goto :goto_1 :catch_2 move-exception p2 goto :goto_1 :catchall_1 move-exception p2 move-object v2, p3 goto :goto_3 :catch_3 move-exception p2 move-object v2, p3 :goto_1 :try_start_5 invoke-virtual {p2}, Ljava/lang/Throwable;->printStackTrace()V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_2 if-eqz p3, :cond_0 :try_start_6 invoke-virtual {p3}, Ljava/io/BufferedOutputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_4 goto :goto_2 :catch_4 move-exception p1 invoke-virtual {p1}, Ljava/io/IOException;->printStackTrace()V :cond_0 :goto_2 if-eqz v2, :cond_3 :try_start_7 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_7 .catch Ljava/io/IOException; {:try_start_7 .. :try_end_7} :catch_5 goto :goto_6 :catch_5 move-exception p1 invoke-virtual {p1}, Ljava/io/IOException;->printStackTrace()V goto :goto_6 :catchall_2 move-exception p2 :goto_3 if-eqz p3, :cond_1 :try_start_8 invoke-virtual {p3}, Ljava/io/BufferedOutputStream;->close()V :try_end_8 .catch Ljava/io/IOException; {:try_start_8 .. :try_end_8} :catch_6 goto :goto_4 :catch_6 move-exception p1 invoke-virtual {p1}, Ljava/io/IOException;->printStackTrace()V :cond_1 :goto_4 if-eqz v2, :cond_2 :try_start_9 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_9 .catch Ljava/io/IOException; {:try_start_9 .. :try_end_9} :catch_7 goto :goto_5 :catch_7 move-exception p1 invoke-virtual {p1}, Ljava/io/IOException;->printStackTrace()V :cond_2 :goto_5 throw p2 :cond_3 :goto_6 return-void .end method .method public static a(Landroid/content/Context;)V .locals 4 invoke-static {p0}, Lcom/tencent/smtt/sdk/am;->v(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_2 const-string v0, "core_unzip_tmp" invoke-static {p0, v0}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;Ljava/lang/String;)Z move-result v0 const/16 v1, 0x1a1 if-eqz v0, :cond_0 invoke-static {}, Lcom/tencent/smtt/sdk/TbsCoreLoadStat;->getInstance()Lcom/tencent/smtt/sdk/TbsCoreLoadStat; move-result-object v0 new-instance v2, Ljava/lang/Throwable; const-string v3, "TMP_TBS_UNZIP_FOLDER_NAME" invoke-direct {v2, v3}, Ljava/lang/Throwable;->(Ljava/lang/String;)V invoke-virtual {v0, p0, v1, v2}, Lcom/tencent/smtt/sdk/TbsCoreLoadStat;->a(Landroid/content/Context;ILjava/lang/Throwable;)V const-string p0, "TbsInstaller" const-string v0, "TbsInstaller-UploadIfTempCoreExistConfError INFO_TEMP_CORE_EXIST_CONF_ERROR TMP_TBS_UNZIP_FOLDER_NAME" :goto_0 invoke-static {p0, v0}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V goto :goto_1 :cond_0 const-string v0, "core_share_backup_tmp" invoke-static {p0, v0}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_1 invoke-static {}, Lcom/tencent/smtt/sdk/TbsCoreLoadStat;->getInstance()Lcom/tencent/smtt/sdk/TbsCoreLoadStat; move-result-object v0 new-instance v2, Ljava/lang/Throwable; const-string v3, "TMP_BACKUP_TBSCORE_FOLDER_NAME" invoke-direct {v2, v3}, Ljava/lang/Throwable;->(Ljava/lang/String;)V invoke-virtual {v0, p0, v1, v2}, Lcom/tencent/smtt/sdk/TbsCoreLoadStat;->a(Landroid/content/Context;ILjava/lang/Throwable;)V const-string p0, "TbsInstaller" const-string v0, "TbsInstaller-UploadIfTempCoreExistConfError INFO_TEMP_CORE_EXIST_CONF_ERROR TMP_BACKUP_TBSCORE_FOLDER_NAME" goto :goto_0 :cond_1 const-string v0, "core_copy_tmp" invoke-static {p0, v0}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;Ljava/lang/String;)Z move-result v0 if-eqz v0, :cond_2 invoke-static {}, Lcom/tencent/smtt/sdk/TbsCoreLoadStat;->getInstance()Lcom/tencent/smtt/sdk/TbsCoreLoadStat; move-result-object v0 new-instance v2, Ljava/lang/Throwable; const-string v3, "TMP_TBS_COPY_FOLDER_NAME" invoke-direct {v2, v3}, Ljava/lang/Throwable;->(Ljava/lang/String;)V invoke-virtual {v0, p0, v1, v2}, Lcom/tencent/smtt/sdk/TbsCoreLoadStat;->a(Landroid/content/Context;ILjava/lang/Throwable;)V const-string p0, "TbsInstaller" const-string v0, "TbsInstaller-UploadIfTempCoreExistConfError INFO_TEMP_CORE_EXIST_CONF_ERROR TMP_TBS_COPY_FOLDER_NAME" goto :goto_0 :cond_2 :goto_1 return-void .end method .method private a(Landroid/content/Context;Landroid/content/Context;I)V .locals 18 .annotation build Landroid/annotation/TargetApi; value = 0xb .end annotation move-object/from16 v1, p0 move-object/from16 v2, p2 move/from16 v3, p3 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v4 const/16 v5, -0x20c invoke-virtual {v4, v5}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->c(Landroid/content/Context;)Z move-result v4 if-eqz v4, :cond_0 return-void :cond_0 const-string v4, "TbsInstaller" new-instance v5, Ljava/lang/StringBuilder; invoke-direct {v5}, Ljava/lang/StringBuilder;->()V const-string v6, "TbsInstaller-copyTbsCoreInThread start! tbsCoreTargetVer is " invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v5 invoke-static {v4, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V sget v4, Landroid/os/Build$VERSION;->SDK_INT:I const/4 v5, 0x4 const/16 v6, 0xb const/4 v7, 0x0 if-lt v4, v6, :cond_1 const-string v4, "tbs_preloadx5_check_cfg_file" invoke-virtual {v2, v4, v5}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v4 goto :goto_0 :cond_1 const-string v4, "tbs_preloadx5_check_cfg_file" invoke-virtual {v2, v4, v7}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v4 :goto_0 const-string v8, "tbs_precheck_disable_version" const/4 v9, -0x1 invoke-interface {v4, v8, v9}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v4 if-ne v4, v3, :cond_2 const-string v2, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller-copyTbsCoreInThread -- version:" invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v3, " is disabled by preload_x5_check!" invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v2, v3}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v2 const/16 v3, -0x20d :goto_1 invoke-virtual {v2, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V return-void :cond_2 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->u(Landroid/content/Context;)Z move-result v4 if-nez v4, :cond_3 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v2 const/16 v3, -0x20e goto :goto_1 :cond_3 sget-object v4, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v4}, Ljava/util/concurrent/locks/Lock;->tryLock()Z move-result v4 const-string v8, "TbsInstaller" new-instance v10, Ljava/lang/StringBuilder; invoke-direct {v10}, Ljava/lang/StringBuilder;->()V const-string v11, "TbsInstaller-copyTbsCoreInThread #1 locked is " invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v10, v4}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v10 invoke-static {v8, v10}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-eqz v4, :cond_24 sget-object v4, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v4}, Ljava/util/concurrent/locks/Lock;->lock()V :try_start_0 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v4 const-string v8, "copy_core_ver" invoke-virtual {v4, v8}, Lcom/tencent/smtt/sdk/ai;->c(Ljava/lang/String;)I move-result v4 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v8 const-string v10, "copy_status" invoke-virtual {v8, v10}, Lcom/tencent/smtt/sdk/ai;->b(Ljava/lang/String;)I move-result v8 const/16 v10, -0x210 const/16 v11, 0xdc if-ne v4, v3, :cond_4 sget-object v3, Lcom/tencent/smtt/sdk/QbSdk;->l:Lcom/tencent/smtt/sdk/TbsListener; invoke-interface {v3, v11}, Lcom/tencent/smtt/sdk/TbsListener;->onInstallFinish(I)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 invoke-virtual {v3, v10}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_7 .catchall {:try_start_0 .. :try_end_0} :catchall_2 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_4 :try_start_1 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v12 const-string v13, "TbsInstaller" new-instance v14, Ljava/lang/StringBuilder; invoke-direct {v14}, Ljava/lang/StringBuilder;->()V const-string v15, "TbsInstaller-copyTbsCoreInThread tbsCoreInstalledVer=" invoke-virtual {v14, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v14, v12}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v14}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v14 invoke-static {v13, v14}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-ne v12, v3, :cond_5 sget-object v3, Lcom/tencent/smtt/sdk/QbSdk;->l:Lcom/tencent/smtt/sdk/TbsListener; invoke-interface {v3, v11}, Lcom/tencent/smtt/sdk/TbsListener;->onInstallFinish(I)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 invoke-virtual {v3, v10}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const-string v3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller-copyTbsCoreInThread return have same version is " invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v12}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 invoke-static {v3, v4}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_7 .catchall {:try_start_1 .. :try_end_1} :catchall_2 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_5 :try_start_2 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v10 invoke-virtual {v10}, Lcom/tencent/smtt/sdk/ai;->b()I move-result v10 if-lez v10, :cond_6 if-gt v3, v10, :cond_7 :cond_6 if-lez v4, :cond_8 if-le v3, v4, :cond_8 :cond_7 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->m(Landroid/content/Context;)V :cond_8 const/4 v4, 0x3 const/4 v10, 0x1 if-ne v8, v4, :cond_a if-lez v12, :cond_a if-gt v3, v12, :cond_9 const v4, 0x54c5638 if-ne v3, v4, :cond_a :cond_9 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->m(Landroid/content/Context;)V const-string v4, "TbsInstaller" const-string v8, "TbsInstaller-copyTbsCoreInThread -- update TBS....." invoke-static {v4, v8, v10}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V const/4 v8, -0x1 :cond_a invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/utils/k;->b(Landroid/content/Context;)Z move-result v4 if-nez v4, :cond_b invoke-static {}, Lcom/tencent/smtt/utils/aa;->a()J move-result-wide v3 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v5 invoke-virtual {v5}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getDownloadMinFreeSpace()J move-result-wide v5 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v7 const/16 v8, -0x211 invoke-virtual {v7, v8}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v7 const/16 v8, 0xd2 new-instance v9, Ljava/lang/StringBuilder; invoke-direct {v9}, Ljava/lang/StringBuilder;->()V const-string v10, "rom is not enough when copying tbs core! curAvailROM=" invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v9, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; const-string v3, ",minReqRom=" invoke-virtual {v9, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v9, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v7, v8, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_7 .catchall {:try_start_2 .. :try_end_2} :catchall_2 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_b if-lez v8, :cond_d :try_start_3 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v4 if-nez v4, :cond_c invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v4 iget-object v4, v4, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v9, "tbs_downloaddecouplecore" invoke-interface {v4, v9, v7}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v4 if-ne v4, v10, :cond_c invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->h(Landroid/content/Context;)I move-result v4 if-eq v3, v4, :cond_c goto :goto_2 :cond_c const-string v3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller-copyTbsCoreInThread return have copied is " invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->h(Landroid/content/Context;)I move-result v5 invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 invoke-static {v3, v4}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_7 .catchall {:try_start_3 .. :try_end_3} :catchall_2 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_d :goto_2 if-nez v8, :cond_f :try_start_4 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v4 const-string v8, "copy_retry_num" invoke-virtual {v4, v8}, Lcom/tencent/smtt/sdk/ai;->c(Ljava/lang/String;)I move-result v4 const/16 v8, 0xa if-le v4, v8, :cond_e invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v3 const/16 v4, 0xd3 const-string v5, "exceed copy retry num!" invoke-virtual {v3, v4, v5}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 const/16 v4, -0x212 invoke-virtual {v3, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_4 .catch Ljava/lang/Exception; {:try_start_4 .. :try_end_4} :catch_7 .catchall {:try_start_4 .. :try_end_4} :catchall_2 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_e :try_start_5 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v8 const-string v9, "copy_retry_num" add-int/2addr v4, v10 invoke-virtual {v8, v9, v4}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;I)V :cond_f invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object v4 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v8 if-nez v8, :cond_10 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v8 iget-object v8, v8, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v9, "tbs_downloaddecouplecore" invoke-interface {v8, v9, v7}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v8 if-ne v8, v10, :cond_10 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->n(Landroid/content/Context;)Ljava/io/File; move-result-object v8 goto :goto_3 :cond_10 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/am;->t(Landroid/content/Context;)Ljava/io/File; move-result-object v8 :goto_3 const/16 v9, 0xd5 if-eqz v4, :cond_21 if-eqz v8, :cond_21 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v12 invoke-virtual {v12, v3, v7}, Lcom/tencent/smtt/sdk/ai;->a(II)V new-instance v12, Lcom/tencent/smtt/utils/z; invoke-direct {v12}, Lcom/tencent/smtt/utils/z;->()V invoke-virtual {v12, v4}, Lcom/tencent/smtt/utils/z;->a(Ljava/io/File;)V invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v13 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v15 const/16 v5, -0x227 invoke-virtual {v15, v5}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static {v4, v8}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;Ljava/io/File;)Z move-result v5 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v15 iget-object v15, v15, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v6, "tbs_downloaddecouplecore" invoke-interface {v15, v6, v7}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v6 if-ne v6, v10, :cond_11 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsShareManager;->b(Landroid/content/Context;)V :cond_11 const-string v6, "TbsInstaller" new-instance v15, Ljava/lang/StringBuilder; invoke-direct {v15}, Ljava/lang/StringBuilder;->()V const-string v7, "TbsInstaller-copyTbsCoreInThread time=" invoke-virtual {v15, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v16 const/4 v7, 0x0 sub-long v13, v16, v13 invoke-virtual {v15, v13, v14}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v15}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v7 invoke-static {v6, v7}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-eqz v5, :cond_20 invoke-virtual {v12, v4}, Lcom/tencent/smtt/utils/z;->b(Ljava/io/File;)V invoke-virtual {v12}, Lcom/tencent/smtt/utils/z;->a()Z move-result v4 if-nez v4, :cond_12 const-string v3, "TbsInstaller" const-string v4, "TbsInstaller-copyTbsCoreInThread copy-verify fail!" invoke-static {v3, v4}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {v8, v10}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v3 const-string v4, "TbsCopy-Verify fail after copying tbs core!" invoke-virtual {v3, v9, v4}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 const/16 v4, -0x213 invoke-virtual {v3, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_5 .catch Ljava/lang/Exception; {:try_start_5 .. :try_end_5} :catch_7 .catchall {:try_start_5 .. :try_end_5} :catchall_2 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_12 const/4 v4, 0x0 :try_start_6 new-instance v5, Ljava/io/File; const-string v6, "1" invoke-direct {v5, v8, v6}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V new-instance v6, Ljava/util/Properties; invoke-direct {v6}, Ljava/util/Properties;->()V :try_end_6 .catch Ljava/lang/Exception; {:try_start_6 .. :try_end_6} :catch_3 .catchall {:try_start_6 .. :try_end_6} :catchall_0 :try_start_7 invoke-virtual {v5}, Ljava/io/File;->exists()Z move-result v7 if-eqz v7, :cond_13 new-instance v7, Ljava/io/FileInputStream; invoke-direct {v7, v5}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v5, Ljava/io/BufferedInputStream; invoke-direct {v5, v7}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_7 .catch Ljava/lang/Exception; {:try_start_7 .. :try_end_7} :catch_2 .catchall {:try_start_7 .. :try_end_7} :catchall_0 :try_start_8 invoke-virtual {v6, v5}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V :try_end_8 .catch Ljava/lang/Exception; {:try_start_8 .. :try_end_8} :catch_0 .catchall {:try_start_8 .. :try_end_8} :catchall_1 move-object v4, v5 const/4 v5, 0x1 goto :goto_4 :catch_0 move-exception v0 goto :goto_5 :cond_13 const/4 v5, 0x0 :goto_4 if-eqz v4, :cond_15 :try_start_9 invoke-virtual {v4}, Ljava/io/BufferedInputStream;->close()V :try_end_9 .catch Ljava/io/IOException; {:try_start_9 .. :try_end_9} :catch_1 .catch Ljava/lang/Exception; {:try_start_9 .. :try_end_9} :catch_7 .catchall {:try_start_9 .. :try_end_9} :catchall_2 goto :goto_7 :catch_1 move-exception v0 move-object v4, v0 :try_start_a invoke-virtual {v4}, Ljava/io/IOException;->printStackTrace()V :try_end_a .catch Ljava/lang/Exception; {:try_start_a .. :try_end_a} :catch_7 .catchall {:try_start_a .. :try_end_a} :catchall_2 goto :goto_7 :catch_2 move-exception v0 move-object v5, v4 goto :goto_5 :catchall_0 move-exception v0 move-object v3, v0 goto/16 :goto_10 :catch_3 move-exception v0 move-object v5, v4 move-object v6, v5 :goto_5 move-object v4, v0 :try_start_b invoke-virtual {v4}, Ljava/lang/Exception;->printStackTrace()V :try_end_b .catchall {:try_start_b .. :try_end_b} :catchall_1 if-eqz v5, :cond_14 :try_start_c invoke-virtual {v5}, Ljava/io/BufferedInputStream;->close()V :try_end_c .catch Ljava/io/IOException; {:try_start_c .. :try_end_c} :catch_4 .catch Ljava/lang/Exception; {:try_start_c .. :try_end_c} :catch_7 .catchall {:try_start_c .. :try_end_c} :catchall_2 goto :goto_6 :catch_4 move-exception v0 move-object v4, v0 :try_start_d invoke-virtual {v4}, Ljava/io/IOException;->printStackTrace()V :cond_14 :goto_6 const/4 v5, 0x1 :cond_15 :goto_7 if-eqz v5, :cond_19 invoke-virtual {v8}, Ljava/io/File;->listFiles()[Ljava/io/File; move-result-object v4 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v7 const/16 v12, -0x228 invoke-virtual {v7, v12}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const/4 v7, 0x0 :goto_8 array-length v12, v4 if-ge v7, v12, :cond_19 aget-object v12, v4, v7 const-string v13, "1" invoke-virtual {v12}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v14 invoke-virtual {v13, v14}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v13 if-nez v13, :cond_18 invoke-virtual {v12}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v13 const-string v14, ".dex" invoke-virtual {v13, v14}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z move-result v13 if-nez v13, :cond_18 const-string v13, "tbs.conf" invoke-virtual {v12}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v14 invoke-virtual {v13, v14}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v13 if-nez v13, :cond_18 invoke-virtual {v12}, Ljava/io/File;->isDirectory()Z move-result v13 if-nez v13, :cond_18 invoke-virtual {v12}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v13 const-string v14, ".prof" invoke-virtual {v13, v14}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z move-result v13 if-eqz v13, :cond_16 goto :goto_9 :cond_16 invoke-static {v12}, Lcom/tencent/smtt/utils/a;->a(Ljava/io/File;)Ljava/lang/String; move-result-object v13 invoke-virtual {v12}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v14 const-string v15, "" invoke-virtual {v6, v14, v15}, Ljava/util/Properties;->getProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object v14 const-string v15, "" invoke-virtual {v14, v15}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v15 if-nez v15, :cond_17 invoke-virtual {v13, v14}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v15 if-eqz v15, :cond_17 const-string v13, "TbsInstaller" new-instance v14, Ljava/lang/StringBuilder; invoke-direct {v14}, Ljava/lang/StringBuilder;->()V const-string v15, "md5_check_success for (" invoke-virtual {v14, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v12}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v12 invoke-virtual {v14, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v12, ")" invoke-virtual {v14, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v14}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v12 invoke-static {v13, v12}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V goto :goto_9 :cond_17 const-string v4, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "md5_check_failure for (" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v12}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v7 invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v7, ")" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v7, " targetMd5:" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6, v14}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v7, ", realMd5:" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v4, v6}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V const/4 v4, 0x0 goto :goto_a :cond_18 :goto_9 add-int/lit8 v7, v7, 0x1 goto/16 :goto_8 :cond_19 const/4 v4, 0x1 :goto_a const-string v6, "TbsInstaller" new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V const-string v12, "copyTbsCoreInThread - md5_check_success:" invoke-virtual {v7, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v4}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v7 invoke-static {v6, v7}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-eqz v5, :cond_1a if-nez v4, :cond_1a const-string v3, "TbsInstaller" const-string v4, "copyTbsCoreInThread - md5 incorrect -> delete destTmpDir!" invoke-static {v3, v4}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V invoke-static {v8, v10}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v3 const-string v4, "TbsCopy-Verify md5 fail after copying tbs core!" invoke-virtual {v3, v9, v4}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 const/16 v4, -0x214 invoke-virtual {v3, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_d .catch Ljava/lang/Exception; {:try_start_d .. :try_end_d} :catch_7 .catchall {:try_start_d .. :try_end_d} :catchall_2 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_1a :try_start_e const-string v4, "TbsInstaller" const-string v5, "TbsInstaller-copyTbsCoreInThread success!" invoke-static {v4, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-direct {v1, v2, v10}, Lcom/tencent/smtt/sdk/am;->f(Landroid/content/Context;Z)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ag;->b(Landroid/content/Context;)Ljava/io/File; move-result-object v4 if-eqz v4, :cond_1c invoke-virtual {v4}, Ljava/io/File;->exists()Z move-result v5 if-eqz v5, :cond_1c new-instance v5, Ljava/io/File; invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsDownloader;->getOverSea(Landroid/content/Context;)Z move-result v6 if-eqz v6, :cond_1b const-string v6, "x5.oversea.tbs.org" goto :goto_b :cond_1b const-string v6, "x5.tbs.org" :goto_b invoke-direct {v5, v4, v6}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-static {v5, v2}, Lcom/tencent/smtt/sdk/ag;->a(Ljava/io/File;Landroid/content/Context;)V :cond_1c invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v4 invoke-virtual {v4, v3, v10}, Lcom/tencent/smtt/sdk/ai;->a(II)V iget-boolean v4, v1, Lcom/tencent/smtt/sdk/am;->j:Z if-eqz v4, :cond_1d invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v4 const-string v5, "continueInstallWithout core success" :goto_c invoke-virtual {v4, v11, v5}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V goto :goto_d :cond_1d invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v4 const-string v5, "success" goto :goto_c :goto_d invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v4 const/16 v5, -0x215 invoke-virtual {v4, v5}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const-string v4, "TbsInstaller" new-instance v5, Ljava/lang/StringBuilder; invoke-direct {v5}, Ljava/lang/StringBuilder;->()V const-string v6, "TbsInstaller-copyTbsCoreInThread success -- version:" invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v5 invoke-static {v4, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V sget v4, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v5, 0xb if-lt v4, v5, :cond_1e const-string v4, "tbs_preloadx5_check_cfg_file" const/4 v5, 0x4 invoke-virtual {v2, v4, v5}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v4 const/4 v5, 0x0 goto :goto_e :cond_1e const-string v4, "tbs_preloadx5_check_cfg_file" const/4 v5, 0x0 invoke-virtual {v2, v4, v5}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v4 :try_end_e .catch Ljava/lang/Exception; {:try_start_e .. :try_end_e} :catch_7 .catchall {:try_start_e .. :try_end_e} :catchall_2 :goto_e :try_start_f invoke-interface {v4}, Landroid/content/SharedPreferences;->edit()Landroid/content/SharedPreferences$Editor; move-result-object v4 const-string v6, "tbs_preload_x5_counter" invoke-interface {v4, v6, v5}, Landroid/content/SharedPreferences$Editor;->putInt(Ljava/lang/String;I)Landroid/content/SharedPreferences$Editor; const-string v6, "tbs_preload_x5_recorder" invoke-interface {v4, v6, v5}, Landroid/content/SharedPreferences$Editor;->putInt(Ljava/lang/String;I)Landroid/content/SharedPreferences$Editor; const-string v5, "tbs_preload_x5_version" invoke-interface {v4, v5, v3}, Landroid/content/SharedPreferences$Editor;->putInt(Ljava/lang/String;I)Landroid/content/SharedPreferences$Editor; invoke-interface {v4}, Landroid/content/SharedPreferences$Editor;->commit()Z :try_end_f .catch Ljava/lang/Throwable; {:try_start_f .. :try_end_f} :catch_5 .catch Ljava/lang/Exception; {:try_start_f .. :try_end_f} :catch_7 .catchall {:try_start_f .. :try_end_f} :catchall_2 goto :goto_f :catch_5 move-exception v0 move-object v3, v0 :try_start_10 const-string v4, "TbsInstaller" new-instance v5, Ljava/lang/StringBuilder; invoke-direct {v5}, Ljava/lang/StringBuilder;->()V const-string v6, "Init tbs_preload_x5_counter#2 exception:" invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {v3}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object v3 invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v4, v3}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V :goto_f invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/utils/aa;->a(Landroid/content/Context;)Z :try_end_10 .catch Ljava/lang/Exception; {:try_start_10 .. :try_end_10} :catch_7 .catchall {:try_start_10 .. :try_end_10} :catchall_2 goto :goto_12 :catchall_1 move-exception v0 move-object v3, v0 move-object v4, v5 :goto_10 if-eqz v4, :cond_1f :try_start_11 invoke-virtual {v4}, Ljava/io/BufferedInputStream;->close()V :try_end_11 .catch Ljava/io/IOException; {:try_start_11 .. :try_end_11} :catch_6 .catch Ljava/lang/Exception; {:try_start_11 .. :try_end_11} :catch_7 .catchall {:try_start_11 .. :try_end_11} :catchall_2 goto :goto_11 :catch_6 move-exception v0 move-object v4, v0 :try_start_12 invoke-virtual {v4}, Ljava/io/IOException;->printStackTrace()V :cond_1f :goto_11 throw v3 :cond_20 const-string v4, "TbsInstaller" const-string v5, "TbsInstaller-copyTbsCoreInThread fail!" invoke-static {v4, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v4 const/4 v5, 0x2 invoke-virtual {v4, v3, v5}, Lcom/tencent/smtt/sdk/ai;->a(II)V const/4 v3, 0x0 invoke-static {v8, v3}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 const/16 v4, -0x216 invoke-virtual {v3, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v3 const/16 v4, 0xd4 const-string v5, "copy fail!" invoke-virtual {v3, v4, v5}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V goto :goto_12 :cond_21 if-nez v4, :cond_22 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v3 const-string v4, "src-dir is null when copying tbs core!" invoke-virtual {v3, v9, v4}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 const/16 v4, -0x217 invoke-virtual {v3, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :cond_22 if-nez v8, :cond_23 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v3 const/16 v4, 0xd6 const-string v5, "dst-dir is null when copying tbs core!" invoke-virtual {v3, v4, v5}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v3 const/16 v4, -0x218 invoke-virtual {v3, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_12 .catch Ljava/lang/Exception; {:try_start_12 .. :try_end_12} :catch_7 .catchall {:try_start_12 .. :try_end_12} :catchall_2 :cond_23 :goto_12 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V goto :goto_14 :catchall_2 move-exception v0 move-object v2, v0 goto :goto_13 :catch_7 move-exception v0 move-object v3, v0 :try_start_13 invoke-static/range {p2 .. p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v2 const/16 v4, 0xd7 invoke-virtual {v3}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v4, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v2 const/16 v3, -0x219 invoke-virtual {v2, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_13 .catchall {:try_start_13 .. :try_end_13} :catchall_2 goto :goto_12 :goto_13 sget-object v3, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v3}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v3, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v3}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V throw v2 :cond_24 invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v2 const/16 v3, -0x21a invoke-virtual {v2, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :goto_14 return-void .end method .method static synthetic a(Lcom/tencent/smtt/sdk/am;Landroid/content/Context;Landroid/content/Context;I)V .locals 0 invoke-direct {p0, p1, p2, p3}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Landroid/content/Context;I)V return-void .end method .method static synthetic a(Lcom/tencent/smtt/sdk/am;Landroid/content/Context;Ljava/lang/String;I)V .locals 0 invoke-direct {p0, p1, p2, p3}, Lcom/tencent/smtt/sdk/am;->b(Landroid/content/Context;Ljava/lang/String;I)V return-void .end method .method private a(Landroid/content/Context;Ljava/io/File;)Z .locals 1 const/4 v0, 0x0 invoke-direct {p0, p1, p2, v0}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Ljava/io/File;Z)Z move-result p1 return p1 .end method .method private a(Landroid/content/Context;Ljava/io/File;Z)Z .locals 9 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller-unzipTbs start" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p2}, Lcom/tencent/smtt/utils/k;->c(Ljava/io/File;)Z move-result v0 const/4 v1, 0x0 if-nez v0, :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p2 const/16 p3, 0xcc const-string v0, "apk is invalid!" invoke-virtual {p2, p3, v0}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p1 const/16 p2, -0x208 :goto_0 invoke-virtual {p1, p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V return v1 :cond_0 const/4 v0, 0x1 :try_start_0 const-string v2, "tbs" invoke-virtual {p1, v2, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object v2 if-eqz p3, :cond_1 new-instance v3, Ljava/io/File; const-string v4, "core_share_decouple" invoke-direct {v3, v2, v4}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V goto :goto_1 :cond_1 new-instance v3, Ljava/io/File; const-string v4, "core_unzip_tmp" invoke-direct {v3, v2, v4}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V :goto_1 invoke-virtual {v3}, Ljava/io/File;->exists()Z move-result v2 if-eqz v2, :cond_2 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v2 iget-object v2, v2, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v4, "tbs_downloaddecouplecore" invoke-interface {v2, v4, v1}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v2 if-eq v2, v0, :cond_2 invoke-static {v3}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_2 :catch_0 move-exception v2 const-string v3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller-unzipTbs -- delete unzip folder if exists exception" invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {v2}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object v2 invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v3, v2}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V :cond_2 :goto_2 if-eqz p3, :cond_3 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->s(Landroid/content/Context;)Ljava/io/File; move-result-object v2 goto :goto_3 :cond_3 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->r(Landroid/content/Context;)Ljava/io/File; move-result-object v2 :goto_3 if-nez v2, :cond_4 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p2 const/16 p3, 0xcd const-string v0, "tmp unzip dir is null!" invoke-virtual {p2, p3, v0}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p1 const/16 p2, -0x209 goto :goto_0 :cond_4 const/16 v3, -0x20b :try_start_1 invoke-static {v2}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;)Z if-eqz p3, :cond_5 invoke-static {v2, v0}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V :cond_5 invoke-static {p2, v2}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Ljava/io/File;)Z move-result p2 if-eqz p3, :cond_8 invoke-virtual {v2}, Ljava/io/File;->list()[Ljava/lang/String; move-result-object v4 const/4 v5, 0x0 :goto_4 array-length v6, v4 if-ge v5, v6, :cond_7 new-instance v6, Ljava/io/File; aget-object v7, v4, v5 invoke-direct {v6, v2, v7}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v6}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v7 const-string v8, ".dex" invoke-virtual {v7, v8}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z move-result v7 if-eqz v7, :cond_6 invoke-virtual {v6}, Ljava/io/File;->delete()Z :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_4 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_2 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :cond_6 add-int/lit8 v5, v5, 0x1 goto :goto_4 :cond_7 :try_start_2 invoke-static {p1}, Lcom/tencent/smtt/sdk/am;->q(Landroid/content/Context;)Ljava/io/File; move-result-object v4 new-instance v5, Ljava/io/File; const-string v6, "x5.tbs" invoke-direct {v5, v4, v6}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v5}, Ljava/io/File;->delete()Z :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_1 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_4 .catchall {:try_start_2 .. :try_end_2} :catchall_0 goto :goto_5 :catch_1 nop :cond_8 :goto_5 if-nez p2, :cond_9 :try_start_3 invoke-static {v2}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p3 const/16 v4, -0x20a invoke-virtual {p3, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const-string p3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "copyFileIfChanged -- delete tmpTbsCoreUnzipDir#1! exist:" invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result v5 invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 invoke-static {p3, v4}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V goto :goto_6 :cond_9 invoke-direct {p0, p1, v0}, Lcom/tencent/smtt/sdk/am;->f(Landroid/content/Context;Z)V if-eqz p3, :cond_a invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->n(Landroid/content/Context;)Ljava/io/File; move-result-object p3 invoke-static {p3, v0}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-virtual {v2, p3}, Ljava/io/File;->renameTo(Ljava/io/File;)Z invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->b(Landroid/content/Context;)V :try_end_3 .catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_4 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_2 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :cond_a :goto_6 const-string p1, "TbsInstaller" const-string p3, "TbsInstaller-unzipTbs done" invoke-static {p1, p3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return p2 :catchall_0 move-exception p1 goto/16 :goto_b :catch_2 move-exception p2 :try_start_4 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p3 invoke-virtual {p3, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 const/16 p3, 0xcf invoke-virtual {p1, p3, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/Throwable;)V if-eqz v2, :cond_b invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p1 :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 if-eqz p1, :cond_b goto :goto_7 :cond_b const/4 v0, 0x0 :goto_7 if-eqz v0, :cond_c if-eqz v2, :cond_c :try_start_5 invoke-static {v2}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V const-string p1, "TbsInstaller" new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V const-string p3, "copyFileIfChanged -- delete tmpTbsCoreUnzipDir#2! exist:" invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p3 invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V :try_end_5 .catch Ljava/lang/Throwable; {:try_start_5 .. :try_end_5} :catch_3 goto :goto_8 :catch_3 move-exception p1 const-string p2, "TbsInstaller" new-instance p3, Ljava/lang/StringBuilder; invoke-direct {p3}, Ljava/lang/StringBuilder;->()V const-string v0, "copyFileIfChanged -- delete tmpTbsCoreUnzipDir#2! exception:" invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {p1}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object p1 invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {p2, p1}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V :cond_c :goto_8 const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-unzipTbs done" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v1 :catch_4 move-exception p2 :try_start_6 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p3 invoke-virtual {p3, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 const/16 p3, 0xce invoke-virtual {p1, p3, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/Throwable;)V if-eqz v2, :cond_d invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p1 :try_end_6 .catchall {:try_start_6 .. :try_end_6} :catchall_0 if-eqz p1, :cond_d goto :goto_9 :cond_d const/4 v0, 0x0 :goto_9 if-eqz v0, :cond_e if-eqz v2, :cond_e :try_start_7 invoke-static {v2}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V const-string p1, "TbsInstaller" new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V const-string p3, "copyFileIfChanged -- delete tmpTbsCoreUnzipDir#2! exist:" invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p3 invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V :try_end_7 .catch Ljava/lang/Throwable; {:try_start_7 .. :try_end_7} :catch_5 goto :goto_a :catch_5 move-exception p1 const-string p2, "TbsInstaller" new-instance p3, Ljava/lang/StringBuilder; invoke-direct {p3}, Ljava/lang/StringBuilder;->()V const-string v0, "copyFileIfChanged -- delete tmpTbsCoreUnzipDir#2! exception:" invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {p1}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object p1 invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {p2, p1}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V :cond_e :goto_a const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-unzipTbs done" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v1 :goto_b const-string p2, "TbsInstaller" const-string p3, "TbsInstaller-unzipTbs done" invoke-static {p2, p3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V throw p1 .end method .method private b(Landroid/content/Context;Ljava/lang/String;I)V .locals 16 .annotation build Landroid/annotation/TargetApi; value = 0xb .end annotation move-object/from16 v1, p0 move-object/from16 v2, p1 move-object/from16 v3, p2 move/from16 v4, p3 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v5, -0x1f5 invoke-virtual {v0, v5}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->c(Landroid/content/Context;)Z move-result v0 const/4 v5, 0x1 if-eqz v0, :cond_0 const-string v0, "TbsInstaller" const-string v3, "isTbsLocalInstalled --> no installation!" invoke-static {v0, v3, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v2, -0x1f6 invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V return-void :cond_0 const-string v0, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "TbsInstaller-installTbsCoreInThread tbsApkPath=" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v0, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "TbsInstaller-installTbsCoreInThread tbsCoreTargetVer=" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v0, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "TbsInstaller-continueInstallTbsCore currentProcessName=" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual/range {p1 .. p1}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo; move-result-object v7 iget-object v7, v7, Landroid/content/pm/ApplicationInfo;->processName:Ljava/lang/String; invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v0, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "TbsInstaller-installTbsCoreInThread currentProcessId=" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Landroid/os/Process;->myPid()I move-result v7 invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v0, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "TbsInstaller-installTbsCoreInThread currentThreadName=" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread; move-result-object v7 invoke-virtual {v7}, Ljava/lang/Thread;->getName()Ljava/lang/String; move-result-object v7 invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v0, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V sget v0, Landroid/os/Build$VERSION;->SDK_INT:I const/4 v6, 0x4 const/16 v7, 0xb const/4 v8, 0x0 if-lt v0, v7, :cond_1 const-string v0, "tbs_preloadx5_check_cfg_file" invoke-virtual {v2, v0, v6}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v0 goto :goto_0 :cond_1 const-string v0, "tbs_preloadx5_check_cfg_file" invoke-virtual {v2, v0, v8}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v0 :goto_0 const-string v9, "tbs_precheck_disable_version" const/4 v10, -0x1 invoke-interface {v0, v9, v10}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v0 if-ne v0, v4, :cond_2 const-string v0, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller-installTbsCoreInThread -- version:" invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v4, " is disabled by preload_x5_check!" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v0, v3}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v2, -0x1f7 invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V return-void :cond_2 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/utils/k;->b(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_3 invoke-static {}, Lcom/tencent/smtt/utils/aa;->a()J move-result-wide v3 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 invoke-virtual {v0}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getDownloadMinFreeSpace()J move-result-wide v5 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v7, -0x1f8 invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const/16 v2, 0xd2 new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V const-string v8, "rom is not enough when installing tbs core! curAvailROM=" invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; const-string v3, ",minReqRom=" invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v0, v2, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V return-void :cond_3 invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->u(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_4 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v2, -0x1f9 invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V return-void :cond_4 sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->tryLock()Z move-result v0 const-string v9, "TbsInstaller" new-instance v11, Ljava/lang/StringBuilder; invoke-direct {v11}, Ljava/lang/StringBuilder;->()V const-string v12, "TbsInstaller-installTbsCoreInThread locked =" invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v11, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v11 invoke-static {v9, v11}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-eqz v0, :cond_2a invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v9, -0x1fb invoke-virtual {v0, v9}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->lock()V :try_start_0 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const-string v9, "copy_core_ver" invoke-virtual {v0, v9}, Lcom/tencent/smtt/sdk/ai;->c(Ljava/lang/String;)I move-result v0 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v9 invoke-virtual {v9}, Lcom/tencent/smtt/sdk/ai;->b()I move-result v9 const-string v11, "TbsInstaller" new-instance v12, Ljava/lang/StringBuilder; invoke-direct {v12}, Ljava/lang/StringBuilder;->()V const-string v13, "TbsInstaller-installTbsCoreInThread tbsCoreCopyVer =" invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v12, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v12 invoke-static {v11, v12}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v11, "TbsInstaller" new-instance v12, Ljava/lang/StringBuilder; invoke-direct {v12}, Ljava/lang/StringBuilder;->()V const-string v13, "TbsInstaller-installTbsCoreInThread tbsCoreInstallVer =" invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v12, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v12 invoke-static {v11, v12}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v11, "TbsInstaller" new-instance v12, Ljava/lang/StringBuilder; invoke-direct {v12}, Ljava/lang/StringBuilder;->()V const-string v13, "TbsInstaller-installTbsCoreInThread tbsCoreTargetVer =" invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v12, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v12 invoke-static {v11, v12}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-lez v9, :cond_5 if-gt v4, v9, :cond_6 :cond_5 if-lez v0, :cond_7 if-le v4, v0, :cond_7 :cond_6 invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->m(Landroid/content/Context;)V :cond_7 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0}, Lcom/tencent/smtt/sdk/ai;->c()I move-result v0 invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v9 const-string v11, "TbsInstaller" new-instance v12, Ljava/lang/StringBuilder; invoke-direct {v12}, Ljava/lang/StringBuilder;->()V const-string v13, "TbsInstaller-installTbsCoreInThread installStatus1=" invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v12, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v12 invoke-static {v11, v12}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v11, "TbsInstaller" new-instance v12, Ljava/lang/StringBuilder; invoke-direct {v12}, Ljava/lang/StringBuilder;->()V const-string v13, "TbsInstaller-installTbsCoreInThread tbsCoreInstalledVer=" invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v12, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v12 invoke-static {v11, v12}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const v11, 0x54c5638 const/4 v12, 0x2 if-ltz v0, :cond_8 if-ge v0, v12, :cond_8 const-string v9, "TbsInstaller" const-string v10, "TbsInstaller-installTbsCoreInThread -- retry....." invoke-static {v9, v10, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V const/4 v9, 0x1 goto :goto_1 :cond_8 const/4 v13, 0x3 if-ne v0, v13, :cond_a if-lez v9, :cond_a if-gt v4, v9, :cond_9 if-ne v4, v11, :cond_a :cond_9 invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->m(Landroid/content/Context;)V const-string v0, "TbsInstaller" const-string v9, "TbsInstaller-installTbsCoreInThread -- update TBS....." invoke-static {v0, v9, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V const/4 v0, -0x1 :cond_a const/4 v9, 0x0 :goto_1 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v10 const/16 v13, -0x1fc invoke-virtual {v10, v13}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const-string v10, "TbsInstaller" new-instance v13, Ljava/lang/StringBuilder; invoke-direct {v13}, Ljava/lang/StringBuilder;->()V const-string v14, "TbsInstaller-installTbsCoreInThread installStatus2=" invoke-virtual {v13, v14}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v13, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v13}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v13 invoke-static {v10, v13}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const/16 v10, -0x1ff const/16 v13, 0xca const/16 v14, 0xa if-ge v0, v5, :cond_1c const-string v15, "TbsInstaller" const-string v11, "STEP 2/2 begin installation....." invoke-static {v15, v11, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v11 const/16 v15, -0x1fd invoke-virtual {v11, v15}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V if-eqz v9, :cond_c invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v11 const-string v15, "unzip_retry_num" invoke-virtual {v11, v15}, Lcom/tencent/smtt/sdk/ai;->c(Ljava/lang/String;)I move-result v11 if-le v11, v14, :cond_b invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const/16 v3, 0xc9 const-string v4, "exceed unzip retry num!" invoke-virtual {v0, v3, v4}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-direct/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->D(Landroid/content/Context;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v2, -0x1fe invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_b :try_start_1 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v15 add-int/2addr v11, v5 invoke-virtual {v15, v11}, Lcom/tencent/smtt/sdk/ai;->b(I)V :cond_c if-nez v3, :cond_d invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v11 const-string v15, "install_apk_path" invoke-virtual {v11, v15}, Lcom/tencent/smtt/sdk/ai;->d(Ljava/lang/String;)Ljava/lang/String; move-result-object v11 if-nez v11, :cond_e invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const-string v3, "apk path is null!" invoke-virtual {v0, v13, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 invoke-virtual {v0, v10}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_d move-object v11, v3 :cond_e :try_start_2 const-string v10, "TbsInstaller" new-instance v13, Ljava/lang/StringBuilder; invoke-direct {v13}, Ljava/lang/StringBuilder;->()V const-string v15, "TbsInstaller-installTbsCoreInThread apkPath =" invoke-virtual {v13, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v13, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v13}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v13 invoke-static {v10, v13}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {v1, v2, v11}, Lcom/tencent/smtt/sdk/am;->b(Landroid/content/Context;Ljava/lang/String;)I move-result v10 if-nez v10, :cond_f invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v3, -0x200 invoke-virtual {v0, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const/16 v2, 0xcb const-string v3, "apk version is 0!" invoke-virtual {v0, v2, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_f :try_start_3 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v13 const-string v15, "install_apk_path" invoke-virtual {v13, v15, v11}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v13 invoke-virtual {v13, v10, v8}, Lcom/tencent/smtt/sdk/ai;->b(II)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v13 const/16 v15, -0x224 invoke-virtual {v13, v15}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v13 iget-object v13, v13, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v15, "tbs_downloaddecouplecore" invoke-interface {v13, v15, v8}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v13 const/16 v15, 0xcf if-ne v13, v5, :cond_10 new-instance v13, Ljava/io/File; invoke-direct {v13, v11}, Ljava/io/File;->(Ljava/lang/String;)V invoke-direct {v1, v2, v13, v5}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Ljava/io/File;Z)Z move-result v11 if-nez v11, :cond_11 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const-string v2, "unzipTbsApk failed" sget-object v3, Lcom/tencent/smtt/sdk/TbsLogReport$EventType;->TYPE_INSTALL_DECOUPLE:Lcom/tencent/smtt/sdk/TbsLogReport$EventType; invoke-virtual {v0, v15, v2, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;Lcom/tencent/smtt/sdk/TbsLogReport$EventType;)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_10 :try_start_4 new-instance v13, Ljava/io/File; invoke-direct {v13, v11}, Ljava/io/File;->(Ljava/lang/String;)V invoke-direct {v1, v2, v13}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Ljava/io/File;)Z move-result v11 if-nez v11, :cond_11 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const-string v2, "unzipTbsApk failed" invoke-virtual {v0, v15, v2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_11 if-eqz v9, :cond_13 :try_start_5 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v11 const-string v13, "unlzma_status" invoke-virtual {v11, v13}, Lcom/tencent/smtt/sdk/ai;->b(Ljava/lang/String;)I move-result v11 const/4 v13, 0x5 if-le v11, v13, :cond_12 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const/16 v3, 0xdf const-string v4, "exceed unlzma retry num!" invoke-virtual {v0, v3, v4}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v3, -0x229 invoke-virtual {v0, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-direct/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->D(Landroid/content/Context;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ag;->c(Landroid/content/Context;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 iget-object v0, v0, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->a:Ljava/util/Map; const-string v3, "tbs_needdownload" invoke-static {v5}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v4 invoke-interface {v0, v3, v4}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 iget-object v0, v0, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->a:Ljava/util/Map; const-string v3, "request_full_package" invoke-static {v5}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v4 invoke-interface {v0, v3, v4}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 invoke-virtual {v0}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->commit()V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_12 :try_start_6 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v13 add-int/2addr v11, v5 invoke-virtual {v13, v11}, Lcom/tencent/smtt/sdk/ai;->d(I)V :cond_13 const-string v11, "TbsInstaller" const-string v13, "unlzma begin" invoke-static {v11, v13}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance()Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v11 iget-object v11, v11, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v13, "tbs_responsecode" invoke-interface {v11, v13, v8}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v11 invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v13 if-eqz v13, :cond_1b const-string v13, "can_unlzma" const/4 v15, 0x0 invoke-static {v2, v13, v15}, Lcom/tencent/smtt/sdk/QbSdk;->a(Landroid/content/Context;Ljava/lang/String;Landroid/os/Bundle;)Ljava/lang/Object; move-result-object v13 if-eqz v13, :cond_14 instance-of v15, v13, Ljava/lang/Boolean; if-eqz v15, :cond_14 check-cast v13, Ljava/lang/Boolean; invoke-virtual {v13}, Ljava/lang/Boolean;->booleanValue()Z move-result v13 goto :goto_2 :cond_14 const/4 v13, 0x0 :goto_2 if-eqz v13, :cond_1b new-instance v13, Landroid/os/Bundle; invoke-direct {v13}, Landroid/os/Bundle;->()V const-string v15, "responseCode" invoke-virtual {v13, v15, v11}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v11 iget-object v11, v11, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v15, "tbs_downloaddecouplecore" invoke-interface {v11, v15, v8}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v11 if-ne v11, v5, :cond_15 const-string v11, "unzip_temp_path" invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->n(Landroid/content/Context;)Ljava/io/File; move-result-object v15 invoke-virtual {v15}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v15 :goto_3 invoke-virtual {v13, v11, v15}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V goto :goto_4 :cond_15 const-string v11, "unzip_temp_path" invoke-virtual/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->r(Landroid/content/Context;)Ljava/io/File; move-result-object v15 invoke-virtual {v15}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v15 goto :goto_3 :goto_4 const-string v11, "unlzma" invoke-static {v2, v11, v13}, Lcom/tencent/smtt/sdk/QbSdk;->a(Landroid/content/Context;Ljava/lang/String;Landroid/os/Bundle;)Ljava/lang/Object; move-result-object v11 const/16 v13, 0xde if-nez v11, :cond_16 const-string v11, "TbsInstaller" const-string v15, "unlzma return null" invoke-static {v11, v15}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v11 const-string v15, "unlzma is null" :goto_5 invoke-virtual {v11, v13, v15}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V goto :goto_7 :cond_16 instance-of v15, v11, Ljava/lang/Boolean; if-eqz v15, :cond_18 check-cast v11, Ljava/lang/Boolean; invoke-virtual {v11}, Ljava/lang/Boolean;->booleanValue()Z move-result v11 if-eqz v11, :cond_17 const-string v11, "TbsInstaller" const-string v13, "unlzma success" invoke-static {v11, v13}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V goto :goto_6 :cond_17 const-string v11, "TbsInstaller" const-string v15, "unlzma return false" invoke-static {v11, v15}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v11 const-string v15, "unlzma return false" goto :goto_5 :cond_18 instance-of v15, v11, Landroid/os/Bundle; if-eqz v15, :cond_19 :goto_6 const/4 v11, 0x1 goto :goto_8 :cond_19 instance-of v15, v11, Ljava/lang/Throwable; if-eqz v15, :cond_1a const-string v15, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "unlzma failure because Throwable" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-object v7, v11 check-cast v7, Ljava/lang/Throwable; invoke-static {v7}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object v7 invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v15, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v6 check-cast v11, Ljava/lang/Throwable; invoke-virtual {v6, v13, v11}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/Throwable;)V :try_end_6 .catchall {:try_start_6 .. :try_end_6} :catchall_0 :cond_1a :goto_7 const/4 v11, 0x0 :goto_8 if-nez v11, :cond_1b sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_1b :try_start_7 const-string v6, "TbsInstaller" const-string v7, "unlzma finished" invoke-static {v6, v7}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v6 invoke-virtual {v6, v10, v5}, Lcom/tencent/smtt/sdk/ai;->b(II)V goto :goto_9 :cond_1c invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v6 iget-object v6, v6, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v7, "tbs_downloaddecouplecore" invoke-interface {v6, v7, v8}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v6 if-ne v6, v5, :cond_1f if-nez v3, :cond_1d invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v6 const-string v7, "install_apk_path" invoke-virtual {v6, v7}, Lcom/tencent/smtt/sdk/ai;->d(Ljava/lang/String;)Ljava/lang/String; move-result-object v6 if-nez v6, :cond_1e invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const-string v3, "apk path is null!" invoke-virtual {v0, v13, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 invoke-virtual {v0, v10}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_7 .catchall {:try_start_7 .. :try_end_7} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_1d move-object v6, v3 :cond_1e :try_start_8 new-instance v7, Ljava/io/File; invoke-direct {v7, v6}, Ljava/io/File;->(Ljava/lang/String;)V invoke-direct {v1, v2, v7, v5}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Ljava/io/File;Z)Z :cond_1f const/4 v10, 0x0 :goto_9 const/16 v6, 0xc8 if-ge v0, v12, :cond_28 if-eqz v9, :cond_21 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const-string v7, "dexopt_retry_num" invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/ai;->c(Ljava/lang/String;)I move-result v0 if-le v0, v14, :cond_20 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 const/16 v3, 0xd0 const-string v4, "exceed dexopt retry num!" invoke-virtual {v0, v3, v4}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v3, -0x202 invoke-virtual {v0, v3}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-direct/range {p0 .. p1}, Lcom/tencent/smtt/sdk/am;->D(Landroid/content/Context;)V :try_end_8 .catchall {:try_start_8 .. :try_end_8} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_20 :try_start_9 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v7 add-int/2addr v0, v5 invoke-virtual {v7, v0}, Lcom/tencent/smtt/sdk/ai;->a(I)V :cond_21 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v7, -0x225 invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-direct {v1, v2, v8}, Lcom/tencent/smtt/sdk/am;->c(Landroid/content/Context;I)Z move-result v0 if-nez v0, :cond_22 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v2, -0x203 invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_9 .catchall {:try_start_9 .. :try_end_9} :catchall_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void :cond_22 :try_start_a invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v10, v12}, Lcom/tencent/smtt/sdk/ai;->b(II)V const-string v0, "TbsInstaller" const-string v7, "STEP 2/2 installation completed! you can restart!" invoke-static {v0, v7, v5}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V const-string v0, "TbsInstaller" new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V const-string v9, "STEP 2/2 installation completed! you can restart! version:" invoke-virtual {v7, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v7 invoke-static {v0, v7}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v7, -0x204 invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V sget v0, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v7, 0xb if-lt v0, v7, :cond_23 const-string v0, "tbs_preloadx5_check_cfg_file" const/4 v7, 0x4 invoke-virtual {v2, v0, v7}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v0 goto :goto_a :cond_23 const-string v0, "tbs_preloadx5_check_cfg_file" invoke-virtual {v2, v0, v8}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences; move-result-object v0 :try_end_a .catchall {:try_start_a .. :try_end_a} :catchall_0 :goto_a :try_start_b invoke-interface {v0}, Landroid/content/SharedPreferences;->edit()Landroid/content/SharedPreferences$Editor; move-result-object v0 const-string v7, "tbs_preload_x5_counter" invoke-interface {v0, v7, v8}, Landroid/content/SharedPreferences$Editor;->putInt(Ljava/lang/String;I)Landroid/content/SharedPreferences$Editor; const-string v7, "tbs_preload_x5_recorder" invoke-interface {v0, v7, v8}, Landroid/content/SharedPreferences$Editor;->putInt(Ljava/lang/String;I)Landroid/content/SharedPreferences$Editor; const-string v7, "tbs_preload_x5_version" invoke-interface {v0, v7, v4}, Landroid/content/SharedPreferences$Editor;->putInt(Ljava/lang/String;I)Landroid/content/SharedPreferences$Editor; invoke-interface {v0}, Landroid/content/SharedPreferences$Editor;->commit()Z invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v7, -0x205 invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :try_end_b .catch Ljava/lang/Throwable; {:try_start_b .. :try_end_b} :catch_0 .catchall {:try_start_b .. :try_end_b} :catchall_0 :goto_b const v7, 0x54c5638 goto :goto_c :catch_0 move-exception v0 :try_start_c const-string v7, "TbsInstaller" new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8}, Ljava/lang/StringBuilder;->()V const-string v9, "Init tbs_preload_x5_counter#1 exception:" invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {v0}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object v0 invoke-virtual {v8, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-static {v7, v0}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v7, -0x206 invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V goto :goto_b :goto_c if-ne v4, v7, :cond_24 invoke-direct {v1, v4, v3, v2}, Lcom/tencent/smtt/sdk/am;->a(ILjava/lang/String;Landroid/content/Context;)V :cond_24 iget-boolean v0, v1, Lcom/tencent/smtt/sdk/am;->j:Z const/16 v3, 0xdd if-eqz v0, :cond_26 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v2 invoke-virtual {v2}, Lcom/tencent/smtt/sdk/ai;->d()I move-result v2 if-ne v2, v5, :cond_25 goto :goto_d :cond_25 const/16 v3, 0xc8 :goto_d const-string v2, "continueInstallWithout core success" :goto_e invoke-virtual {v0, v3, v2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V goto :goto_10 :cond_26 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v0 invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v2 invoke-virtual {v2}, Lcom/tencent/smtt/sdk/ai;->d()I move-result v2 if-ne v2, v5, :cond_27 goto :goto_f :cond_27 const/16 v3, 0xc8 :goto_f const-string v2, "success" goto :goto_e :cond_28 if-ne v0, v12, :cond_29 sget-object v0, Lcom/tencent/smtt/sdk/QbSdk;->l:Lcom/tencent/smtt/sdk/TbsListener; invoke-interface {v0, v6}, Lcom/tencent/smtt/sdk/TbsListener;->onInstallFinish(I)V :try_end_c .catchall {:try_start_c .. :try_end_c} :catchall_0 :cond_29 :goto_10 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V goto :goto_11 :catchall_0 move-exception v0 sget-object v2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V sget-object v2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V throw v0 :cond_2a invoke-static/range {p1 .. p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 const/16 v2, -0x207 invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V :goto_11 invoke-virtual/range {p0 .. p0}, Lcom/tencent/smtt/sdk/am;->b()V return-void .end method .method private b(Landroid/content/Context;Ljava/io/File;)Z .locals 9 const/4 v0, 0x0 :try_start_0 new-instance v1, Lcom/tencent/smtt/sdk/at; invoke-direct {v1, p0}, Lcom/tencent/smtt/sdk/at;->(Lcom/tencent/smtt/sdk/am;)V invoke-virtual {p2, v1}, Ljava/io/File;->listFiles(Ljava/io/FileFilter;)[Ljava/io/File; move-result-object v1 array-length v2, v1 sget v3, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v4, 0x10 if-ge v3, v4, :cond_0 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 if-eqz v3, :cond_0 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 const-string v4, "com.tencent.tbs" invoke-virtual {v3, v4}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result v3 :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_1 if-eqz v3, :cond_0 const-wide/16 v3, 0x1388 :try_start_1 invoke-static {v3, v4}, Ljava/lang/Thread;->sleep(J)V :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0 :catch_0 :cond_0 :try_start_2 invoke-virtual {p1}, Landroid/content/Context;->getClassLoader()Ljava/lang/ClassLoader; move-result-object v3 const/4 v4, 0x0 :goto_0 if-ge v4, v2, :cond_1 const-string v5, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "jarFile: " invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; aget-object v7, v1, v4 invoke-virtual {v7}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v7 invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v5, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V new-instance v5, Ldalvik/system/DexClassLoader; aget-object v6, v1, v4 invoke-virtual {v6}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v6 invoke-virtual {p2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v7 const/4 v8, 0x0 invoke-direct {v5, v6, v7, v8, v3}, Ldalvik/system/DexClassLoader;->(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/ClassLoader;)V :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_1 add-int/lit8 v4, v4, 0x1 goto :goto_0 :cond_1 const/4 p1, 0x1 return p1 :catch_1 move-exception p2 invoke-virtual {p2}, Ljava/lang/Exception;->printStackTrace()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 const/16 v1, 0xd1 invoke-virtual {p2}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object p2 invoke-virtual {p1, v1, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-doTbsDexOpt done" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v0 .end method .method private c(Landroid/content/Context;I)Z .locals 6 const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-doTbsDexOpt start - dirMode: " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const/4 v0, 0x0 const/4 v1, 0x1 packed-switch p2, :pswitch_data_0 :try_start_0 const-string v2, "TbsInstaller" goto :goto_3 :pswitch_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p2 goto :goto_0 :pswitch_1 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->t(Landroid/content/Context;)Ljava/io/File; move-result-object p2 goto :goto_0 :pswitch_2 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 iget-object p2, p2, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v2, "tbs_downloaddecouplecore" invoke-interface {p2, v2, v0}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result p2 if-ne p2, v1, :cond_0 return v1 :cond_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->r(Landroid/content/Context;)Ljava/io/File; move-result-object p2 :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_1 :goto_0 :try_start_1 const-string v2, "java.vm.version" invoke-static {v2}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String; move-result-object v2 if-eqz v2, :cond_1 const-string v3, "2" invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z move-result v2 :try_end_1 .catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_1} :catch_0 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_1 if-eqz v2, :cond_1 const/4 v2, 0x1 goto :goto_1 :catch_0 move-exception v2 :try_start_2 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v3 const/16 v4, 0xe2 invoke-virtual {v3, v4, v2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/Throwable;)V :cond_1 const/4 v2, 0x0 :goto_1 sget v3, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v4, 0x17 if-ne v3, v4, :cond_2 const/4 v3, 0x1 goto :goto_2 :cond_2 const/4 v3, 0x0 :goto_2 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v4 iget-object v4, v4, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v5, "tbs_stop_preoat" invoke-interface {v4, v5, v0}, Landroid/content/SharedPreferences;->getBoolean(Ljava/lang/String;Z)Z move-result v4 if-eqz v2, :cond_3 if-eqz v3, :cond_3 if-nez v4, :cond_3 const/4 v0, 0x1 :cond_3 if-eqz v0, :cond_4 invoke-direct {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->c(Landroid/content/Context;Ljava/io/File;)Z move-result v0 if-eqz v0, :cond_4 return v1 :cond_4 invoke-direct {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->b(Landroid/content/Context;Ljava/io/File;)Z move-result p2 return p2 :goto_3 new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "doDexoptOrDexoat mode error: " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-static {v2, p2}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_1 return v0 :catch_1 move-exception p2 invoke-virtual {p2}, Ljava/lang/Exception;->printStackTrace()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 const/16 v0, 0xd1 invoke-virtual {p2}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object p2 invoke-virtual {p1, v0, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-doTbsDexOpt done" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v1 :pswitch_data_0 .packed-switch 0x0 :pswitch_2 :pswitch_1 :pswitch_0 .end packed-switch .end method .method private c(Landroid/content/Context;Ljava/io/File;)Z .locals 9 const/16 v0, 0xe2 const/4 v1, 0x0 :try_start_0 new-instance v2, Ljava/io/File; const-string v3, "tbs_sdk_extension_dex.jar" invoke-direct {v2, p2, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V new-instance v3, Ljava/io/File; const-string v4, "tbs_sdk_extension_dex.dex" invoke-direct {v3, p2, v4}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {p1}, Landroid/content/Context;->getClassLoader()Ljava/lang/ClassLoader; move-result-object v4 new-instance v5, Ldalvik/system/DexClassLoader; invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v2 invoke-virtual {p2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v6 const/4 v7, 0x0 invoke-direct {v5, v2, v6, v7, v4}, Ldalvik/system/DexClassLoader;->(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/ClassLoader;)V invoke-virtual {v3}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v2 invoke-static {p1, v2}, Lcom/tencent/smtt/sdk/g;->a(Landroid/content/Context;Ljava/lang/String;)Ljava/lang/String; move-result-object v2 invoke-static {v2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z move-result v3 if-eqz v3, :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p2 const-string v2, "can not find oat command" invoke-virtual {p2, v0, v2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V return v1 :cond_0 new-instance v3, Lcom/tencent/smtt/sdk/au; invoke-direct {v3, p0}, Lcom/tencent/smtt/sdk/au;->(Lcom/tencent/smtt/sdk/am;)V invoke-virtual {p2, v3}, Ljava/io/File;->listFiles(Ljava/io/FileFilter;)[Ljava/io/File; move-result-object p2 array-length v3, p2 const/4 v4, 0x0 :goto_0 if-ge v4, v3, :cond_1 aget-object v5, p2, v4 invoke-virtual {v5}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v6 invoke-virtual {v5}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v5 invoke-virtual {v5}, Ljava/lang/String;->length()I move-result v5 add-int/lit8 v5, v5, -0x4 invoke-virtual {v6, v1, v5}, Ljava/lang/String;->substring(II)Ljava/lang/String; move-result-object v5 const-string v6, "tbs_sdk_extension_dex" invoke-virtual {v2, v6, v5}, Ljava/lang/String;->replaceAll(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object v6 new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V const-string v8, "/system/bin/dex2oat " invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v6, " --dex-location=" invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v6 invoke-virtual {v6, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object v6 invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; sget-object v6, Ljava/io/File;->separator:Ljava/lang/String; invoke-virtual {v7, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v5, ".jar" invoke-virtual {v7, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v5 invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime; move-result-object v6 invoke-virtual {v6, v5}, Ljava/lang/Runtime;->exec(Ljava/lang/String;)Ljava/lang/Process; move-result-object v5 invoke-virtual {v5}, Ljava/lang/Process;->waitFor()I :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 add-int/lit8 v4, v4, 0x1 goto :goto_0 :cond_1 const/4 p1, 0x1 return p1 :catch_0 move-exception p2 invoke-virtual {p2}, Ljava/lang/Exception;->printStackTrace()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 invoke-virtual {p1, v0, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/Throwable;)V return v1 .end method .method private declared-synchronized c(Landroid/content/Context;Z)Z .locals 6 monitor-enter p0 :try_start_0 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller-enableTbsCoreFromCopy" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_2 const/4 v0, 0x0 :try_start_1 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->u(Landroid/content/Context;)Z move-result v1 :try_end_1 .catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_1 if-nez v1, :cond_0 monitor-exit p0 return v0 :cond_0 :try_start_2 sget-object v1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v1}, Ljava/util/concurrent/locks/Lock;->tryLock()Z move-result v1 const-string v2, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "TbsInstaller-enableTbsCoreFromCopy Locked =" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v2, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_2 .catch Ljava/lang/Throwable; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_1 if-eqz v1, :cond_3 :try_start_3 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 const-string v2, "copy_status" invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/ai;->b(Ljava/lang/String;)I move-result v1 invoke-virtual {p0, v0, p1}, Lcom/tencent/smtt/sdk/am;->a(ZLandroid/content/Context;)I move-result v2 const-string v3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller-enableTbsCoreFromCopy copyStatus =" invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 invoke-static {v3, v4}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller-enableTbsCoreFromCopy tbsCoreInstalledVer =" invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 invoke-static {v3, v4}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const/4 v3, 0x1 if-ne v1, v3, :cond_2 if-nez v2, :cond_1 const-string p2, "TbsInstaller" const-string v1, "TbsInstaller-enableTbsCoreFromCopy tbsCoreInstalledVer = 0" invoke-static {p2, v1, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V :goto_0 invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->z(Landroid/content/Context;)V const/4 v0, 0x1 goto :goto_1 :cond_1 if-eqz p2, :cond_2 const-string p2, "TbsInstaller" const-string v1, "TbsInstaller-enableTbsCoreFromCopy tbsCoreInstalledVer != 0" invoke-static {p2, v1, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 goto :goto_0 :cond_2 :goto_1 :try_start_4 sget-object p2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {p2}, Ljava/util/concurrent/locks/Lock;->unlock()V goto :goto_2 :catchall_0 move-exception p2 sget-object v1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v1}, Ljava/util/concurrent/locks/Lock;->unlock()V throw p2 :cond_3 :goto_2 invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V :try_end_4 .catch Ljava/lang/Throwable; {:try_start_4 .. :try_end_4} :catch_0 .catchall {:try_start_4 .. :try_end_4} :catchall_1 goto :goto_3 :catchall_1 move-exception p1 goto :goto_4 :catch_0 move-exception p2 :try_start_5 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v1 const/16 v2, 0xd7 invoke-virtual {p2}, Ljava/lang/Throwable;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v1, v2, v3}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller::enableTbsCoreFromCopy exception:" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {p2}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object p2 invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-static {p1, p2}, Lcom/tencent/smtt/sdk/QbSdk;->a(Landroid/content/Context;Ljava/lang/String;)V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_1 :goto_3 monitor-exit p0 return v0 :goto_4 :try_start_6 throw p1 :try_end_6 .catchall {:try_start_6 .. :try_end_6} :catchall_2 :catchall_2 move-exception p1 monitor-exit p0 throw p1 .end method .method private d(Landroid/content/Context;I)Landroid/content/Context; .locals 8 const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller--getTbsCoreHostContext tbsCoreTargetVer=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const/4 v0, 0x0 if-gtz p2, :cond_0 return-object v0 :cond_0 invoke-static {}, Lcom/tencent/smtt/sdk/TbsShareManager;->getCoreProviderAppList()[Ljava/lang/String; move-result-object v1 const/4 v2, 0x0 :goto_0 array-length v3, v1 if-ge v2, v3, :cond_4 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 aget-object v4, v1, v2 invoke-virtual {v3, v4}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z move-result v3 if-eqz v3, :cond_1 goto :goto_1 :cond_1 aget-object v3, v1, v2 invoke-direct {p0, p1, v3}, Lcom/tencent/smtt/sdk/am;->e(Landroid/content/Context;Ljava/lang/String;)Z move-result v3 if-eqz v3, :cond_3 aget-object v3, v1, v2 invoke-virtual {p0, p1, v3}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Ljava/lang/String;)Landroid/content/Context; move-result-object v3 if-eqz v3, :cond_3 invoke-virtual {p0, v3}, Lcom/tencent/smtt/sdk/am;->f(Landroid/content/Context;)Z move-result v4 if-nez v4, :cond_2 const-string v3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller--getTbsCoreHostContext " invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; aget-object v5, v1, v2 invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v5, " illegal signature go on next" invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 invoke-static {v3, v4}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;)V goto :goto_1 :cond_2 invoke-virtual {p0, v3}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v4 const-string v5, "TbsInstaller" new-instance v6, Ljava/lang/StringBuilder; invoke-direct {v6}, Ljava/lang/StringBuilder;->()V const-string v7, "TbsInstaller-getTbsCoreHostContext hostTbsCoreVer=" invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v6 invoke-static {v5, v6}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-eqz v4, :cond_3 if-ne v4, p2, :cond_3 const-string p1, "TbsInstaller" new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V const-string v0, "TbsInstaller-getTbsCoreHostContext targetApp=" invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; aget-object v0, v1, v2 invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return-object v3 :cond_3 :goto_1 add-int/lit8 v2, v2, 0x1 goto :goto_0 :cond_4 return-object v0 .end method .method private static d(Landroid/content/Context;Ljava/lang/String;)Z .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p0, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p0 new-instance v0, Ljava/io/File; invoke-direct {v0, p0, p1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result p0 if-nez p0, :cond_0 const-string p0, "TbsInstaller" const-string p1, "TbsInstaller-isPrepareTbsCore, #1" :goto_0 invoke-static {p0, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v1 :cond_0 new-instance p0, Ljava/io/File; const-string p1, "tbs.conf" invoke-direct {p0, v0, p1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {p0}, Ljava/io/File;->exists()Z move-result p0 if-nez p0, :cond_1 const-string p0, "TbsInstaller" const-string p1, "TbsInstaller-isPrepareTbsCore, #2" goto :goto_0 :cond_1 const-string p0, "TbsInstaller" const-string p1, "TbsInstaller-isPrepareTbsCore, #3" invoke-static {p0, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const/4 p0, 0x1 return p0 .end method .method private declared-synchronized d(Landroid/content/Context;Z)Z .locals 5 monitor-enter p0 :try_start_0 const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-enableTbsCoreFromUnzip canRenameTmpDir =" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_1 const/4 v0, 0x0 :try_start_1 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->u(Landroid/content/Context;)Z move-result v1 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_1 if-nez v1, :cond_0 monitor-exit p0 return v0 :cond_0 :try_start_2 sget-object v1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v1}, Ljava/util/concurrent/locks/Lock;->tryLock()Z move-result v1 const-string v2, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "TbsInstaller-enableTbsCoreFromUnzip locked=" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v2, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_1 if-eqz v1, :cond_3 :try_start_3 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 invoke-virtual {v1}, Lcom/tencent/smtt/sdk/ai;->c()I move-result v1 const-string v2, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "TbsInstaller-enableTbsCoreFromUnzip installStatus=" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v2, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, v0, p1}, Lcom/tencent/smtt/sdk/am;->a(ZLandroid/content/Context;)I move-result v2 const/4 v3, 0x2 const/4 v4, 0x1 if-ne v1, v3, :cond_2 if-nez v2, :cond_1 const-string p2, "TbsInstaller" const-string v1, "TbsInstaller-enableTbsCoreFromUnzip tbsCoreInstalledVer = 0" invoke-static {p2, v1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V :goto_0 invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->y(Landroid/content/Context;)V const/4 v0, 0x1 goto :goto_1 :cond_1 if-eqz p2, :cond_2 const-string p2, "TbsInstaller" const-string v1, "TbsInstaller-enableTbsCoreFromUnzip tbsCoreInstalledVer != 0" invoke-static {p2, v1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 goto :goto_0 :cond_2 :goto_1 :try_start_4 sget-object p2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {p2}, Ljava/util/concurrent/locks/Lock;->unlock()V goto :goto_2 :catchall_0 move-exception p2 sget-object v1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v1}, Ljava/util/concurrent/locks/Lock;->unlock()V throw p2 :cond_3 :goto_2 invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V :try_end_4 .catch Ljava/lang/Exception; {:try_start_4 .. :try_end_4} :catch_0 .catchall {:try_start_4 .. :try_end_4} :catchall_1 goto :goto_3 :catch_0 move-exception p2 :try_start_5 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller::enableTbsCoreFromUnzip Exception: " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {p1, v1}, Lcom/tencent/smtt/sdk/QbSdk;->a(Landroid/content/Context;Ljava/lang/String;)V invoke-virtual {p2}, Ljava/lang/Exception;->printStackTrace()V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_1 :goto_3 monitor-exit p0 return v0 :catchall_1 move-exception p1 monitor-exit p0 throw p1 .end method .method private e(Landroid/content/Context;Ljava/lang/String;)Z .locals 1 const/4 v0, 0x0 :try_start_0 invoke-virtual {p1}, Landroid/content/Context;->getPackageManager()Landroid/content/pm/PackageManager; move-result-object p1 invoke-virtual {p1, p2, v0}, Landroid/content/pm/PackageManager;->getPackageInfo(Ljava/lang/String;I)Landroid/content/pm/PackageInfo; move-result-object p1 :try_end_0 .catch Landroid/content/pm/PackageManager$NameNotFoundException; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 const/4 p1, 0x0 :goto_0 if-eqz p1, :cond_0 const/4 p1, 0x1 return p1 :cond_0 return v0 .end method .method private declared-synchronized e(Landroid/content/Context;Z)Z .locals 0 monitor-enter p0 monitor-exit p0 const/4 p1, 0x0 return p1 .end method .method private f(Landroid/content/Context;Z)V .locals 4 const/16 v0, 0xe1 if-nez p1, :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 const-string p2, "setTmpFolderCoreToRead context is null" invoke-virtual {p1, v0, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V return-void :cond_0 :try_start_0 const-string v1, "tbs" const/4 v2, 0x0 invoke-virtual {p1, v1, v2}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object v1 new-instance v2, Ljava/io/File; const-string v3, "tmp_folder_core_to_read.conf" invoke-direct {v2, v1, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V if-eqz p2, :cond_2 invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p2 if-eqz p2, :cond_1 goto :goto_0 :cond_1 invoke-virtual {v2}, Ljava/io/File;->createNewFile()Z goto :goto_0 :cond_2 invoke-static {v2}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 move-exception p2 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "setTmpFolderCoreToRead Exception message is " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v2, " Exception cause is " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/Exception;->getCause()Ljava/lang/Throwable; move-result-object p2 invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-virtual {p1, v0, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :goto_0 return-void .end method .method static q(Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p0, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p0 new-instance v0, Ljava/io/File; const-string v1, "core_private" invoke-direct {v0, p0, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p0 if-nez p0, :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p0 if-nez p0, :cond_0 const/4 p0, 0x0 return-object p0 :cond_0 return-object v0 .end method .method private static v(Landroid/content/Context;)Z .locals 4 const/4 v0, 0x1 if-nez p0, :cond_0 const-string p0, "TbsInstaller" const-string v1, "TbsInstaller-getTmpFolderCoreToRead, #1" :goto_0 invoke-static {p0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v0 :cond_0 :try_start_0 const-string v1, "tbs" const/4 v2, 0x0 invoke-virtual {p0, v1, v2}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p0 new-instance v1, Ljava/io/File; const-string v3, "tmp_folder_core_to_read.conf" invoke-direct {v1, p0, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v1}, Ljava/io/File;->exists()Z move-result p0 if-eqz p0, :cond_1 const-string p0, "TbsInstaller" const-string v1, "TbsInstaller-getTmpFolderCoreToRead, #2" invoke-static {p0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v0 :cond_1 const-string p0, "TbsInstaller" const-string v1, "TbsInstaller-getTmpFolderCoreToRead, #3" invoke-static {p0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 return v2 :catch_0 const-string p0, "TbsInstaller" const-string v1, "TbsInstaller-getTmpFolderCoreToRead, #4" goto :goto_0 .end method .method private w(Landroid/content/Context;)V .locals 1 :try_start_0 invoke-static {}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance()Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 invoke-virtual {v0}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getTbsCoreLoadRenameFileLockEnable()Z move-result v0 :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 const/4 v0, 0x1 :goto_0 if-nez v0, :cond_0 goto :goto_1 :cond_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->k:Ljava/nio/channels/FileLock; if-eqz v0, :cond_1 sget-object v0, Lcom/tencent/smtt/sdk/am;->k:Ljava/nio/channels/FileLock; invoke-static {p1, v0}, Lcom/tencent/smtt/utils/k;->a(Landroid/content/Context;Ljava/nio/channels/FileLock;)V :cond_1 :goto_1 return-void .end method .method private x(Landroid/content/Context;)Z .locals 2 const/4 v0, 0x1 :try_start_0 invoke-static {}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance()Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v1 invoke-virtual {v1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getTbsCoreLoadRenameFileLockEnable()Z move-result v1 :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :catch_0 const/4 v1, 0x1 :goto_0 if-nez v1, :cond_0 invoke-static {}, Lcom/tencent/smtt/sdk/bq;->a()Lcom/tencent/smtt/sdk/bq; move-result-object v1 invoke-virtual {v1, p1}, Lcom/tencent/smtt/sdk/bq;->b(Landroid/content/Context;)Ljava/nio/channels/FileLock; move-result-object p1 :goto_1 sput-object p1, Lcom/tencent/smtt/sdk/am;->k:Ljava/nio/channels/FileLock; goto :goto_2 :cond_0 invoke-static {p1}, Lcom/tencent/smtt/utils/k;->f(Landroid/content/Context;)Ljava/nio/channels/FileLock; move-result-object p1 goto :goto_1 :goto_2 sget-object p1, Lcom/tencent/smtt/sdk/am;->k:Ljava/nio/channels/FileLock; if-nez p1, :cond_1 const/4 p1, 0x0 return p1 :cond_1 return v0 .end method .method private y(Landroid/content/Context;)V .locals 6 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--generateNewTbsCoreFromUnzip" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->x(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_0 const-string p1, "TbsInstaller" const-string v0, "get rename fileLock#4 ## failed!" invoke-static {p1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return-void :cond_0 const/4 v0, 0x1 :try_start_0 invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->A(Landroid/content/Context;)V invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->B(Landroid/content/Context;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v1 if-nez v1, :cond_1 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->a(Landroid/content/Context;)V :cond_1 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 const/4 v2, 0x0 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/ai;->a(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/ai;->b(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 invoke-virtual {v1, v2}, Lcom/tencent/smtt/sdk/ai;->d(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 const-string v3, "incrupdate_retry_num" invoke-virtual {v1, v3, v2}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 const/4 v3, 0x3 invoke-virtual {v1, v2, v3}, Lcom/tencent/smtt/sdk/ai;->b(II)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 const-string v3, "" invoke-virtual {v1, v3}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 const/4 v3, -0x1 invoke-virtual {v1, v3}, Lcom/tencent/smtt/sdk/ai;->c(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v1 if-nez v1, :cond_3 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v1 iget-object v1, v1, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v3, "tbs_decouplecoreversion" invoke-interface {v1, v3, v2}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v1 if-lez v1, :cond_2 invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v3 invoke-virtual {v3, p1}, Lcom/tencent/smtt/sdk/am;->h(Landroid/content/Context;)I move-result v3 if-eq v1, v3, :cond_2 invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v3 invoke-virtual {v3, p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v3 if-ne v1, v3, :cond_2 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->l(Landroid/content/Context;)Z goto :goto_0 :cond_2 const-string v3, "TbsInstaller" new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "TbsInstaller--generateNewTbsCoreFromUnzip #1 deCoupleCoreVersion is " invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v1, " getTbsCoreShareDecoupleCoreVersion is " invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v1 invoke-virtual {v1, p1}, Lcom/tencent/smtt/sdk/am;->h(Landroid/content/Context;)I move-result v1 invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v1, " getTbsCoreInstalledVerInNolock is " invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v1 invoke-virtual {v1, p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v1 invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v3, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :cond_3 :goto_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v1 if-eqz v1, :cond_4 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->k(Landroid/content/Context;)I move-result v1 invoke-static {p1, v1, v0}, Lcom/tencent/smtt/sdk/TbsShareManager;->writeCoreInfoForThirdPartyApp(Landroid/content/Context;IZ)V :cond_4 sget-object v1, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_1 :catch_0 move-exception v1 invoke-virtual {v1}, Ljava/lang/Throwable;->printStackTrace()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v2 const/16 v3, 0xdb new-instance v4, Ljava/lang/StringBuilder; invoke-direct {v4}, Ljava/lang/StringBuilder;->()V const-string v5, "exception when renameing from unzip:" invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/Throwable;->toString()Ljava/lang/String; move-result-object v1 invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-virtual {v2, v3, v1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V const-string v1, "TbsInstaller" const-string v2, "TbsInstaller--generateNewTbsCoreFromUnzip Exception" invoke-static {v1, v2, v0}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;Z)V :goto_1 invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->w(Landroid/content/Context;)V return-void .end method .method private z(Landroid/content/Context;)V .locals 5 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--generateNewTbsCoreFromCopy" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->x(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_0 const-string p1, "TbsInstaller" const-string v0, "get rename fileLock#4 ## failed!" invoke-static {p1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return-void :cond_0 :try_start_0 invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->A(Landroid/content/Context;)V invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->C(Landroid/content/Context;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->a(Landroid/content/Context;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const/4 v1, 0x3 const/4 v2, 0x0 invoke-virtual {v0, v2, v1}, Lcom/tencent/smtt/sdk/ai;->a(II)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_2 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 iget-object v0, v0, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v1, "tbs_decouplecoreversion" invoke-interface {v0, v1, v2}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v0 if-lez v0, :cond_1 invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v1 invoke-virtual {v1, p1}, Lcom/tencent/smtt/sdk/am;->h(Landroid/content/Context;)I move-result v1 if-eq v0, v1, :cond_1 invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v1 invoke-virtual {v1, p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v1 if-ne v0, v1, :cond_1 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->l(Landroid/content/Context;)Z goto :goto_0 :cond_1 const-string v1, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "TbsInstaller--generateNewTbsCoreFromCopy #1 deCoupleCoreVersion is " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v0, " getTbsCoreShareDecoupleCoreVersion is " invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v0 invoke-virtual {v0, p1}, Lcom/tencent/smtt/sdk/am;->h(Landroid/content/Context;)I move-result v0 invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; const-string v0, " getTbsCoreInstalledVerInNolock is " invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v0 invoke-virtual {v0, p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v0 invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-static {v1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :cond_2 :goto_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v1 invoke-virtual {v0, v1}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_1 :catch_0 move-exception v0 invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v1 const/16 v2, 0xdb new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "exception when renameing from copy:" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {v1, v2, v0}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :goto_1 invoke-direct {p0, p1}, Lcom/tencent/smtt/sdk/am;->w(Landroid/content/Context;)V return-void .end method # virtual methods .method a(Ljava/lang/String;)I .locals 4 const/4 v0, 0x0 if-nez p1, :cond_0 return v0 :cond_0 const/4 v1, 0x0 :try_start_0 new-instance v2, Ljava/io/File; invoke-direct {v2, p1}, Ljava/io/File;->(Ljava/lang/String;)V new-instance p1, Ljava/io/File; const-string v3, "tbs.conf" invoke-direct {p1, v2, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {p1}, Ljava/io/File;->exists()Z move-result v2 if-nez v2, :cond_1 return v0 :cond_1 new-instance v2, Ljava/util/Properties; invoke-direct {v2}, Ljava/util/Properties;->()V new-instance v3, Ljava/io/FileInputStream; invoke-direct {v3, p1}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance p1, Ljava/io/BufferedInputStream; invoke-direct {p1, v3}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_4 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 invoke-virtual {v2, p1}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V invoke-virtual {p1}, Ljava/io/BufferedInputStream;->close()V const-string v1, "tbs_core_version" invoke-virtual {v2, v1}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String; move-result-object v1 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_2 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-nez v1, :cond_2 :try_start_2 invoke-virtual {p1}, Ljava/io/BufferedInputStream;->close()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 :catch_0 return v0 :cond_2 :try_start_3 invoke-static {v1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I move-result v1 :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_2 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :try_start_4 invoke-virtual {p1}, Ljava/io/BufferedInputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_1 :catch_1 return v1 :catchall_0 move-exception v0 move-object v1, p1 goto :goto_0 :catch_2 move-object v1, p1 goto :goto_1 :catchall_1 move-exception v0 :goto_0 if-eqz v1, :cond_3 :try_start_5 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_3 :catch_3 :cond_3 throw v0 :catch_4 :goto_1 if-eqz v1, :cond_4 :try_start_6 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_5 :catch_5 :cond_4 return v0 .end method .method public a(ZLandroid/content/Context;)I .locals 0 if-nez p1, :cond_0 sget-object p1, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; invoke-virtual {p1}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/Integer; invoke-virtual {p1}, Ljava/lang/Integer;->intValue()I move-result p1 if-gtz p1, :cond_1 :cond_0 sget-object p1, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; invoke-virtual {p0, p2}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result p2 invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p2 invoke-virtual {p1, p2}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V :cond_1 sget-object p1, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; invoke-virtual {p1}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/Integer; invoke-virtual {p1}, Ljava/lang/Integer;->intValue()I move-result p1 return p1 .end method .method a(Landroid/content/Context;Ljava/lang/String;)Landroid/content/Context; .locals 1 const/4 v0, 0x2 :try_start_0 invoke-virtual {p1, p2, v0}, Landroid/content/Context;->createPackageContext(Ljava/lang/String;I)Landroid/content/Context; move-result-object p1 :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 return-object p1 :catch_0 const/4 p1, 0x0 return-object p1 .end method .method a(Landroid/content/Context;Landroid/os/Bundle;)V .locals 2 if-eqz p2, :cond_1 if-nez p1, :cond_0 goto :goto_0 :cond_0 const/4 v0, 0x2 new-array v0, v0, [Ljava/lang/Object; const/4 v1, 0x0 aput-object p1, v0, v1 const/4 p1, 0x1 aput-object p2, v0, p1 new-instance p1, Landroid/os/Message; invoke-direct {p1}, Landroid/os/Message;->()V const/4 p2, 0x3 iput p2, p1, Landroid/os/Message;->what:I iput-object v0, p1, Landroid/os/Message;->obj:Ljava/lang/Object; sget-object p2, Lcom/tencent/smtt/sdk/am;->l:Landroid/os/Handler; invoke-virtual {p2, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z :cond_1 :goto_0 return-void .end method .method a(Landroid/content/Context;Ljava/lang/String;I)V .locals 3 const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-installTbsCore tbsApkPath=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-installTbsCore tbsCoreTargetVer=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-continueInstallTbsCore currentProcessName=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo; move-result-object v2 iget-object v2, v2, Landroid/content/pm/ApplicationInfo;->processName:Ljava/lang/String; invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-installTbsCore currentProcessId=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Landroid/os/Process;->myPid()I move-result v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-installTbsCore currentThreadName=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread; move-result-object v2 invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const/4 v0, 0x3 new-array v0, v0, [Ljava/lang/Object; const/4 v1, 0x0 aput-object p1, v0, v1 const/4 p1, 0x1 aput-object p2, v0, p1 invoke-static {p3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p2 const/4 p3, 0x2 aput-object p2, v0, p3 new-instance p2, Landroid/os/Message; invoke-direct {p2}, Landroid/os/Message;->()V iput p1, p2, Landroid/os/Message;->what:I iput-object v0, p2, Landroid/os/Message;->obj:Ljava/lang/Object; sget-object p1, Lcom/tencent/smtt/sdk/am;->l:Landroid/os/Handler; invoke-virtual {p1, p2}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z return-void .end method .method a(Landroid/content/Context;Z)V .locals 10 const/4 v0, 0x1 if-eqz p2, :cond_0 iput-boolean v0, p0, Lcom/tencent/smtt/sdk/am;->j:Z :cond_0 const-string p2, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-continueInstallTbsCore currentProcessName=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo; move-result-object v2 iget-object v2, v2, Landroid/content/pm/ApplicationInfo;->processName:Ljava/lang/String; invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {p2, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string p2, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-continueInstallTbsCore currentProcessId=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Landroid/os/Process;->myPid()I move-result v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {p2, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string p2, "TbsInstaller" new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller-continueInstallTbsCore currentThreadName=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread; move-result-object v2 invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {p2, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->u(Landroid/content/Context;)Z move-result p2 if-nez p2, :cond_1 return-void :cond_1 const/4 p2, 0x0 sget-object v1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v1}, Ljava/util/concurrent/locks/Lock;->tryLock()Z move-result v1 const/4 v2, -0x1 const/4 v3, 0x0 if-eqz v1, :cond_2 :try_start_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object p2 invoke-virtual {p2}, Lcom/tencent/smtt/sdk/ai;->c()I move-result p2 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v1 invoke-virtual {v1}, Lcom/tencent/smtt/sdk/ai;->b()I move-result v1 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v4 const-string v5, "install_apk_path" invoke-virtual {v4, v5}, Lcom/tencent/smtt/sdk/ai;->d(Ljava/lang/String;)Ljava/lang/String; move-result-object v4 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v5 const-string v6, "copy_core_ver" invoke-virtual {v5, v6}, Lcom/tencent/smtt/sdk/ai;->c(Ljava/lang/String;)I move-result v5 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v6 const-string v7, "copy_status" invoke-virtual {v6, v7}, Lcom/tencent/smtt/sdk/ai;->b(Ljava/lang/String;)I move-result v6 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 sget-object v7, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v7}, Ljava/util/concurrent/locks/Lock;->unlock()V goto :goto_0 :catchall_0 move-exception p1 sget-object p2, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {p2}, Ljava/util/concurrent/locks/Lock;->unlock()V throw p1 :cond_2 move-object v4, p2 const/4 p2, -0x1 const/4 v1, 0x0 const/4 v5, 0x0 const/4 v6, -0x1 :goto_0 invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V const-string v7, "TbsInstaller" new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8}, Ljava/lang/StringBuilder;->()V const-string v9, "TbsInstaller-continueInstallTbsCore installStatus=" invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v8 invoke-static {v7, v8}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v7, "TbsInstaller" new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8}, Ljava/lang/StringBuilder;->()V const-string v9, "TbsInstaller-continueInstallTbsCore tbsCoreInstallVer=" invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v8 invoke-static {v7, v8}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v7, "TbsInstaller" new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8}, Ljava/lang/StringBuilder;->()V const-string v9, "TbsInstaller-continueInstallTbsCore tbsApkPath=" invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v8 invoke-static {v7, v8}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v7, "TbsInstaller" new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8}, Ljava/lang/StringBuilder;->()V const-string v9, "TbsInstaller-continueInstallTbsCore tbsCoreCopyVer=" invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v8 invoke-static {v7, v8}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v7, "TbsInstaller" new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8}, Ljava/lang/StringBuilder;->()V const-string v9, "TbsInstaller-continueInstallTbsCore copyStatus=" invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v8 invoke-static {v7, v8}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v7 if-eqz v7, :cond_3 invoke-static {p1, v3}, Lcom/tencent/smtt/sdk/TbsShareManager;->a(Landroid/content/Context;Z)I move-result p2 invoke-virtual {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->b(Landroid/content/Context;I)V goto :goto_2 :cond_3 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v7 iget-object v7, v7, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v8, "tbs_responsecode" invoke-interface {v7, v8, v3}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v7 const/4 v8, 0x2 if-eq v7, v0, :cond_5 if-eq v7, v8, :cond_5 const/4 v9, 0x4 if-ne v7, v9, :cond_4 goto :goto_1 :cond_4 const/4 v0, 0x0 :cond_5 :goto_1 if-nez v0, :cond_6 if-eqz v7, :cond_6 new-instance v0, Landroid/os/Bundle; invoke-direct {v0}, Landroid/os/Bundle;->()V const-string v3, "operation" const/16 v7, 0x2711 invoke-virtual {v0, v3, v7}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V invoke-virtual {p0, p1, v0}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Landroid/os/Bundle;)V :cond_6 if-le p2, v2, :cond_7 if-ge p2, v8, :cond_7 invoke-virtual {p0, p1, v4, v1}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Ljava/lang/String;I)V :cond_7 if-nez v6, :cond_8 invoke-virtual {p0, p1, v5}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;I)Z :cond_8 :goto_2 return-void .end method .method a(Landroid/content/Context;I)Z .locals 4 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloader;->getOverSea(Landroid/content/Context;)Z move-result v0 const/4 v1, 0x0 if-eqz v0, :cond_0 return v1 :cond_0 const-string v0, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller-installLocalTbsCore targetTbsCoreVer=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v0, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller-continueInstallTbsCore currentProcessName=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo; move-result-object v3 iget-object v3, v3, Landroid/content/pm/ApplicationInfo;->processName:Ljava/lang/String; invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v0, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller-installLocalTbsCore currentProcessId=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Landroid/os/Process;->myPid()I move-result v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v0, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v0, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller-installLocalTbsCore currentThreadName=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread; move-result-object v3 invoke-virtual {v3}, Ljava/lang/Thread;->getName()Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v0, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-direct {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;I)Landroid/content/Context; move-result-object v0 if-eqz v0, :cond_1 const/4 v2, 0x3 new-array v2, v2, [Ljava/lang/Object; aput-object v0, v2, v1 const/4 v0, 0x1 aput-object p1, v2, v0 invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p1 const/4 p2, 0x2 aput-object p1, v2, p2 new-instance p1, Landroid/os/Message; invoke-direct {p1}, Landroid/os/Message;->()V iput p2, p1, Landroid/os/Message;->what:I iput-object v2, p1, Landroid/os/Message;->obj:Ljava/lang/Object; sget-object p2, Lcom/tencent/smtt/sdk/am;->l:Landroid/os/Handler; invoke-virtual {p2, p1}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z return v0 :cond_1 const-string p1, "TbsInstaller" const-string p2, "TbsInstaller--installLocalTbsCore copy from null" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v1 .end method .method public declared-synchronized a(Landroid/content/Context;Landroid/content/Context;)Z .locals 2 monitor-enter p0 :try_start_0 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--quickDexOptForThirdPartyApp" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V sget-boolean v0, Lcom/tencent/smtt/sdk/am;->n:Z :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 const/4 v1, 0x1 if-ne v0, v1, :cond_0 monitor-exit p0 return v1 :cond_0 :try_start_1 sput-boolean v1, Lcom/tencent/smtt/sdk/am;->n:Z new-instance v0, Lcom/tencent/smtt/sdk/ap; invoke-direct {v0, p0, p2, p1}, Lcom/tencent/smtt/sdk/ap;->(Lcom/tencent/smtt/sdk/am;Landroid/content/Context;Landroid/content/Context;)V invoke-virtual {v0}, Lcom/tencent/smtt/sdk/ap;->start()V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 monitor-exit p0 return v1 :catchall_0 move-exception p1 monitor-exit p0 throw p1 .end method .method public a(Landroid/content/Context;[Ljava/io/File;)Z .locals 0 const/4 p1, 0x0 return p1 .end method .method b(Landroid/content/Context;Ljava/lang/String;)I .locals 1 invoke-virtual {p1}, Landroid/content/Context;->getPackageManager()Landroid/content/pm/PackageManager; move-result-object p1 const/4 v0, 0x0 invoke-virtual {p1, p2, v0}, Landroid/content/pm/PackageManager;->getPackageArchiveInfo(Ljava/lang/String;I)Landroid/content/pm/PackageInfo; move-result-object p1 if-eqz p1, :cond_0 iget p1, p1, Landroid/content/pm/PackageInfo;->versionCode:I return p1 :cond_0 return v0 .end method .method b(Landroid/content/Context;Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p2, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p2 new-instance v0, Ljava/io/File; const-string v1, "core_share" invoke-direct {v0, p2, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p2 if-nez p2, :cond_1 if-eqz p1, :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result p1 if-nez p1, :cond_1 :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p1 if-nez p1, :cond_1 const/4 p1, 0x0 return-object p1 :cond_1 return-object v0 .end method .method declared-synchronized b()V .locals 2 monitor-enter p0 :try_start_0 iget v0, p0, Lcom/tencent/smtt/sdk/am;->d:I add-int/lit8 v1, v0, -0x1 iput v1, p0, Lcom/tencent/smtt/sdk/am;->d:I const/4 v1, 0x1 if-gt v0, v1, :cond_1 iget-boolean v0, p0, Lcom/tencent/smtt/sdk/am;->g:Z if-nez v0, :cond_0 goto :goto_0 :cond_0 const-string v0, "TbsInstaller" const-string v1, "releaseTbsInstallingFileLock without skip" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V iget-object v0, p0, Lcom/tencent/smtt/sdk/am;->e:Ljava/nio/channels/FileLock; iget-object v1, p0, Lcom/tencent/smtt/sdk/am;->f:Ljava/io/FileOutputStream; invoke-static {v0, v1}, Lcom/tencent/smtt/utils/k;->a(Ljava/nio/channels/FileLock;Ljava/io/FileOutputStream;)V const/4 v0, 0x0 iput-boolean v0, p0, Lcom/tencent/smtt/sdk/am;->g:Z :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 monitor-exit p0 return-void :cond_1 :goto_0 :try_start_1 const-string v0, "TbsInstaller" const-string v1, "releaseTbsInstallingFileLock with skip" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 monitor-exit p0 return-void :catchall_0 move-exception v0 monitor-exit p0 throw v0 .end method .method public b(Landroid/content/Context;)V .locals 2 const/4 v0, 0x1 invoke-direct {p0, p1, v0}, Lcom/tencent/smtt/sdk/am;->f(Landroid/content/Context;Z)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->h(Landroid/content/Context;)I move-result p1 const/4 v1, 0x2 invoke-virtual {v0, p1, v1}, Lcom/tencent/smtt/sdk/ai;->b(II)V return-void .end method .method b(Landroid/content/Context;I)V .locals 2 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller-installTbsCoreForThirdPartyApp" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-gtz p2, :cond_0 return-void :cond_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v0 if-ne v0, p2, :cond_1 return-void :cond_1 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->e(Landroid/content/Context;)Landroid/content/Context; move-result-object p2 if-nez p2, :cond_3 invoke-static {}, Lcom/tencent/smtt/sdk/TbsShareManager;->getHostCorePathAppDefined()Ljava/lang/String; move-result-object v1 if-eqz v1, :cond_2 goto :goto_0 :cond_2 if-gtz v0, :cond_4 const-string p2, "TbsInstaller" const-string v0, "TbsInstaller--installTbsCoreForThirdPartyApp hostContext == null" invoke-static {p2, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string p2, "TbsInstaller::installTbsCoreForThirdPartyApp forceSysWebViewInner #2" invoke-static {p1, p2}, Lcom/tencent/smtt/sdk/QbSdk;->a(Landroid/content/Context;Ljava/lang/String;)V goto :goto_1 :cond_3 :goto_0 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--quickDexOptForThirdPartyApp hostContext != null" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->a(Landroid/content/Context;Landroid/content/Context;)Z :cond_4 :goto_1 return-void .end method .method b(Landroid/content/Context;Landroid/os/Bundle;)V .locals 12 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->c(Landroid/content/Context;)Z move-result v0 if-eqz v0, :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p1 const/16 p2, -0x21b :goto_0 invoke-virtual {p1, p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V return-void :cond_0 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller-installLocalTesCoreExInThread" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-eqz p2, :cond_13 if-nez p1, :cond_1 goto/16 :goto_b :cond_1 invoke-static {p1}, Lcom/tencent/smtt/utils/k;->b(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_2 invoke-static {}, Lcom/tencent/smtt/utils/aa;->a()J move-result-wide v0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 invoke-virtual {p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getDownloadMinFreeSpace()J move-result-wide v2 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p2 const/16 v4, 0xd2 new-instance v5, Ljava/lang/StringBuilder; invoke-direct {v5}, Ljava/lang/StringBuilder;->()V const-string v6, "rom is not enough when patching tbs core! curAvailROM=" invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v5, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; const-string v0, ",minReqRom=" invoke-virtual {v5, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v5, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {p2, v4, v0}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p1 const/16 p2, -0x21c goto :goto_0 :cond_2 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->u(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_3 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p1 const/16 p2, -0x21d goto :goto_0 :cond_3 sget-object v0, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->tryLock()Z move-result v0 const-string v1, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller-installLocalTesCoreExInThread locked=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v1, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V if-eqz v0, :cond_12 const/4 v0, 0x0 const/4 v1, -0x1 const/16 v2, -0x220 const/16 v3, 0xd9 const/16 v4, -0x222 const/4 v5, 0x2 const/4 v6, 0x0 const/4 v7, 0x1 :try_start_0 invoke-static {v7}, Lcom/tencent/smtt/sdk/QbSdk;->setTBSInstallingStatus(Z)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->i(Landroid/content/Context;)I move-result v8 if-lez v8, :cond_f invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v8 invoke-virtual {v8}, Lcom/tencent/smtt/sdk/ai;->d()I move-result v8 if-ne v8, v7, :cond_4 goto/16 :goto_6 :cond_4 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v8 iget-object v8, v8, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v9, "tbs_responsecode" invoke-interface {v8, v9, v6}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v8 if-eq v8, v7, :cond_6 if-eq v8, v5, :cond_6 const/4 v9, 0x4 if-ne v8, v9, :cond_5 goto :goto_1 :cond_5 const/4 v9, 0x0 goto :goto_2 :cond_6 :goto_1 const/4 v9, 0x1 :goto_2 if-nez v9, :cond_c if-eqz v8, :cond_c invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v8 const-string v9, "incrupdate_retry_num" invoke-virtual {v8, v9}, Lcom/tencent/smtt/sdk/ai;->c(Ljava/lang/String;)I move-result v8 const/4 v9, 0x5 if-le v8, v9, :cond_a const-string v8, "TbsInstaller" const-string v9, "TbsInstaller-installLocalTesCoreExInThread exceed incrupdate num" invoke-static {v8, v9}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const-string v8, "old_apk_location" invoke-virtual {p2, v8}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object v8 const-string v9, "new_apk_location" invoke-virtual {p2, v9}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object v9 const-string v10, "diff_file_location" invoke-virtual {p2, v10}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object p2 invoke-static {v8}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z move-result v10 if-nez v10, :cond_7 new-instance v10, Ljava/io/File; invoke-direct {v10, v8}, Ljava/io/File;->(Ljava/lang/String;)V invoke-static {v10}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V :cond_7 invoke-static {v9}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z move-result v8 if-nez v8, :cond_8 new-instance v8, Ljava/io/File; invoke-direct {v8, v9}, Ljava/io/File;->(Ljava/lang/String;)V invoke-static {v8}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V :cond_8 invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z move-result v8 if-nez v8, :cond_9 new-instance v8, Ljava/io/File; invoke-direct {v8, p2}, Ljava/io/File;->(Ljava/lang/String;)V invoke-static {v8}, Lcom/tencent/smtt/utils/k;->b(Ljava/io/File;)V :cond_9 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 iget-object p2, p2, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->a:Ljava/util/Map; const-string v8, "tbs_needdownload" invoke-static {v7}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v9 invoke-interface {p2, v8, v9}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 invoke-virtual {p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->commit()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p2 const/16 v8, 0xe0 const-string v9, "incrUpdate exceed retry max num" invoke-virtual {p2, v8, v9}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_1 .catchall {:try_start_0 .. :try_end_0} :catchall_1 sget-object p1, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {p1}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-installLocalTesCoreExInThread PATCH_NONEEDPATCH" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {v6}, Lcom/tencent/smtt/sdk/QbSdk;->setTBSInstallingStatus(Z)V return-void :cond_a :try_start_1 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v9 const-string v10, "incrupdate_retry_num" add-int/2addr v8, v7 invoke-virtual {v9, v10, v8}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/am;->q(Landroid/content/Context;)Ljava/io/File; move-result-object v8 if-eqz v8, :cond_c new-instance v9, Ljava/io/File; const-string v10, "x5.tbs" invoke-direct {v9, v8, v10}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v9}, Ljava/io/File;->exists()Z move-result v8 if-eqz v8, :cond_c invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v8 const/16 v9, -0x226 invoke-virtual {v8, v9}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static {p1, p2}, Lcom/tencent/smtt/sdk/QbSdk;->a(Landroid/content/Context;Landroid/os/Bundle;)Landroid/os/Bundle; move-result-object p2 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_1 .catchall {:try_start_1 .. :try_end_1} :catchall_1 if-nez p2, :cond_b const/4 v0, 0x1 goto :goto_3 :cond_b :try_start_2 const-string v0, "patch_result" invoke-virtual {p2, v0}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I move-result v0 :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_0 goto :goto_3 :catchall_0 move-exception v0 move-object v8, p2 move-object p2, v0 goto/16 :goto_7 :catch_0 move-exception v0 move-object v11, v0 move-object v0, p2 move-object p2, v11 goto/16 :goto_8 :cond_c move-object p2, v0 const/4 v0, 0x2 :goto_3 sget-object v8, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v8}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V if-nez v0, :cond_d const-string v0, "TbsInstaller" const-string v3, "TbsInstaller-installLocalTesCoreExInThread PATCH_SUCCESS" invoke-static {v0, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const-string v3, "incrupdate_retry_num" invoke-virtual {v0, v3, v6}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v6, v1}, Lcom/tencent/smtt/sdk/ai;->b(II)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/ai;->c(I)V const-string v0, "apk_path" invoke-virtual {p2, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 new-instance v1, Ljava/io/File; invoke-direct {v1, v0}, Ljava/io/File;->(Ljava/lang/String;)V invoke-static {v1, p1}, Lcom/tencent/smtt/sdk/ag;->a(Ljava/io/File;Landroid/content/Context;)V const-string v1, "tbs_core_ver" invoke-virtual {p2, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I move-result p2 invoke-direct {p0, p1, v0, p2}, Lcom/tencent/smtt/sdk/am;->b(Landroid/content/Context;Ljava/lang/String;I)V goto :goto_5 :cond_d if-ne v0, v5, :cond_e const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-installLocalTesCoreExInThread PATCH_NONEEDPATCH" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V goto :goto_5 :cond_e invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 invoke-virtual {p2, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const-string p2, "TbsInstaller" const-string v1, "TbsInstaller-installLocalTesCoreExInThread PATCH_FAIL" invoke-static {p2, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 iget-object p2, p2, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->a:Ljava/util/Map; const-string v1, "tbs_needdownload" invoke-static {v7}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v2 invoke-interface {p2, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 invoke-virtual {p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->commit()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V const-string v1, "incrUpdate fail! patch ret=" invoke-virtual {p2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; :goto_4 invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-virtual {p1, v3, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :goto_5 invoke-static {v6}, Lcom/tencent/smtt/sdk/QbSdk;->setTBSInstallingStatus(Z)V goto/16 :goto_b :cond_f :goto_6 :try_start_3 invoke-static {v6}, Lcom/tencent/smtt/sdk/QbSdk;->setTBSInstallingStatus(Z)V :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_1 .catchall {:try_start_3 .. :try_end_3} :catchall_1 sget-object p1, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {p1}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-installLocalTesCoreExInThread PATCH_NONEEDPATCH" invoke-static {p1, p2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {v6}, Lcom/tencent/smtt/sdk/QbSdk;->setTBSInstallingStatus(Z)V return-void :catchall_1 move-exception p2 move-object v8, v0 :goto_7 const/4 v0, 0x2 goto :goto_9 :catch_1 move-exception p2 :goto_8 :try_start_4 const-string v8, "TbsInstaller" new-instance v9, Ljava/lang/StringBuilder; invoke-direct {v9}, Ljava/lang/StringBuilder;->()V const-string v10, "installLocalTbsCoreExInThread exception:" invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-static {p2}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String; move-result-object v10 invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v9 invoke-static {v8, v9}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p2}, Ljava/lang/Exception;->printStackTrace()V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_1 :try_start_5 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v8 const/16 v9, -0x21f invoke-virtual {v8, v9}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object v8 const/16 v9, 0xda invoke-virtual {p2}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object p2 invoke-virtual {v8, v9, p2}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_2 sget-object p2, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {p2}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 invoke-virtual {p2, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const-string p2, "TbsInstaller" const-string v0, "TbsInstaller-installLocalTesCoreExInThread PATCH_FAIL" invoke-static {p2, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 iget-object p2, p2, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->a:Ljava/util/Map; const-string v0, "tbs_needdownload" invoke-static {v7}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v1 invoke-interface {p2, v0, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p2 invoke-virtual {p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->commit()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V const-string v0, "incrUpdate fail! patch ret=" invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; goto/16 :goto_4 :catchall_2 move-exception p2 move-object v8, v0 const/4 v0, 0x1 :goto_9 sget-object v9, Lcom/tencent/smtt/sdk/am;->i:Ljava/util/concurrent/locks/Lock; invoke-interface {v9}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V if-eqz v0, :cond_11 if-ne v0, v5, :cond_10 const-string p1, "TbsInstaller" const-string v0, "TbsInstaller-installLocalTesCoreExInThread PATCH_NONEEDPATCH" invoke-static {p1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V goto :goto_a :cond_10 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v1 invoke-virtual {v1, v4}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V const-string v1, "TbsInstaller" const-string v2, "TbsInstaller-installLocalTesCoreExInThread PATCH_FAIL" invoke-static {v1, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v1 iget-object v1, v1, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->a:Ljava/util/Map; invoke-static {v7}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean; move-result-object v2 const-string v4, "tbs_needdownload" invoke-interface {v1, v4, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v1 invoke-virtual {v1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->commit()V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsLogReport; move-result-object p1 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "incrUpdate fail! patch ret=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {p1, v3, v0}, Lcom/tencent/smtt/sdk/TbsLogReport;->a(ILjava/lang/String;)V goto :goto_a :cond_11 const-string v0, "TbsInstaller" const-string v3, "TbsInstaller-installLocalTesCoreExInThread PATCH_SUCCESS" invoke-static {v0, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const-string v3, "incrupdate_retry_num" invoke-virtual {v0, v3, v6}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 invoke-virtual {v0, v2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v6, v1}, Lcom/tencent/smtt/sdk/ai;->b(II)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v7}, Lcom/tencent/smtt/sdk/ai;->c(I)V const-string v0, "apk_path" invoke-virtual {v8, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 new-instance v1, Ljava/io/File; invoke-direct {v1, v0}, Ljava/io/File;->(Ljava/lang/String;)V invoke-static {v1, p1}, Lcom/tencent/smtt/sdk/ag;->a(Ljava/io/File;Landroid/content/Context;)V const-string v1, "tbs_core_ver" invoke-virtual {v8, v1}, Landroid/os/Bundle;->getInt(Ljava/lang/String;)I move-result v1 invoke-direct {p0, p1, v0, v1}, Lcom/tencent/smtt/sdk/am;->b(Landroid/content/Context;Ljava/lang/String;I)V :goto_a invoke-static {v6}, Lcom/tencent/smtt/sdk/QbSdk;->setTBSInstallingStatus(Z)V throw p2 :cond_12 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object p1 const/16 p2, -0x223 invoke-virtual {p1, p2}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->setInstallInterruptCode(I)V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V :cond_13 :goto_b return-void .end method .method b(Landroid/content/Context;Z)V .locals 4 sget-boolean v0, Lcom/tencent/smtt/sdk/QbSdk;->b:Z if-eqz v0, :cond_0 return-void :cond_0 sget v0, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v1, 0x8 const/4 v2, 0x1 if-ge v0, v1, :cond_1 const-string p1, "TbsInstaller" const-string p2, "android version < 2.1 no need install X5 core" invoke-static {p1, p2, v2}, Lcom/tencent/smtt/utils/TbsLog;->e(Ljava/lang/String;Ljava/lang/String;Z)V return-void :cond_1 :try_start_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_2 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->s(Landroid/content/Context;)Ljava/io/File; move-result-object v0 if-eqz v0, :cond_2 invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result v1 if-eqz v1, :cond_2 const/4 v1, 0x0 invoke-static {v0, v1}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-static {p1}, Lcom/tencent/smtt/sdk/am;->q(Landroid/content/Context;)Ljava/io/File; move-result-object v0 new-instance v1, Ljava/io/File; const-string v3, "x5.tbs" invoke-direct {v1, v0, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v1}, Ljava/io/File;->delete()Z :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_0 :catch_0 :cond_2 invoke-static {p1}, Lcom/tencent/smtt/sdk/am;->v(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_3 goto :goto_3 :cond_3 const-string v0, "core_unzip_tmp" invoke-static {p1, v0}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;Ljava/lang/String;)Z move-result v0 if-nez v0, :cond_4 goto :goto_1 :cond_4 invoke-direct {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;Z)Z move-result v0 if-eqz v0, :cond_5 const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-installTbsCoreIfNeeded, enableTbsCoreFromUnzip!!" :goto_0 invoke-static {p1, p2, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V goto :goto_3 :cond_5 :goto_1 const-string v0, "core_share_backup_tmp" invoke-static {p1, v0}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;Ljava/lang/String;)Z move-result v0 if-nez v0, :cond_6 goto :goto_2 :cond_6 invoke-direct {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->e(Landroid/content/Context;Z)Z move-result v0 if-eqz v0, :cond_7 const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-installTbsCoreIfNeeded, enableTbsCoreFromBackup!!" goto :goto_0 :cond_7 :goto_2 const-string v0, "core_copy_tmp" invoke-static {p1, v0}, Lcom/tencent/smtt/sdk/am;->d(Landroid/content/Context;Ljava/lang/String;)Z move-result v0 if-nez v0, :cond_8 goto :goto_4 :cond_8 invoke-direct {p0, p1, p2}, Lcom/tencent/smtt/sdk/am;->c(Landroid/content/Context;Z)Z move-result p1 if-eqz p1, :cond_9 const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-installTbsCoreIfNeeded, enableTbsCoreFromCopy!!" goto :goto_0 :goto_3 return-void :cond_9 :goto_4 const-string p1, "TbsInstaller" const-string p2, "TbsInstaller-installTbsCoreIfNeeded, error !!" invoke-static {p1, p2, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;Z)V return-void .end method .method c(Landroid/content/Context;Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p2, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p2 new-instance v0, Ljava/io/File; const-string v1, "core_share_decouple" invoke-direct {v0, p2, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p2 if-nez p2, :cond_1 if-eqz p1, :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->isThirdPartyApp(Landroid/content/Context;)Z move-result p1 if-nez p1, :cond_1 :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p1 if-nez p1, :cond_1 const/4 p1, 0x0 return-object p1 :cond_1 return-object v0 .end method .method public c(Landroid/content/Context;Ljava/lang/String;)Ljava/lang/String; .locals 3 invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z move-result v0 const/4 v1, 0x0 if-eqz v0, :cond_0 return-object v1 :cond_0 :try_start_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v2, "tbs.conf" invoke-direct {v0, p1, v2}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result p1 if-nez p1, :cond_1 return-object v1 :cond_1 new-instance p1, Ljava/util/Properties; invoke-direct {p1}, Ljava/util/Properties;->()V new-instance v2, Ljava/io/FileInputStream; invoke-direct {v2, v0}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v0, Ljava/io/BufferedInputStream; invoke-direct {v0, v2}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_2 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 invoke-virtual {p1, v0}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V invoke-virtual {v0}, Ljava/io/BufferedInputStream;->close()V invoke-virtual {p1, p2}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_3 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :try_start_2 invoke-virtual {v0}, Ljava/io/BufferedInputStream;->close()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 :catch_0 return-object p1 :catchall_0 move-exception p1 move-object v1, v0 goto :goto_0 :catchall_1 move-exception p1 :goto_0 if-eqz v1, :cond_2 :try_start_3 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_3 .catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_1 :catch_1 :cond_2 throw p1 :catch_2 move-object v0, v1 :catch_3 if-eqz v0, :cond_3 :try_start_4 invoke-virtual {v0}, Ljava/io/BufferedInputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_4 :catch_4 :cond_3 return-object v1 .end method .method c(Landroid/content/Context;)Z .locals 9 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "tbs.conf" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result p1 const/4 v1, 0x0 if-nez p1, :cond_0 return v1 :cond_0 new-instance p1, Ljava/util/Properties; invoke-direct {p1}, Ljava/util/Properties;->()V const/4 v2, 0x0 :try_start_0 new-instance v3, Ljava/io/FileInputStream; invoke-direct {v3, v0}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v4, Ljava/io/BufferedInputStream; invoke-direct {v4, v3}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_3 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 invoke-virtual {p1, v4}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V const-string v2, "tbs_local_installation" const-string v3, "false" invoke-virtual {p1, v2, v3}, Ljava/util/Properties;->getProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String; move-result-object p1 invoke-static {p1}, Ljava/lang/Boolean;->valueOf(Ljava/lang/String;)Ljava/lang/Boolean; move-result-object p1 invoke-virtual {p1}, Ljava/lang/Boolean;->booleanValue()Z move-result p1 :try_end_1 .catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_1} :catch_2 .catchall {:try_start_1 .. :try_end_1} :catchall_0 const/4 v2, 0x1 if-eqz p1, :cond_1 :try_start_2 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v5 invoke-virtual {v0}, Ljava/io/File;->lastModified()J move-result-wide v7 const/4 v0, 0x0 sub-long/2addr v5, v7 const-wide/32 v7, 0xf731400 cmp-long v0, v5, v7 if-lez v0, :cond_1 const/4 v1, 0x1 goto :goto_0 :catch_0 move-exception v0 move-object v2, v4 goto :goto_2 :cond_1 :goto_0 const-string v0, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v5, "TBS_LOCAL_INSTALLATION is:" invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; const-string v5, " expired=" invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v0, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_2 .catch Ljava/lang/Throwable; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_0 xor-int/lit8 v0, v1, 0x1 and-int/2addr p1, v0 :try_start_3 invoke-virtual {v4}, Ljava/io/BufferedInputStream;->close()V :try_end_3 .catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_1 goto :goto_3 :catch_1 move-exception v0 invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V goto :goto_3 :catchall_0 move-exception p1 goto :goto_4 :catch_2 move-exception v0 move-object v2, v4 goto :goto_1 :catchall_1 move-exception p1 move-object v4, v2 goto :goto_4 :catch_3 move-exception v0 :goto_1 const/4 p1, 0x0 :goto_2 :try_start_4 invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_1 if-eqz v2, :cond_2 :try_start_5 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_1 :cond_2 :goto_3 return p1 :goto_4 if-eqz v4, :cond_3 :try_start_6 invoke-virtual {v4}, Ljava/io/BufferedInputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_4 goto :goto_5 :catch_4 move-exception v0 invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V :cond_3 :goto_5 throw p1 .end method .method public d(Landroid/content/Context;)V .locals 5 :try_start_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "tbs.conf" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V new-instance p1, Ljava/util/Properties; invoke-direct {p1}, Ljava/util/Properties;->()V :try_end_0 .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_0} :catch_7 const/4 v1, 0x0 :try_start_1 new-instance v2, Ljava/io/FileInputStream; invoke-direct {v2, v0}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v3, Ljava/io/BufferedInputStream; invoke-direct {v3, v2}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_1 .catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_1} :catch_5 .catchall {:try_start_1 .. :try_end_1} :catchall_2 :try_start_2 invoke-virtual {p1, v3}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V new-instance v2, Ljava/io/FileOutputStream; invoke-direct {v2, v0}, Ljava/io/FileOutputStream;->(Ljava/io/File;)V new-instance v0, Ljava/io/BufferedOutputStream; invoke-direct {v0, v2}, Ljava/io/BufferedOutputStream;->(Ljava/io/OutputStream;)V :try_end_2 .catch Ljava/lang/Throwable; {:try_start_2 .. :try_end_2} :catch_2 .catchall {:try_start_2 .. :try_end_2} :catchall_1 :try_start_3 const-string v2, "tbs_local_installation" const-string v4, "false" invoke-virtual {p1, v2, v4}, Ljava/util/Properties;->setProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object; invoke-virtual {p1, v0, v1}, Ljava/util/Properties;->store(Ljava/io/OutputStream;Ljava/lang/String;)V :try_end_3 .catch Ljava/lang/Throwable; {:try_start_3 .. :try_end_3} :catch_1 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :try_start_4 invoke-virtual {v0}, Ljava/io/BufferedOutputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_0 .catch Ljava/lang/Throwable; {:try_start_4 .. :try_end_4} :catch_7 :catch_0 :goto_0 :try_start_5 invoke-virtual {v3}, Ljava/io/BufferedInputStream;->close()V :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_7 .catch Ljava/lang/Throwable; {:try_start_5 .. :try_end_5} :catch_7 goto :goto_5 :catchall_0 move-exception p1 move-object v1, v0 goto :goto_1 :catch_1 move-object v1, v0 goto :goto_3 :catchall_1 move-exception p1 goto :goto_1 :catch_2 nop goto :goto_3 :catchall_2 move-exception p1 move-object v3, v1 :goto_1 if-eqz v1, :cond_0 :try_start_6 invoke-virtual {v1}, Ljava/io/BufferedOutputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_3 .catch Ljava/lang/Throwable; {:try_start_6 .. :try_end_6} :catch_7 goto :goto_2 :catch_3 nop :cond_0 :goto_2 if-eqz v3, :cond_1 :try_start_7 invoke-virtual {v3}, Ljava/io/BufferedInputStream;->close()V :try_end_7 .catch Ljava/io/IOException; {:try_start_7 .. :try_end_7} :catch_4 .catch Ljava/lang/Throwable; {:try_start_7 .. :try_end_7} :catch_7 :catch_4 :cond_1 :try_start_8 throw p1 :try_end_8 .catch Ljava/lang/Throwable; {:try_start_8 .. :try_end_8} :catch_7 :catch_5 move-object v3, v1 :goto_3 if-eqz v1, :cond_2 :try_start_9 invoke-virtual {v1}, Ljava/io/BufferedOutputStream;->close()V :try_end_9 .catch Ljava/io/IOException; {:try_start_9 .. :try_end_9} :catch_6 .catch Ljava/lang/Throwable; {:try_start_9 .. :try_end_9} :catch_7 goto :goto_4 :catch_6 nop :cond_2 :goto_4 if-eqz v3, :cond_3 goto :goto_0 :catch_7 :cond_3 :goto_5 return-void .end method .method public e(Landroid/content/Context;)Z .locals 8 const/4 v0, 0x0 :try_start_0 new-instance v1, Ljava/io/File; const/4 v2, 0x4 invoke-static {p1, v2}, Lcom/tencent/smtt/utils/k;->a(Landroid/content/Context;I)Ljava/lang/String; move-result-object v2 const-string v3, "x5.tbs.decouple" invoke-direct {v1, v2, v3}, Ljava/io/File;->(Ljava/lang/String;Ljava/lang/String;)V invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v2 invoke-virtual {v2, p1}, Lcom/tencent/smtt/sdk/am;->s(Landroid/content/Context;)Ljava/io/File; move-result-object v2 invoke-static {v2}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;)Z const/4 v3, 0x1 invoke-static {v2, v3}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-static {v1, v2}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Ljava/io/File;)Z invoke-virtual {v2}, Ljava/io/File;->list()[Ljava/lang/String; move-result-object v1 const/4 v4, 0x0 :goto_0 array-length v5, v1 if-ge v4, v5, :cond_1 new-instance v5, Ljava/io/File; aget-object v6, v1, v4 invoke-direct {v5, v2, v6}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v5}, Ljava/io/File;->getName()Ljava/lang/String; move-result-object v6 const-string v7, ".dex" invoke-virtual {v6, v7}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z move-result v6 if-eqz v6, :cond_0 invoke-virtual {v5}, Ljava/io/File;->delete()Z :cond_0 add-int/lit8 v4, v4, 0x1 goto :goto_0 :cond_1 invoke-static {}, Lcom/tencent/smtt/sdk/am;->a()Lcom/tencent/smtt/sdk/am; move-result-object v1 invoke-direct {v1, p1, v3}, Lcom/tencent/smtt/sdk/am;->f(Landroid/content/Context;Z)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->n(Landroid/content/Context;)Ljava/io/File; move-result-object v1 invoke-static {v1, v3}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-virtual {v2, v1}, Ljava/io/File;->renameTo(Ljava/io/File;)Z invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->b(Landroid/content/Context;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 return v3 :catch_0 return v0 .end method .method f(Landroid/content/Context;)Z .locals 5 invoke-static {}, Lcom/tencent/smtt/sdk/TbsShareManager;->getHostCorePathAppDefined()Ljava/lang/String; move-result-object v0 const/4 v1, 0x1 if-eqz v0, :cond_0 return v1 :cond_0 const/4 v0, 0x0 :try_start_0 invoke-virtual {p1}, Landroid/content/Context;->getPackageManager()Landroid/content/pm/PackageManager; move-result-object v2 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 const/16 v4, 0x40 invoke-virtual {v2, v3, v4}, Landroid/content/pm/PackageManager;->getPackageInfo(Ljava/lang/String;I)Landroid/content/pm/PackageInfo; move-result-object v2 iget-object v2, v2, Landroid/content/pm/PackageInfo;->signatures:[Landroid/content/pm/Signature; aget-object v2, v2, v0 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 const-string v4, "com.tencent.mtt" invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_1 invoke-virtual {v2}, Landroid/content/pm/Signature;->toCharsString()Ljava/lang/String; move-result-object p1 const-string v2, "3082023f308201a8a00302010202044c46914a300d06092a864886f70d01010505003064310b30090603550406130238363110300e060355040813074265696a696e673110300e060355040713074265696a696e673110300e060355040a130754656e63656e74310c300a060355040b13035753443111300f0603550403130873616d75656c6d6f301e170d3130303732313036313835305a170d3430303731333036313835305a3064310b30090603550406130238363110300e060355040813074265696a696e673110300e060355040713074265696a696e673110300e060355040a130754656e63656e74310c300a060355040b13035753443111300f0603550403130873616d75656c6d6f30819f300d06092a864886f70d010101050003818d0030818902818100c209077044bd0d63ea00ede5b839914cabcc912a87f0f8b390877e0f7a2583f0d5933443c40431c35a4433bc4c965800141961adc44c9625b1d321385221fd097e5bdc2f44a1840d643ab59dc070cf6c4b4b4d98bed5cbb8046e0a7078ae134da107cdf2bfc9b440fe5cb2f7549b44b73202cc6f7c2c55b8cfb0d333a021f01f0203010001300d06092a864886f70d010105050003818100b007db9922774ef4ccfee81ba514a8d57c410257e7a2eba64bfa17c9e690da08106d32f637ac41fbc9f205176c71bde238c872c3ee2f8313502bee44c80288ea4ef377a6f2cdfe4d3653c145c4acfedbfbadea23b559d41980cc3cdd35d79a68240693739aabf5c5ed26148756cf88264226de394c8a24ac35b712b120d4d23a" invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-nez p1, :cond_6 return v0 :cond_1 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 const-string v4, "com.tencent.mm" invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_2 invoke-virtual {v2}, Landroid/content/pm/Signature;->toCharsString()Ljava/lang/String; move-result-object p1 const-string v2, "308202eb30820254a00302010202044d36f7a4300d06092a864886f70d01010505003081b9310b300906035504061302383631123010060355040813094775616e67646f6e673111300f060355040713085368656e7a68656e31353033060355040a132c54656e63656e7420546563686e6f6c6f6779285368656e7a68656e2920436f6d70616e79204c696d69746564313a3038060355040b133154656e63656e74204775616e677a686f7520526573656172636820616e6420446576656c6f706d656e742043656e7465723110300e0603550403130754656e63656e74301e170d3131303131393134333933325a170d3431303131313134333933325a3081b9310b300906035504061302383631123010060355040813094775616e67646f6e673111300f060355040713085368656e7a68656e31353033060355040a132c54656e63656e7420546563686e6f6c6f6779285368656e7a68656e2920436f6d70616e79204c696d69746564313a3038060355040b133154656e63656e74204775616e677a686f7520526573656172636820616e6420446576656c6f706d656e742043656e7465723110300e0603550403130754656e63656e7430819f300d06092a864886f70d010101050003818d0030818902818100c05f34b231b083fb1323670bfbe7bdab40c0c0a6efc87ef2072a1ff0d60cc67c8edb0d0847f210bea6cbfaa241be70c86daf56be08b723c859e52428a064555d80db448cdcacc1aea2501eba06f8bad12a4fa49d85cacd7abeb68945a5cb5e061629b52e3254c373550ee4e40cb7c8ae6f7a8151ccd8df582d446f39ae0c5e930203010001300d06092a864886f70d0101050500038181009c8d9d7f2f908c42081b4c764c377109a8b2c70582422125ce545842d5f520aea69550b6bd8bfd94e987b75a3077eb04ad341f481aac266e89d3864456e69fba13df018acdc168b9a19dfd7ad9d9cc6f6ace57c746515f71234df3a053e33ba93ece5cd0fc15f3e389a3f365588a9fcb439e069d3629cd7732a13fff7b891499" invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-nez p1, :cond_6 return v0 :cond_2 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 const-string v4, "com.tencent.mobileqq" invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_3 invoke-virtual {v2}, Landroid/content/pm/Signature;->toCharsString()Ljava/lang/String; move-result-object p1 const-string v2, "30820253308201bca00302010202044bbb0361300d06092a864886f70d0101050500306d310e300c060355040613054368696e61310f300d06035504080c06e58c97e4baac310f300d06035504070c06e58c97e4baac310f300d060355040a0c06e885bee8aeaf311b3019060355040b0c12e697a0e7babfe4b89ae58aa1e7b3bbe7bb9f310b30090603550403130251513020170d3130303430363039343831375a180f32323834303132303039343831375a306d310e300c060355040613054368696e61310f300d06035504080c06e58c97e4baac310f300d06035504070c06e58c97e4baac310f300d060355040a0c06e885bee8aeaf311b3019060355040b0c12e697a0e7babfe4b89ae58aa1e7b3bbe7bb9f310b300906035504031302515130819f300d06092a864886f70d010101050003818d0030818902818100a15e9756216f694c5915e0b529095254367c4e64faeff07ae13488d946615a58ddc31a415f717d019edc6d30b9603d3e2a7b3de0ab7e0cf52dfee39373bc472fa997027d798d59f81d525a69ecf156e885fd1e2790924386b2230cc90e3b7adc95603ddcf4c40bdc72f22db0f216a99c371d3bf89cba6578c60699e8a0d536950203010001300d06092a864886f70d01010505000381810094a9b80e80691645dd42d6611775a855f71bcd4d77cb60a8e29404035a5e00b21bcc5d4a562482126bd91b6b0e50709377ceb9ef8c2efd12cc8b16afd9a159f350bb270b14204ff065d843832720702e28b41491fbc3a205f5f2f42526d67f17614d8a974de6487b2c866efede3b4e49a0f916baa3c1336fd2ee1b1629652049" invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-nez p1, :cond_6 return v0 :cond_3 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 const-string v4, "com.tencent.tbs" invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_4 invoke-virtual {v2}, Landroid/content/pm/Signature;->toCharsString()Ljava/lang/String; move-result-object p1 const-string v2, "3082023f308201a8a00302010202044c46914a300d06092a864886f70d01010505003064310b30090603550406130238363110300e060355040813074265696a696e673110300e060355040713074265696a696e673110300e060355040a130754656e63656e74310c300a060355040b13035753443111300f0603550403130873616d75656c6d6f301e170d3130303732313036313835305a170d3430303731333036313835305a3064310b30090603550406130238363110300e060355040813074265696a696e673110300e060355040713074265696a696e673110300e060355040a130754656e63656e74310c300a060355040b13035753443111300f0603550403130873616d75656c6d6f30819f300d06092a864886f70d010101050003818d0030818902818100c209077044bd0d63ea00ede5b839914cabcc912a87f0f8b390877e0f7a2583f0d5933443c40431c35a4433bc4c965800141961adc44c9625b1d321385221fd097e5bdc2f44a1840d643ab59dc070cf6c4b4b4d98bed5cbb8046e0a7078ae134da107cdf2bfc9b440fe5cb2f7549b44b73202cc6f7c2c55b8cfb0d333a021f01f0203010001300d06092a864886f70d010105050003818100b007db9922774ef4ccfee81ba514a8d57c410257e7a2eba64bfa17c9e690da08106d32f637ac41fbc9f205176c71bde238c872c3ee2f8313502bee44c80288ea4ef377a6f2cdfe4d3653c145c4acfedbfbadea23b559d41980cc3cdd35d79a68240693739aabf5c5ed26148756cf88264226de394c8a24ac35b712b120d4d23a" invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-nez p1, :cond_6 return v0 :cond_4 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v3 const-string v4, "com.qzone" invoke-virtual {v3, v4}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_5 invoke-virtual {v2}, Landroid/content/pm/Signature;->toCharsString()Ljava/lang/String; move-result-object p1 const-string v2, "308202ad30820216a00302010202044c26cea2300d06092a864886f70d010105050030819a310b3009060355040613023836311530130603550408130c4265696a696e672043697479311530130603550407130c4265696a696e67204369747931263024060355040a131d515a6f6e65205465616d206f662054656e63656e7420436f6d70616e7931183016060355040b130f54656e63656e7420436f6d70616e79311b301906035504031312416e64726f696420515a6f6e65205465616d301e170d3130303632373034303830325a170d3335303632313034303830325a30819a310b3009060355040613023836311530130603550408130c4265696a696e672043697479311530130603550407130c4265696a696e67204369747931263024060355040a131d515a6f6e65205465616d206f662054656e63656e7420436f6d70616e7931183016060355040b130f54656e63656e7420436f6d70616e79311b301906035504031312416e64726f696420515a6f6e65205465616d30819f300d06092a864886f70d010101050003818d003081890281810082d6aca037a9843fbbe88b6dd19f36e9c24ce174c1b398f3a529e2a7fe02de99c27539602c026edf96ad8d43df32a85458bca1e6fbf11958658a7d6751a1d9b782bf43a8c19bd1c06bdbfd94c0516326ae3cf638ac42bb470580e340c46e6f306a772c1ef98f10a559edf867f3f31fe492808776b7bd953b2cba2d2b2d66a44f0203010001300d06092a864886f70d0101050500038181006003b04a8a8c5be9650f350cda6896e57dd13e6e83e7f891fc70f6a3c2eaf75cfa4fc998365deabbd1b9092159edf4b90df5702a0d101f8840b5d4586eb92a1c3cd19d95fbc1c2ac956309eda8eef3944baf08c4a49d3b9b3ffb06bc13dab94ecb5b8eb74e8789aa0ba21cb567f538bbc59c2a11e6919924a24272eb79251677" invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-nez p1, :cond_6 return v0 :cond_5 invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object p1 const-string v3, "com.tencent.qqpimsecure" invoke-virtual {p1, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 if-eqz p1, :cond_6 invoke-virtual {v2}, Landroid/content/pm/Signature;->toCharsString()Ljava/lang/String; move-result-object p1 const-string v2, "30820239308201a2a00302010202044c96f48f300d06092a864886f70d01010505003060310b300906035504061302434e310b300906035504081302474431123010060355040713094775616e677a686f753110300e060355040a130754656e63656e74310b3009060355040b130233473111300f0603550403130857696c736f6e57753020170d3130303932303035343334335a180f32303635303632333035343334335a3060310b300906035504061302434e310b300906035504081302474431123010060355040713094775616e677a686f753110300e060355040a130754656e63656e74310b3009060355040b130233473111300f0603550403130857696c736f6e577530819f300d06092a864886f70d010101050003818d0030818902818100b56e79dbb1185a79e52d792bb3d0bb3da8010d9b87da92ec69f7dc5ad66ab6bfdff2a6a1ed285dd2358f28b72a468be7c10a2ce30c4c27323ed4edcc936080e5bedc2cbbca0b7e879c08a631182793f44bb3ea284179b263410c298e5f6831032c9702ba4a74e2ccfc9ef857f12201451602fc8e774ac59d6398511586c83d1d0203010001300d06092a864886f70d0101050500038181002475615bb65b8d8786b890535802948840387d06b1692ff3ea47ef4c435719ba1865b81e6bfa6293ce31747c3cd6b34595b485cc1563fd90107ba5845c28b95c79138f0dec288940395bc10f92f2b69d8dc410999deb38900974ce9984b678030edfba8816582f56160d87e38641288d8588d2a31e20b89f223d788dd35cc9c8" invoke-virtual {p1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result p1 :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 if-nez p1, :cond_6 return v0 :cond_6 return v1 :catch_0 const-string p1, "TbsInstaller" const-string v1, "TbsInstaller-installLocalTbsCore getPackageInfo fail" invoke-static {p1, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v0 .end method .method g(Landroid/content/Context;)I .locals 5 const/4 v0, 0x0 const/4 v1, 0x0 :try_start_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->r(Landroid/content/Context;)Ljava/io/File; move-result-object p1 const-string v2, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "TbsInstaller--getTmpTbsCoreVersionUnzipDir tbsShareDir is " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-static {v2, v3}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V new-instance v2, Ljava/io/File; const-string v3, "tbs.conf" invoke-direct {v2, p1, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p1 if-nez p1, :cond_0 return v0 :cond_0 new-instance p1, Ljava/util/Properties; invoke-direct {p1}, Ljava/util/Properties;->()V new-instance v3, Ljava/io/FileInputStream; invoke-direct {v3, v2}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v2, Ljava/io/BufferedInputStream; invoke-direct {v2, v3}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_4 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 invoke-virtual {p1, v2}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V const-string v1, "tbs_core_version" invoke-virtual {p1, v1}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_2 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-nez p1, :cond_1 :try_start_2 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 :catch_0 return v0 :cond_1 :try_start_3 invoke-static {p1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I move-result p1 :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_2 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :try_start_4 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_1 :catch_1 return p1 :catchall_0 move-exception p1 move-object v1, v2 goto :goto_0 :catch_2 move-object v1, v2 goto :goto_1 :catchall_1 move-exception p1 :goto_0 if-eqz v1, :cond_2 :try_start_5 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_3 :catch_3 :cond_2 throw p1 :catch_4 :goto_1 if-eqz v1, :cond_3 :try_start_6 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_5 :catch_5 :cond_3 return v0 .end method .method h(Landroid/content/Context;)I .locals 4 const/4 v0, 0x0 const/4 v1, 0x0 :try_start_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->n(Landroid/content/Context;)Ljava/io/File; move-result-object p1 new-instance v2, Ljava/io/File; const-string v3, "tbs.conf" invoke-direct {v2, p1, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p1 if-nez p1, :cond_0 return v0 :cond_0 new-instance p1, Ljava/util/Properties; invoke-direct {p1}, Ljava/util/Properties;->()V new-instance v3, Ljava/io/FileInputStream; invoke-direct {v3, v2}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v2, Ljava/io/BufferedInputStream; invoke-direct {v2, v3}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_4 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 invoke-virtual {p1, v2}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V const-string v1, "tbs_core_version" invoke-virtual {p1, v1}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_2 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-nez p1, :cond_1 :try_start_2 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 :catch_0 return v0 :cond_1 :try_start_3 invoke-static {p1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I move-result p1 :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_2 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :try_start_4 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_1 :catch_1 return p1 :catchall_0 move-exception p1 move-object v1, v2 goto :goto_0 :catch_2 move-object v1, v2 goto :goto_1 :catchall_1 move-exception p1 :goto_0 if-eqz v1, :cond_2 :try_start_5 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_3 :catch_3 :cond_2 throw p1 :catch_4 :goto_1 if-eqz v1, :cond_3 :try_start_6 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_5 :catch_5 :cond_3 return v0 .end method .method i(Landroid/content/Context;)I .locals 5 const/4 v0, 0x0 const/4 v1, 0x0 :try_start_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p1 new-instance v2, Ljava/io/File; const-string v3, "tbs.conf" invoke-direct {v2, p1, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p1 if-nez p1, :cond_0 return v0 :cond_0 new-instance p1, Ljava/util/Properties; invoke-direct {p1}, Ljava/util/Properties;->()V new-instance v3, Ljava/io/FileInputStream; invoke-direct {v3, v2}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v2, Ljava/io/BufferedInputStream; invoke-direct {v2, v3}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_3 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 invoke-virtual {p1, v2}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V const-string v1, "tbs_core_version" invoke-virtual {p1, v1}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_2 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-nez p1, :cond_1 :try_start_2 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_0 goto :goto_0 :catch_0 move-exception p1 const-string v1, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller--getTbsCoreInstalledVerInNolock IOException=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {v1, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :goto_0 return v0 :cond_1 :try_start_3 invoke-static {p1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I move-result p1 :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_2 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :try_start_4 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_1 goto :goto_1 :catch_1 move-exception v0 const-string v1, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller--getTbsCoreInstalledVerInNolock IOException=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-static {v1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :goto_1 return p1 :catchall_0 move-exception p1 move-object v1, v2 goto :goto_4 :catch_2 move-exception p1 move-object v1, v2 goto :goto_2 :catchall_1 move-exception p1 goto :goto_4 :catch_3 move-exception p1 :goto_2 :try_start_5 const-string v2, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "TbsInstaller--getTbsCoreInstalledVerInNolock Exception=" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {v2, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_1 if-eqz v1, :cond_2 :try_start_6 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_4 goto :goto_3 :catch_4 move-exception p1 const-string v1, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller--getTbsCoreInstalledVerInNolock IOException=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {v1, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :cond_2 :goto_3 return v0 :goto_4 if-eqz v1, :cond_3 :try_start_7 invoke-virtual {v1}, Ljava/io/BufferedInputStream;->close()V :try_end_7 .catch Ljava/io/IOException; {:try_start_7 .. :try_end_7} :catch_5 goto :goto_5 :catch_5 move-exception v0 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller--getTbsCoreInstalledVerInNolock IOException=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 const-string v1, "TbsInstaller" invoke-static {v1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :cond_3 :goto_5 throw p1 .end method .method j(Landroid/content/Context;)Z .locals 2 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "tbs.conf" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result p1 if-nez p1, :cond_0 const/4 p1, 0x0 return p1 :cond_0 const/4 p1, 0x1 return p1 .end method .method k(Landroid/content/Context;)I .locals 5 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->u(Landroid/content/Context;)Z move-result v0 if-nez v0, :cond_0 const/4 p1, -0x1 return p1 :cond_0 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->tryLock()Z move-result v0 const-string v1, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller--getTbsCoreInstalledVer locked=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v1, v2}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V const/4 v1, 0x0 if-eqz v0, :cond_5 const/4 v0, 0x0 :try_start_0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object p1 new-instance v2, Ljava/io/File; const-string v3, "tbs.conf" invoke-direct {v2, p1, v3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v2}, Ljava/io/File;->exists()Z move-result p1 :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_3 .catchall {:try_start_0 .. :try_end_0} :catchall_1 if-nez p1, :cond_1 sget-object p1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {p1}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V return v1 :cond_1 :try_start_1 new-instance p1, Ljava/util/Properties; invoke-direct {p1}, Ljava/util/Properties;->()V new-instance v3, Ljava/io/FileInputStream; invoke-direct {v3, v2}, Ljava/io/FileInputStream;->(Ljava/io/File;)V new-instance v2, Ljava/io/BufferedInputStream; invoke-direct {v2, v3}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_3 .catchall {:try_start_1 .. :try_end_1} :catchall_1 :try_start_2 invoke-virtual {p1, v2}, Ljava/util/Properties;->load(Ljava/io/InputStream;)V invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V const-string v0, "tbs_core_version" invoke-virtual {p1, v0}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String; move-result-object p1 :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 if-nez p1, :cond_2 :try_start_3 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_3 .catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_0 goto :goto_0 :catch_0 move-exception p1 const-string v0, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller--getTbsCoreInstalledVer IOException=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {v0, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :goto_0 sget-object p1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {p1}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V return v1 :cond_2 :try_start_4 sget-object v0, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; invoke-static {p1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I move-result p1 invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p1 invoke-virtual {v0, p1}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V sget-object p1, Lcom/tencent/smtt/sdk/am;->a:Ljava/lang/ThreadLocal; invoke-virtual {p1}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/Integer; invoke-virtual {p1}, Ljava/lang/Integer;->intValue()I move-result p1 :try_end_4 .catch Ljava/lang/Exception; {:try_start_4 .. :try_end_4} :catch_2 .catchall {:try_start_4 .. :try_end_4} :catchall_0 :try_start_5 invoke-virtual {v2}, Ljava/io/BufferedInputStream;->close()V :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_1 goto :goto_1 :catch_1 move-exception v0 const-string v1, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller--getTbsCoreInstalledVer IOException=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-static {v1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :goto_1 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V return p1 :catchall_0 move-exception p1 move-object v0, v2 goto :goto_4 :catch_2 move-exception p1 move-object v0, v2 goto :goto_2 :catchall_1 move-exception p1 goto :goto_4 :catch_3 move-exception p1 :goto_2 :try_start_6 const-string v2, "TbsInstaller" new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "TbsInstaller--getTbsCoreInstalledVer Exception=" invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {v2, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_6 .catchall {:try_start_6 .. :try_end_6} :catchall_1 if-eqz v0, :cond_3 :try_start_7 invoke-virtual {v0}, Ljava/io/BufferedInputStream;->close()V :try_end_7 .catch Ljava/io/IOException; {:try_start_7 .. :try_end_7} :catch_4 goto :goto_3 :catch_4 move-exception p1 const-string v0, "TbsInstaller" new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "TbsInstaller--getTbsCoreInstalledVer IOException=" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-static {v0, p1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :cond_3 :goto_3 sget-object p1, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {p1}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V return v1 :goto_4 if-eqz v0, :cond_4 :try_start_8 invoke-virtual {v0}, Ljava/io/BufferedInputStream;->close()V :try_end_8 .catch Ljava/io/IOException; {:try_start_8 .. :try_end_8} :catch_5 goto :goto_5 :catch_5 move-exception v0 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "TbsInstaller--getTbsCoreInstalledVer IOException=" invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/io/IOException;->toString()Ljava/lang/String; move-result-object v0 invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 const-string v1, "TbsInstaller" invoke-static {v1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :cond_4 :goto_5 sget-object v0, Lcom/tencent/smtt/sdk/am;->h:Ljava/util/concurrent/locks/Lock; invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V throw p1 :cond_5 invoke-virtual {p0}, Lcom/tencent/smtt/sdk/am;->b()V return v1 .end method .method public l(Landroid/content/Context;)Z .locals 4 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--coreShareCopyToDecouple #0" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->o(Landroid/content/Context;)Ljava/io/File; move-result-object v0 invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->n(Landroid/content/Context;)Ljava/io/File; move-result-object v1 const/4 v2, 0x1 :try_start_0 invoke-static {v1, v2}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V new-instance v3, Lcom/tencent/smtt/sdk/as; invoke-direct {v3, p0}, Lcom/tencent/smtt/sdk/as;->(Lcom/tencent/smtt/sdk/am;)V invoke-static {v0, v1, v3}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Ljava/io/File;Ljava/io/FileFilter;)Z invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsShareManager;->b(Landroid/content/Context;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 const-string p1, "TbsInstaller" const-string v0, "TbsInstaller--coreShareCopyToDecouple success!!!" invoke-static {p1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V return v2 :catch_0 const/4 p1, 0x0 return p1 .end method .method m(Landroid/content/Context;)V .locals 5 const-string v0, "TbsInstaller" const-string v1, "TbsInstaller--cleanStatusAndTmpDir" invoke-static {v0, v1}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const/4 v1, 0x0 invoke-virtual {v0, v1}, Lcom/tencent/smtt/sdk/ai;->a(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v1}, Lcom/tencent/smtt/sdk/ai;->b(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v1}, Lcom/tencent/smtt/sdk/ai;->d(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const-string v2, "incrupdate_retry_num" invoke-virtual {v0, v2, v1}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->getInstance(Landroid/content/Context;)Lcom/tencent/smtt/sdk/TbsDownloadConfig; move-result-object v0 iget-object v0, v0, Lcom/tencent/smtt/sdk/TbsDownloadConfig;->mPreferences:Landroid/content/SharedPreferences; const-string v2, "tbs_downloaddecouplecore" invoke-interface {v0, v2, v1}, Landroid/content/SharedPreferences;->getInt(Ljava/lang/String;I)I move-result v0 const/4 v2, 0x1 if-eq v0, v2, :cond_0 invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const/4 v3, -0x1 invoke-virtual {v0, v1, v3}, Lcom/tencent/smtt/sdk/ai;->b(II)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const-string v4, "" invoke-virtual {v0, v4}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 const-string v4, "copy_retry_num" invoke-virtual {v0, v4, v1}, Lcom/tencent/smtt/sdk/ai;->a(Ljava/lang/String;I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v3}, Lcom/tencent/smtt/sdk/ai;->c(I)V invoke-static {p1}, Lcom/tencent/smtt/sdk/ai;->a(Landroid/content/Context;)Lcom/tencent/smtt/sdk/ai; move-result-object v0 invoke-virtual {v0, v1, v3}, Lcom/tencent/smtt/sdk/ai;->a(II)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->r(Landroid/content/Context;)Ljava/io/File; move-result-object v0 invoke-static {v0, v2}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V invoke-virtual {p0, p1}, Lcom/tencent/smtt/sdk/am;->t(Landroid/content/Context;)Ljava/io/File; move-result-object p1 invoke-static {p1, v2}, Lcom/tencent/smtt/utils/k;->a(Ljava/io/File;Z)V :cond_0 return-void .end method .method n(Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p1, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "core_share_decouple" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p1 if-nez p1, :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p1 if-nez p1, :cond_0 const/4 p1, 0x0 return-object p1 :cond_0 return-object v0 .end method .method o(Landroid/content/Context;)Ljava/io/File; .locals 1 const/4 v0, 0x0 invoke-virtual {p0, v0, p1}, Lcom/tencent/smtt/sdk/am;->b(Landroid/content/Context;Landroid/content/Context;)Ljava/io/File; move-result-object p1 return-object p1 .end method .method p(Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p1, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "share" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p1 if-nez p1, :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p1 if-nez p1, :cond_0 const/4 p1, 0x0 return-object p1 :cond_0 return-object v0 .end method .method r(Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p1, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "core_unzip_tmp" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p1 if-nez p1, :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p1 if-nez p1, :cond_0 const/4 p1, 0x0 return-object p1 :cond_0 return-object v0 .end method .method s(Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p1, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "core_unzip_tmp_decouple" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p1 if-nez p1, :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p1 if-nez p1, :cond_0 const/4 p1, 0x0 return-object p1 :cond_0 return-object v0 .end method .method t(Landroid/content/Context;)Ljava/io/File; .locals 2 const-string v0, "tbs" const/4 v1, 0x0 invoke-virtual {p1, v0, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File; move-result-object p1 new-instance v0, Ljava/io/File; const-string v1, "core_copy_tmp" invoke-direct {v0, p1, v1}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z move-result p1 if-nez p1, :cond_0 invoke-virtual {v0}, Ljava/io/File;->mkdir()Z move-result p1 if-nez p1, :cond_0 const/4 p1, 0x0 return-object p1 :cond_0 return-object v0 .end method .method declared-synchronized u(Landroid/content/Context;)Z .locals 3 monitor-enter p0 :try_start_0 iget v0, p0, Lcom/tencent/smtt/sdk/am;->d:I const/4 v1, 0x1 add-int/2addr v0, v1 iput v0, p0, Lcom/tencent/smtt/sdk/am;->d:I iget-boolean v0, p0, Lcom/tencent/smtt/sdk/am;->g:Z if-eqz v0, :cond_0 const-string p1, "TbsInstaller" const-string v0, "getTbsInstallingFileLock success,is cached= true" invoke-static {p1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 monitor-exit p0 return v1 :cond_0 :try_start_1 const-string v0, "tbslock.txt" invoke-static {p1, v1, v0}, Lcom/tencent/smtt/utils/k;->b(Landroid/content/Context;ZLjava/lang/String;)Ljava/io/FileOutputStream; move-result-object v0 iput-object v0, p0, Lcom/tencent/smtt/sdk/am;->f:Ljava/io/FileOutputStream; iget-object v0, p0, Lcom/tencent/smtt/sdk/am;->f:Ljava/io/FileOutputStream; const/4 v2, 0x0 if-eqz v0, :cond_2 iget-object v0, p0, Lcom/tencent/smtt/sdk/am;->f:Ljava/io/FileOutputStream; invoke-static {p1, v0}, Lcom/tencent/smtt/utils/k;->a(Landroid/content/Context;Ljava/io/FileOutputStream;)Ljava/nio/channels/FileLock; move-result-object p1 iput-object p1, p0, Lcom/tencent/smtt/sdk/am;->e:Ljava/nio/channels/FileLock; iget-object p1, p0, Lcom/tencent/smtt/sdk/am;->e:Ljava/nio/channels/FileLock; :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-nez p1, :cond_1 monitor-exit p0 return v2 :cond_1 :try_start_2 const-string p1, "TbsInstaller" const-string v0, "getTbsInstallingFileLock success,is cached= false" invoke-static {p1, v0}, Lcom/tencent/smtt/utils/TbsLog;->i(Ljava/lang/String;Ljava/lang/String;)V iput-boolean v1, p0, Lcom/tencent/smtt/sdk/am;->g:Z :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 monitor-exit p0 return v1 :cond_2 monitor-exit p0 return v2 :catchall_0 move-exception p1 monitor-exit p0 throw p1 .end method