2022-06-10 21:38:30 +09:00

3005 lines
82 KiB
Smali

.class public final Lcom/google/android/gms/dynamite/DynamiteModule;
.super Ljava/lang/Object;
.source "com.google.android.gms:play-services-basement@@18.0.0"
# annotations
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/google/android/gms/dynamite/DynamiteModule$DynamiteLoaderClassLoader;,
Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;,
Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
}
.end annotation
# static fields
.field public static final PREFER_HIGHEST_OR_LOCAL_VERSION:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.end field
.field public static final PREFER_HIGHEST_OR_LOCAL_VERSION_NO_FORCE_STAGING:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.end field
.field public static final PREFER_HIGHEST_OR_REMOTE_VERSION:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.end field
.field public static final PREFER_LOCAL:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.end field
.field public static final PREFER_REMOTE:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.end field
.field public static final PREFER_REMOTE_VERSION_NO_FORCE_STAGING:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.end field
.field public static final zza:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end field
.field private static zzb:Ljava/lang/Boolean; = null
.annotation build Landroidx/annotation/Nullable;
.end annotation
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "DynamiteModule.class"
.end annotation
.end field
.field private static zzc:Ljava/lang/String; = null
.annotation build Landroidx/annotation/Nullable;
.end annotation
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "DynamiteModule.class"
.end annotation
.end field
.field private static zzd:Z = false
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "DynamiteModule.class"
.end annotation
.end field
.field private static zze:I = -0x1
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "DynamiteModule.class"
.end annotation
.end field
.field private static final zzf:Ljava/lang/ThreadLocal;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/ThreadLocal<",
"Lcom/google/android/gms/dynamite/zzn;",
">;"
}
.end annotation
.end field
.field private static final zzg:Ljava/lang/ThreadLocal;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/ThreadLocal<",
"Ljava/lang/Long;",
">;"
}
.end annotation
.end field
.field private static final zzh:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$IVersions;
.field private static zzj:Lcom/google/android/gms/dynamite/zzq;
.annotation build Landroidx/annotation/Nullable;
.end annotation
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "DynamiteModule.class"
.end annotation
.end field
.field private static zzk:Lcom/google/android/gms/dynamite/zzr;
.annotation build Landroidx/annotation/Nullable;
.end annotation
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "DynamiteModule.class"
.end annotation
.end field
# instance fields
.field private final zzi:Landroid/content/Context;
# direct methods
.method public static constructor <clinit>()V
.locals 1
.line 1
new-instance v0, Ljava/lang/ThreadLocal;
invoke-direct {v0}, Ljava/lang/ThreadLocal;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf:Ljava/lang/ThreadLocal;
new-instance v0, Lcom/google/android/gms/dynamite/zzd;
.line 2
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzd;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
new-instance v0, Lcom/google/android/gms/dynamite/zze;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zze;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzh:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$IVersions;
new-instance v0, Lcom/google/android/gms/dynamite/zzf;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzf;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->PREFER_REMOTE:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
new-instance v0, Lcom/google/android/gms/dynamite/zzg;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzg;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->PREFER_LOCAL:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
new-instance v0, Lcom/google/android/gms/dynamite/zzh;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzh;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->PREFER_REMOTE_VERSION_NO_FORCE_STAGING:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
new-instance v0, Lcom/google/android/gms/dynamite/zzi;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzi;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->PREFER_HIGHEST_OR_LOCAL_VERSION:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
new-instance v0, Lcom/google/android/gms/dynamite/zzj;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzj;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->PREFER_HIGHEST_OR_LOCAL_VERSION_NO_FORCE_STAGING:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
new-instance v0, Lcom/google/android/gms/dynamite/zzk;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzk;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->PREFER_HIGHEST_OR_REMOTE_VERSION:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
new-instance v0, Lcom/google/android/gms/dynamite/zzl;
invoke-direct {v0}, Lcom/google/android/gms/dynamite/zzl;-><init>()V
sput-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zza:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
return-void
.end method
.method private constructor <init>(Landroid/content/Context;)V
.locals 0
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
invoke-static {p1}, Lcom/google/android/gms/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
iput-object p1, p0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzi:Landroid/content/Context;
return-void
.end method
.method public static getLocalVersion(Landroid/content/Context;Ljava/lang/String;)I
.locals 5
.param p0 # Landroid/content/Context;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.param p1 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
const-string v0, "DynamiteModule"
const/4 v1, 0x0
.line 1
:try_start_0
invoke-virtual {p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object p0
.line 2
invoke-virtual {p0}, Landroid/content/Context;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object p0
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v2
add-int/lit8 v2, v2, 0x3d
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3, v2}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v2, "com.google.android.gms.dynamite.descriptors."
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "."
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "ModuleDescriptor"
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 3
invoke-virtual {p0, v2}, Ljava/lang/ClassLoader;->loadClass(Ljava/lang/String;)Ljava/lang/Class;
move-result-object p0
const-string v2, "MODULE_ID"
.line 4
invoke-virtual {p0, v2}, Ljava/lang/Class;->getDeclaredField(Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v2
const-string v3, "MODULE_VERSION"
.line 5
invoke-virtual {p0, v3}, Ljava/lang/Class;->getDeclaredField(Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object p0
const/4 v3, 0x0
.line 6
invoke-virtual {v2, v3}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v4
invoke-static {v4, p1}, Lcom/google/android/gms/common/internal/Objects;->equal(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v4
if-nez v4, :cond_0
.line 7
invoke-virtual {v2, v3}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p0
invoke-static {p0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v2
add-int/lit8 v2, v2, 0x33
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/String;->length()I
move-result v3
add-int/2addr v2, v3
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3, v2}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v2, "Module descriptor id \'"
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, "\' didn\'t match expected id \'"
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, "\'"
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
.line 8
invoke-static {v0, p0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
return v1
.line 9
:cond_0
invoke-virtual {p0, v3}, Ljava/lang/reflect/Field;->getInt(Ljava/lang/Object;)I
move-result p0
:try_end_0
.catch Ljava/lang/ClassNotFoundException; {:try_start_0 .. :try_end_0} :catch_1
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
return p0
:catch_0
move-exception p0
.line 10
invoke-virtual {p0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object p0
invoke-static {p0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
const-string p1, "Failed to load module descriptor class: "
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_1
invoke-virtual {p1, p0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
goto :goto_0
:cond_1
new-instance p0, Ljava/lang/String;
invoke-direct {p0, p1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_0
invoke-static {v0, p0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_1
.line 11
:catch_1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result p0
new-instance v2, Ljava/lang/StringBuilder;
add-int/lit8 p0, p0, 0x2d
invoke-direct {v2, p0}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p0, "Local module descriptor class for "
invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, " not found."
invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-static {v0, p0}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:goto_1
return v1
.end method
.method public static getRemoteVersion(Landroid/content/Context;Ljava/lang/String;)I
.locals 1
.param p0 # Landroid/content/Context;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.param p1 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
const/4 v0, 0x0
.line 1
invoke-static {p0, p1, v0}, Lcom/google/android/gms/dynamite/DynamiteModule;->zza(Landroid/content/Context;Ljava/lang/String;Z)I
move-result p0
return p0
.end method
.method public static load(Landroid/content/Context;Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;Ljava/lang/String;)Lcom/google/android/gms/dynamite/DynamiteModule;
.locals 19
.param p0 # Landroid/content/Context;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.param p1 # Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.param p2 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
}
.end annotation
move-object/from16 v1, p0
move-object/from16 v2, p1
move-object/from16 v3, p2
.line 1
const-class v4, Lcom/google/android/gms/dynamite/DynamiteModule;
sget-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v5
check-cast v5, Lcom/google/android/gms/dynamite/zzn;
new-instance v6, Lcom/google/android/gms/dynamite/zzn;
const/4 v7, 0x0
invoke-direct {v6, v7}, Lcom/google/android/gms/dynamite/zzn;-><init>(Lcom/google/android/gms/dynamite/zzm;)V
.line 2
invoke-virtual {v0, v6}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
sget-object v8, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
.line 3
invoke-virtual {v8}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v9
check-cast v9, Ljava/lang/Long;
invoke-virtual {v9}, Ljava/lang/Long;->longValue()J
move-result-wide v9
.line 4
:try_start_0
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v13
invoke-static {v13, v14}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v13
invoke-virtual {v8, v13}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
sget-object v13, Lcom/google/android/gms/dynamite/DynamiteModule;->zzh:Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$IVersions;
.line 5
invoke-interface {v2, v1, v3, v13}, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;->selectModule(Landroid/content/Context;Ljava/lang/String;Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$IVersions;)Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;
move-result-object v13
const-string v14, "DynamiteModule"
.line 6
iget v15, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->localVersion:I
iget v7, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->remoteVersion:I
invoke-static/range {p2 .. p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v17
invoke-virtual/range {v17 .. v17}, Ljava/lang/String;->length()I
move-result v17
add-int/lit8 v17, v17, 0x44
invoke-static/range {p2 .. p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v18
invoke-virtual/range {v18 .. v18}, Ljava/lang/String;->length()I
move-result v18
add-int v11, v17, v18
new-instance v12, Ljava/lang/StringBuilder;
invoke-direct {v12, v11}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v11, "Considering local module "
invoke-virtual {v12, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, ":"
invoke-virtual {v12, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v15}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v11, " and remote module "
invoke-virtual {v12, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, ":"
invoke-virtual {v12, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-static {v14, v7}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
.line 7
iget v7, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->selection:I
if-eqz v7, :cond_18
const/4 v11, -0x1
if-ne v7, v11, :cond_0
iget v7, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->localVersion:I
if-eqz v7, :cond_18
move v7, v11
:cond_0
const/4 v12, 0x1
if-ne v7, v12, :cond_1
iget v14, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->remoteVersion:I
if-eqz v14, :cond_18
:cond_1
if-ne v7, v11, :cond_4
.line 8
invoke-static {v1, v3}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzc(Landroid/content/Context;Ljava/lang/String;)Lcom/google/android/gms/dynamite/DynamiteModule;
move-result-object v1
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_4
const-wide/16 v2, 0x0
cmp-long v2, v9, v2
if-nez v2, :cond_2
.line 9
invoke-virtual {v8}, Ljava/lang/ThreadLocal;->remove()V
goto :goto_0
.line 10
:cond_2
invoke-static {v9, v10}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
invoke-virtual {v8, v2}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
.line 11
:goto_0
iget-object v2, v6, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
if-eqz v2, :cond_3
.line 12
invoke-interface {v2}, Landroid/database/Cursor;->close()V
.line 13
:cond_3
invoke-virtual {v0, v5}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
return-object v1
:cond_4
if-ne v7, v12, :cond_17
.line 14
:try_start_1
iget v14, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->remoteVersion:I
:try_end_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_1 .. :try_end_1} :catch_2
.catchall {:try_start_1 .. :try_end_1} :catchall_4
:try_start_2
monitor-enter v4
:try_end_2
.catch Landroid/os/RemoteException; {:try_start_2 .. :try_end_2} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_2 .. :try_end_2} :catch_0
.catchall {:try_start_2 .. :try_end_2} :catchall_3
:try_start_3
sget-object v15, Lcom/google/android/gms/dynamite/DynamiteModule;->zzb:Ljava/lang/Boolean;
.line 15
monitor-exit v4
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_2
if-eqz v15, :cond_12
.line 16
:try_start_4
invoke-virtual {v15}, Ljava/lang/Boolean;->booleanValue()Z
move-result v15
const/4 v12, 0x2
if-eqz v15, :cond_a
const-string v15, "DynamiteModule"
.line 17
invoke-static/range {p2 .. p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v18
invoke-virtual/range {v18 .. v18}, Ljava/lang/String;->length()I
move-result v18
add-int/lit8 v11, v18, 0x33
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7, v11}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v11, "Selected remote version of "
invoke-virtual {v7, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, ", version >= "
invoke-virtual {v7, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7, v14}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-static {v15, v7}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
monitor-enter v4
:try_end_4
.catch Landroid/os/RemoteException; {:try_start_4 .. :try_end_4} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_4 .. :try_end_4} :catch_0
.catchall {:try_start_4 .. :try_end_4} :catchall_3
:try_start_5
sget-object v7, Lcom/google/android/gms/dynamite/DynamiteModule;->zzk:Lcom/google/android/gms/dynamite/zzr;
.line 18
monitor-exit v4
:try_end_5
.catchall {:try_start_5 .. :try_end_5} :catchall_1
if-eqz v7, :cond_9
.line 19
:try_start_6
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v11
check-cast v11, Lcom/google/android/gms/dynamite/zzn;
if-eqz v11, :cond_8
iget-object v15, v11, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
if-eqz v15, :cond_8
.line 20
invoke-virtual/range {p0 .. p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v15
iget-object v11, v11, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
const/16 v16, 0x0
.line 21
invoke-static/range {v16 .. v16}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
monitor-enter v4
:try_end_6
.catch Landroid/os/RemoteException; {:try_start_6 .. :try_end_6} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_6 .. :try_end_6} :catch_0
.catchall {:try_start_6 .. :try_end_6} :catchall_3
:try_start_7
sget v2, Lcom/google/android/gms/dynamite/DynamiteModule;->zze:I
if-lt v2, v12, :cond_5
const/4 v12, 0x1
goto :goto_1
:cond_5
const/4 v12, 0x0
.line 22
:goto_1
invoke-static {v12}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v2
monitor-exit v4
:try_end_7
.catchall {:try_start_7 .. :try_end_7} :catchall_0
.line 23
:try_start_8
invoke-virtual {v2}, Ljava/lang/Boolean;->booleanValue()Z
move-result v2
if-eqz v2, :cond_6
const-string v2, "DynamiteModule"
const-string v4, "Dynamite loader version >= 2, using loadModule2NoCrashUtils"
.line 24
invoke-static {v2, v4}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
.line 25
invoke-static {v15}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v2
.line 26
invoke-static {v11}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v4
.line 27
invoke-virtual {v7, v2, v3, v14, v4}, Lcom/google/android/gms/dynamite/zzr;->zzf(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;ILcom/google/android/gms/dynamic/IObjectWrapper;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v2
goto :goto_2
:cond_6
const-string v2, "DynamiteModule"
const-string v4, "Dynamite loader version < 2, falling back to loadModule2"
.line 28
invoke-static {v2, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 29
invoke-static {v15}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v2
.line 30
invoke-static {v11}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v4
.line 31
invoke-virtual {v7, v2, v3, v14, v4}, Lcom/google/android/gms/dynamite/zzr;->zze(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;ILcom/google/android/gms/dynamic/IObjectWrapper;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v2
.line 32
:goto_2
invoke-static {v2}, Lcom/google/android/gms/dynamic/ObjectWrapper;->unwrap(Lcom/google/android/gms/dynamic/IObjectWrapper;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Landroid/content/Context;
if-eqz v2, :cond_7
.line 33
new-instance v4, Lcom/google/android/gms/dynamite/DynamiteModule;
.line 34
invoke-direct {v4, v2}, Lcom/google/android/gms/dynamite/DynamiteModule;-><init>(Landroid/content/Context;)V
goto/16 :goto_4
.line 35
:cond_7
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "Failed to get module context"
const/4 v4, 0x0
.line 36
invoke-direct {v0, v2, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
:try_end_8
.catch Landroid/os/RemoteException; {:try_start_8 .. :try_end_8} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_8 .. :try_end_8} :catch_0
.catchall {:try_start_8 .. :try_end_8} :catchall_3
:catchall_0
move-exception v0
.line 37
:try_start_9
monitor-exit v4
:try_end_9
.catchall {:try_start_9 .. :try_end_9} :catchall_0
:try_start_a
throw v0
.line 38
:cond_8
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "No result cursor"
const/4 v4, 0x0
.line 39
invoke-direct {v0, v2, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
.line 40
:cond_9
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "DynamiteLoaderV2 was not cached."
const/4 v4, 0x0
.line 41
invoke-direct {v0, v2, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
:try_end_a
.catch Landroid/os/RemoteException; {:try_start_a .. :try_end_a} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_a .. :try_end_a} :catch_0
.catchall {:try_start_a .. :try_end_a} :catchall_3
:catchall_1
move-exception v0
.line 42
:try_start_b
monitor-exit v4
:try_end_b
.catchall {:try_start_b .. :try_end_b} :catchall_1
:try_start_c
throw v0
:cond_a
const-string v2, "DynamiteModule"
.line 43
invoke-static/range {p2 .. p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/String;->length()I
move-result v4
add-int/lit8 v4, v4, 0x33
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7, v4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v4, "Selected remote version of "
invoke-virtual {v7, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, ", version >= "
invoke-virtual {v7, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7, v14}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v2, v4}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
.line 44
invoke-static/range {p0 .. p0}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf(Landroid/content/Context;)Lcom/google/android/gms/dynamite/zzq;
move-result-object v2
if-eqz v2, :cond_11
.line 45
invoke-virtual {v2}, Lcom/google/android/gms/dynamite/zzq;->zze()I
move-result v4
const/4 v7, 0x3
if-lt v4, v7, :cond_c
.line 46
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/google/android/gms/dynamite/zzn;
if-eqz v4, :cond_b
.line 47
invoke-static/range {p0 .. p0}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v7
iget-object v4, v4, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
.line 48
invoke-static {v4}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v4
.line 49
invoke-virtual {v2, v7, v3, v14, v4}, Lcom/google/android/gms/dynamite/zzq;->zzi(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;ILcom/google/android/gms/dynamic/IObjectWrapper;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v2
goto :goto_3
.line 50
:cond_b
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "No cached result cursor holder"
const/4 v4, 0x0
.line 51
invoke-direct {v0, v2, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
:cond_c
if-ne v4, v12, :cond_d
const-string v4, "DynamiteModule"
const-string v7, "IDynamite loader version = 2"
.line 52
invoke-static {v4, v7}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 53
invoke-static/range {p0 .. p0}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v4
invoke-virtual {v2, v4, v3, v14}, Lcom/google/android/gms/dynamite/zzq;->zzj(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;I)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v2
goto :goto_3
:cond_d
const-string v4, "DynamiteModule"
const-string v7, "Dynamite loader version < 2, falling back to createModuleContext"
.line 54
invoke-static {v4, v7}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 55
invoke-static/range {p0 .. p0}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v4
invoke-virtual {v2, v4, v3, v14}, Lcom/google/android/gms/dynamite/zzq;->zzh(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;I)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v2
.line 56
:goto_3
invoke-static {v2}, Lcom/google/android/gms/dynamic/ObjectWrapper;->unwrap(Lcom/google/android/gms/dynamic/IObjectWrapper;)Ljava/lang/Object;
move-result-object v4
if-eqz v4, :cond_10
.line 57
new-instance v4, Lcom/google/android/gms/dynamite/DynamiteModule;
.line 58
invoke-static {v2}, Lcom/google/android/gms/dynamic/ObjectWrapper;->unwrap(Lcom/google/android/gms/dynamic/IObjectWrapper;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Landroid/content/Context;
invoke-direct {v4, v2}, Lcom/google/android/gms/dynamite/DynamiteModule;-><init>(Landroid/content/Context;)V
:try_end_c
.catch Landroid/os/RemoteException; {:try_start_c .. :try_end_c} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_c .. :try_end_c} :catch_0
.catchall {:try_start_c .. :try_end_c} :catchall_3
:goto_4
const-wide/16 v1, 0x0
cmp-long v1, v9, v1
if-nez v1, :cond_e
.line 59
invoke-virtual {v8}, Ljava/lang/ThreadLocal;->remove()V
goto :goto_5
.line 60
:cond_e
invoke-static {v9, v10}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
invoke-virtual {v8, v1}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
.line 61
:goto_5
iget-object v1, v6, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
if-eqz v1, :cond_f
.line 62
invoke-interface {v1}, Landroid/database/Cursor;->close()V
.line 63
:cond_f
invoke-virtual {v0, v5}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
return-object v4
.line 64
:cond_10
:try_start_d
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "Failed to load remote module."
const/4 v4, 0x0
.line 65
invoke-direct {v0, v2, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
.line 66
:cond_11
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "Failed to create IDynamiteLoader."
const/4 v4, 0x0
.line 67
invoke-direct {v0, v2, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
.line 68
:cond_12
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "Failed to determine which loading route to use."
const/4 v4, 0x0
.line 69
invoke-direct {v0, v2, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
:try_end_d
.catch Landroid/os/RemoteException; {:try_start_d .. :try_end_d} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_d .. :try_end_d} :catch_0
.catchall {:try_start_d .. :try_end_d} :catchall_3
:catchall_2
move-exception v0
.line 70
:try_start_e
monitor-exit v4
:try_end_e
.catchall {:try_start_e .. :try_end_e} :catchall_2
:try_start_f
throw v0
:try_end_f
.catch Landroid/os/RemoteException; {:try_start_f .. :try_end_f} :catch_1
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_f .. :try_end_f} :catch_0
.catchall {:try_start_f .. :try_end_f} :catchall_3
:catchall_3
move-exception v0
.line 71
:try_start_10
invoke-static {v1, v0}, Lcom/google/android/gms/common/util/CrashUtils;->addDynamiteErrorToDropBox(Landroid/content/Context;Ljava/lang/Throwable;)Z
new-instance v2, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v4, "Failed to load remote module."
const/4 v7, 0x0
.line 72
invoke-direct {v2, v4, v0, v7}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;Lcom/google/android/gms/dynamite/zzp;)V
throw v2
:catch_0
move-exception v0
.line 73
throw v0
:catch_1
move-exception v0
.line 74
new-instance v2, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v4, "Failed to load remote module."
const/4 v7, 0x0
.line 75
invoke-direct {v2, v4, v0, v7}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;Lcom/google/android/gms/dynamite/zzp;)V
throw v2
:try_end_10
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_10 .. :try_end_10} :catch_2
.catchall {:try_start_10 .. :try_end_10} :catchall_4
:catch_2
move-exception v0
:try_start_11
const-string v2, "DynamiteModule"
const-string v4, "Failed to load remote module: "
.line 76
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v7
invoke-static {v7}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v7
invoke-virtual {v7}, Ljava/lang/String;->length()I
move-result v8
if-eqz v8, :cond_13
invoke-virtual {v4, v7}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
goto :goto_6
.line 77
:cond_13
new-instance v7, Ljava/lang/String;
.line 78
invoke-direct {v7, v4}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v4, v7
:goto_6
invoke-static {v2, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 79
iget v2, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->localVersion:I
if-eqz v2, :cond_16
new-instance v4, Lcom/google/android/gms/dynamite/zzo;
const/4 v7, 0x0
invoke-direct {v4, v2, v7}, Lcom/google/android/gms/dynamite/zzo;-><init>(II)V
move-object/from16 v2, p1
.line 80
invoke-interface {v2, v1, v3, v4}, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy;->selectModule(Landroid/content/Context;Ljava/lang/String;Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$IVersions;)Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;
move-result-object v2
.line 81
iget v2, v2, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->selection:I
const/4 v4, -0x1
if-ne v2, v4, :cond_16
.line 82
invoke-static {v1, v3}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzc(Landroid/content/Context;Ljava/lang/String;)Lcom/google/android/gms/dynamite/DynamiteModule;
move-result-object v0
:try_end_11
.catchall {:try_start_11 .. :try_end_11} :catchall_4
const-wide/16 v1, 0x0
cmp-long v1, v9, v1
if-nez v1, :cond_14
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
.line 83
invoke-virtual {v1}, Ljava/lang/ThreadLocal;->remove()V
goto :goto_7
.line 84
:cond_14
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
.line 85
invoke-static {v9, v10}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
.line 86
:goto_7
iget-object v1, v6, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
if-eqz v1, :cond_15
.line 87
invoke-interface {v1}, Landroid/database/Cursor;->close()V
:cond_15
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf:Ljava/lang/ThreadLocal;
.line 88
invoke-virtual {v1, v5}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
return-object v0
.line 89
:cond_16
:try_start_12
new-instance v1, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "Remote load failed. No local fallback found."
const/4 v3, 0x0
.line 90
invoke-direct {v1, v2, v0, v3}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;Lcom/google/android/gms/dynamite/zzp;)V
throw v1
.line 91
:cond_17
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
new-instance v1, Ljava/lang/StringBuilder;
const/16 v2, 0x2f
.line 92
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v2, "VersionPolicy returned invalid code:"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x0
invoke-direct {v0, v1, v2}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
.line 93
:cond_18
new-instance v0, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
.line 94
iget v1, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->localVersion:I
iget v2, v13, Lcom/google/android/gms/dynamite/DynamiteModule$VersionPolicy$SelectionResult;->remoteVersion:I
invoke-static/range {p2 .. p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/String;->length()I
move-result v4
add-int/lit8 v4, v4, 0x5c
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7, v4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v4, "No acceptable module "
invoke-virtual {v7, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " found. Local version is "
invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " and remote version is "
invoke-virtual {v7, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, "."
invoke-virtual {v7, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x0
invoke-direct {v0, v1, v2}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw v0
:try_end_12
.catchall {:try_start_12 .. :try_end_12} :catchall_4
:catchall_4
move-exception v0
const-wide/16 v1, 0x0
cmp-long v1, v9, v1
if-nez v1, :cond_19
.line 95
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
.line 96
invoke-virtual {v1}, Ljava/lang/ThreadLocal;->remove()V
goto :goto_8
.line 97
:cond_19
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
.line 98
invoke-static {v9, v10}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
.line 99
:goto_8
iget-object v1, v6, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
if-eqz v1, :cond_1a
.line 100
invoke-interface {v1}, Landroid/database/Cursor;->close()V
:cond_1a
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf:Ljava/lang/ThreadLocal;
.line 101
invoke-virtual {v1, v5}, Ljava/lang/ThreadLocal;->set(Ljava/lang/Object;)V
.line 102
throw v0
.end method
.method public static zza(Landroid/content/Context;Ljava/lang/String;Z)I
.locals 9
.param p0 # Landroid/content/Context;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.param p1 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.line 1
:try_start_0
const-class v0, Lcom/google/android/gms/dynamite/DynamiteModule;
monitor-enter v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_4
:try_start_1
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzb:Ljava/lang/Boolean;
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_3
const/4 v2, 0x0
if-nez v1, :cond_8
:try_start_2
invoke-virtual {p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v1
invoke-virtual {v1}, Landroid/content/Context;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v1
const-class v3, Lcom/google/android/gms/dynamite/DynamiteModule$DynamiteLoaderClassLoader;
.line 2
invoke-virtual {v3}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v3
invoke-virtual {v1, v3}, Ljava/lang/ClassLoader;->loadClass(Ljava/lang/String;)Ljava/lang/Class;
move-result-object v1
const-string v3, "sClassLoader"
.line 3
invoke-virtual {v1, v3}, Ljava/lang/Class;->getDeclaredField(Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v1
.line 4
invoke-virtual {v1}, Ljava/lang/reflect/Field;->getDeclaringClass()Ljava/lang/Class;
move-result-object v3
monitor-enter v3
:try_end_2
.catch Ljava/lang/ClassNotFoundException; {:try_start_2 .. :try_end_2} :catch_4
.catch Ljava/lang/IllegalAccessException; {:try_start_2 .. :try_end_2} :catch_3
.catch Ljava/lang/NoSuchFieldException; {:try_start_2 .. :try_end_2} :catch_2
.catchall {:try_start_2 .. :try_end_2} :catchall_3
.line 5
:try_start_3
invoke-virtual {v1, v2}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/lang/ClassLoader;
if-eqz v4, :cond_1
.line 6
invoke-static {}, Ljava/lang/ClassLoader;->getSystemClassLoader()Ljava/lang/ClassLoader;
move-result-object v1
if-ne v4, v1, :cond_0
sget-object v1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_0
goto/16 :goto_3
.line 7
:cond_0
:try_start_4
invoke-static {v4}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzd(Ljava/lang/ClassLoader;)V
:try_end_4
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_4 .. :try_end_4} :catch_0
.catchall {:try_start_4 .. :try_end_4} :catchall_0
:catch_0
:try_start_5
sget-object v1, Ljava/lang/Boolean;->TRUE:Ljava/lang/Boolean;
goto :goto_3
:cond_1
sget-boolean v4, Lcom/google/android/gms/dynamite/DynamiteModule;->zzd:Z
if-nez v4, :cond_7
sget-object v4, Ljava/lang/Boolean;->TRUE:Ljava/lang/Boolean;
.line 8
invoke-virtual {v4, v2}, Ljava/lang/Boolean;->equals(Ljava/lang/Object;)Z
move-result v5
:try_end_5
.catchall {:try_start_5 .. :try_end_5} :catchall_0
if-eqz v5, :cond_2
goto :goto_2
.line 9
:cond_2
:try_start_6
invoke-static {p0, p1, p2}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzb(Landroid/content/Context;Ljava/lang/String;Z)I
move-result v5
sget-object v6, Lcom/google/android/gms/dynamite/DynamiteModule;->zzc:Ljava/lang/String;
if-eqz v6, :cond_6
.line 10
invoke-virtual {v6}, Ljava/lang/String;->isEmpty()Z
move-result v6
if-eqz v6, :cond_3
goto :goto_1
.line 11
:cond_3
invoke-static {}, Lcom/google/android/gms/dynamite/zzb;->zza()Ljava/lang/ClassLoader;
move-result-object v6
if-eqz v6, :cond_4
goto :goto_0
.line 12
:cond_4
sget v6, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v7, 0x1d
if-lt v6, v7, :cond_5
.line 13
new-instance v6, Ldalvik/system/DelegateLastClassLoader;
sget-object v7, Lcom/google/android/gms/dynamite/DynamiteModule;->zzc:Ljava/lang/String;
.line 14
invoke-static {v7}, Lcom/google/android/gms/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
invoke-static {}, Ljava/lang/ClassLoader;->getSystemClassLoader()Ljava/lang/ClassLoader;
move-result-object v8
invoke-direct {v6, v7, v8}, Ldalvik/system/DelegateLastClassLoader;-><init>(Ljava/lang/String;Ljava/lang/ClassLoader;)V
goto :goto_0
.line 15
:cond_5
new-instance v6, Lcom/google/android/gms/dynamite/zzc;
sget-object v7, Lcom/google/android/gms/dynamite/DynamiteModule;->zzc:Ljava/lang/String;
.line 16
invoke-static {v7}, Lcom/google/android/gms/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
invoke-static {}, Ljava/lang/ClassLoader;->getSystemClassLoader()Ljava/lang/ClassLoader;
move-result-object v8
invoke-direct {v6, v7, v8}, Lcom/google/android/gms/dynamite/zzc;-><init>(Ljava/lang/String;Ljava/lang/ClassLoader;)V
.line 17
:goto_0
invoke-static {v6}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzd(Ljava/lang/ClassLoader;)V
.line 18
invoke-virtual {v1, v2, v6}, Ljava/lang/reflect/Field;->set(Ljava/lang/Object;Ljava/lang/Object;)V
sput-object v4, Lcom/google/android/gms/dynamite/DynamiteModule;->zzb:Ljava/lang/Boolean;
:try_end_6
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_6 .. :try_end_6} :catch_1
.catchall {:try_start_6 .. :try_end_6} :catchall_0
.line 19
:try_start_7
monitor-exit v3
:try_end_7
.catchall {:try_start_7 .. :try_end_7} :catchall_0
:try_start_8
monitor-exit v0
:try_end_8
.catchall {:try_start_8 .. :try_end_8} :catchall_3
return v5
.line 20
:cond_6
:goto_1
:try_start_9
monitor-exit v3
:try_end_9
.catchall {:try_start_9 .. :try_end_9} :catchall_0
:try_start_a
monitor-exit v0
:try_end_a
.catchall {:try_start_a .. :try_end_a} :catchall_3
return v5
.line 21
:catch_1
:try_start_b
invoke-static {}, Ljava/lang/ClassLoader;->getSystemClassLoader()Ljava/lang/ClassLoader;
move-result-object v4
invoke-virtual {v1, v2, v4}, Ljava/lang/reflect/Field;->set(Ljava/lang/Object;Ljava/lang/Object;)V
sget-object v1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
goto :goto_3
.line 22
:cond_7
:goto_2
invoke-static {}, Ljava/lang/ClassLoader;->getSystemClassLoader()Ljava/lang/ClassLoader;
move-result-object v4
invoke-virtual {v1, v2, v4}, Ljava/lang/reflect/Field;->set(Ljava/lang/Object;Ljava/lang/Object;)V
sget-object v1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
.line 23
:goto_3
monitor-exit v3
goto :goto_5
:catchall_0
move-exception v1
monitor-exit v3
:try_end_b
.catchall {:try_start_b .. :try_end_b} :catchall_0
:try_start_c
throw v1
:try_end_c
.catch Ljava/lang/ClassNotFoundException; {:try_start_c .. :try_end_c} :catch_4
.catch Ljava/lang/IllegalAccessException; {:try_start_c .. :try_end_c} :catch_3
.catch Ljava/lang/NoSuchFieldException; {:try_start_c .. :try_end_c} :catch_2
.catchall {:try_start_c .. :try_end_c} :catchall_3
:catch_2
move-exception v1
goto :goto_4
:catch_3
move-exception v1
goto :goto_4
:catch_4
move-exception v1
:goto_4
:try_start_d
const-string v3, "DynamiteModule"
.line 24
invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v4
add-int/lit8 v4, v4, 0x1e
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5, v4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v4, "Failed to load module via V2: "
invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v3, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
sget-object v1, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;
.line 25
:goto_5
sput-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzb:Ljava/lang/Boolean;
.line 26
:cond_8
monitor-exit v0
:try_end_d
.catchall {:try_start_d .. :try_end_d} :catchall_3
.line 27
:try_start_e
invoke-virtual {v1}, Ljava/lang/Boolean;->booleanValue()Z
move-result v0
:try_end_e
.catchall {:try_start_e .. :try_end_e} :catchall_4
const/4 v1, 0x0
if-eqz v0, :cond_a
.line 28
:try_start_f
invoke-static {p0, p1, p2}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzb(Landroid/content/Context;Ljava/lang/String;Z)I
move-result p0
:try_end_f
.catch Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException; {:try_start_f .. :try_end_f} :catch_5
.catchall {:try_start_f .. :try_end_f} :catchall_4
return p0
:catch_5
move-exception p1
:try_start_10
const-string p2, "DynamiteModule"
const-string v0, "Failed to retrieve remote module version: "
.line 29
invoke-virtual {p1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_9
invoke-virtual {v0, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_6
.line 30
:cond_9
new-instance p1, Ljava/lang/String;
.line 31
invoke-direct {p1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_6
invoke-static {p2, p1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
return v1
.line 32
:cond_a
invoke-static {p0}, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf(Landroid/content/Context;)Lcom/google/android/gms/dynamite/zzq;
move-result-object v3
:try_end_10
.catchall {:try_start_10 .. :try_end_10} :catchall_4
if-nez v3, :cond_b
goto/16 :goto_c
.line 33
:cond_b
:try_start_11
invoke-virtual {v3}, Lcom/google/android/gms/dynamite/zzq;->zze()I
move-result v0
const/4 v4, 0x3
if-lt v0, v4, :cond_11
sget-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf:Ljava/lang/ThreadLocal;
.line 34
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/dynamite/zzn;
if-eqz v0, :cond_c
iget-object v0, v0, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
if-eqz v0, :cond_c
.line 35
invoke-interface {v0, v1}, Landroid/database/Cursor;->getInt(I)I
move-result v1
goto/16 :goto_c
.line 36
:cond_c
invoke-static {p0}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v4
sget-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Long;
invoke-virtual {v0}, Ljava/lang/Long;->longValue()J
move-result-wide v7
move-object v5, p1
move v6, p2
.line 37
invoke-virtual/range {v3 .. v8}, Lcom/google/android/gms/dynamite/zzq;->zzk(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;ZJ)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object p1
.line 38
invoke-static {p1}, Lcom/google/android/gms/dynamic/ObjectWrapper;->unwrap(Lcom/google/android/gms/dynamic/IObjectWrapper;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Landroid/database/Cursor;
:try_end_11
.catch Landroid/os/RemoteException; {:try_start_11 .. :try_end_11} :catch_7
.catchall {:try_start_11 .. :try_end_11} :catchall_2
if-eqz p1, :cond_10
.line 39
:try_start_12
invoke-interface {p1}, Landroid/database/Cursor;->moveToFirst()Z
move-result p2
if-nez p2, :cond_d
goto :goto_8
.line 40
:cond_d
invoke-interface {p1, v1}, Landroid/database/Cursor;->getInt(I)I
move-result p2
if-lez p2, :cond_e
.line 41
invoke-static {p1}, Lcom/google/android/gms/dynamite/DynamiteModule;->zze(Landroid/database/Cursor;)Z
move-result v0
:try_end_12
.catch Landroid/os/RemoteException; {:try_start_12 .. :try_end_12} :catch_6
.catchall {:try_start_12 .. :try_end_12} :catchall_1
if-eqz v0, :cond_e
goto :goto_7
:cond_e
move-object v2, p1
:goto_7
if-eqz v2, :cond_f
.line 42
:try_start_13
invoke-interface {v2}, Landroid/database/Cursor;->close()V
:try_end_13
.catchall {:try_start_13 .. :try_end_13} :catchall_4
:cond_f
move v1, p2
goto :goto_c
:cond_10
:goto_8
:try_start_14
const-string p2, "DynamiteModule"
const-string v0, "Failed to retrieve remote module version."
.line 43
invoke-static {p2, v0}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_14
.catch Landroid/os/RemoteException; {:try_start_14 .. :try_end_14} :catch_6
.catchall {:try_start_14 .. :try_end_14} :catchall_1
if-eqz p1, :cond_14
.line 44
:try_start_15
invoke-interface {p1}, Landroid/database/Cursor;->close()V
:try_end_15
.catchall {:try_start_15 .. :try_end_15} :catchall_4
goto :goto_c
:catchall_1
move-exception p2
move-object v2, p1
goto :goto_d
:catch_6
move-exception p2
move-object v2, p1
goto :goto_a
:cond_11
const/4 v4, 0x2
if-ne v0, v4, :cond_12
:try_start_16
const-string v0, "DynamiteModule"
const-string v4, "IDynamite loader version = 2, no high precision latency measurement."
.line 45
invoke-static {v0, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 46
invoke-static {p0}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v0
.line 47
invoke-virtual {v3, v0, p1, p2}, Lcom/google/android/gms/dynamite/zzq;->zzg(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;Z)I
move-result v1
goto :goto_c
:cond_12
const-string v0, "DynamiteModule"
const-string v4, "IDynamite loader version < 2, falling back to getModuleVersion2"
.line 48
invoke-static {v0, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 49
invoke-static {p0}, Lcom/google/android/gms/dynamic/ObjectWrapper;->wrap(Ljava/lang/Object;)Lcom/google/android/gms/dynamic/IObjectWrapper;
move-result-object v0
invoke-virtual {v3, v0, p1, p2}, Lcom/google/android/gms/dynamite/zzq;->zzf(Lcom/google/android/gms/dynamic/IObjectWrapper;Ljava/lang/String;Z)I
move-result v1
:try_end_16
.catch Landroid/os/RemoteException; {:try_start_16 .. :try_end_16} :catch_7
.catchall {:try_start_16 .. :try_end_16} :catchall_2
goto :goto_c
:goto_9
move-object p2, p1
goto :goto_d
:catch_7
move-exception p1
move-object p2, p1
:goto_a
:try_start_17
const-string p1, "DynamiteModule"
const-string v0, "Failed to retrieve remote module version: "
.line 50
invoke-virtual {p2}, Landroid/os/RemoteException;->getMessage()Ljava/lang/String;
move-result-object p2
invoke-static {p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p2
invoke-virtual {p2}, Ljava/lang/String;->length()I
move-result v3
if-eqz v3, :cond_13
invoke-virtual {v0, p2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p2
goto :goto_b
.line 51
:cond_13
new-instance p2, Ljava/lang/String;
.line 52
invoke-direct {p2, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_b
invoke-static {p1, p2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_17
.catchall {:try_start_17 .. :try_end_17} :catchall_2
if-eqz v2, :cond_14
.line 53
:try_start_18
invoke-interface {v2}, Landroid/database/Cursor;->close()V
:cond_14
:goto_c
return v1
:catchall_2
move-exception p1
goto :goto_9
:goto_d
if-eqz v2, :cond_15
invoke-interface {v2}, Landroid/database/Cursor;->close()V
.line 54
:cond_15
throw p2
:try_end_18
.catchall {:try_start_18 .. :try_end_18} :catchall_4
:catchall_3
move-exception p1
.line 55
:try_start_19
monitor-exit v0
:try_end_19
.catchall {:try_start_19 .. :try_end_19} :catchall_3
:try_start_1a
throw p1
:try_end_1a
.catchall {:try_start_1a .. :try_end_1a} :catchall_4
:catchall_4
move-exception p1
.line 56
invoke-static {p0, p1}, Lcom/google/android/gms/common/util/CrashUtils;->addDynamiteErrorToDropBox(Landroid/content/Context;Ljava/lang/Throwable;)Z
.line 57
throw p1
.end method
.method private static zzb(Landroid/content/Context;Ljava/lang/String;Z)I
.locals 10
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
}
.end annotation
const/4 v0, 0x0
.line 1
:try_start_0
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzg:Ljava/lang/ThreadLocal;
invoke-virtual {v1}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/Long;
invoke-virtual {v1}, Ljava/lang/Long;->longValue()J
move-result-wide v1
.line 2
invoke-virtual {p0}, Landroid/content/Context;->getContentResolver()Landroid/content/ContentResolver;
move-result-object v3
const-string p0, "api_force_staging"
const-string v4, "api"
const/4 v9, 0x1
if-eq v9, p2, :cond_0
move-object p0, v4
:cond_0
new-instance p2, Landroid/net/Uri$Builder;
.line 3
invoke-direct {p2}, Landroid/net/Uri$Builder;-><init>()V
const-string v4, "content"
.line 4
invoke-virtual {p2, v4}, Landroid/net/Uri$Builder;->scheme(Ljava/lang/String;)Landroid/net/Uri$Builder;
move-result-object p2
const-string v4, "com.google.android.gms.chimera"
.line 5
invoke-virtual {p2, v4}, Landroid/net/Uri$Builder;->authority(Ljava/lang/String;)Landroid/net/Uri$Builder;
move-result-object p2
.line 6
invoke-virtual {p2, p0}, Landroid/net/Uri$Builder;->path(Ljava/lang/String;)Landroid/net/Uri$Builder;
move-result-object p0
.line 7
invoke-virtual {p0, p1}, Landroid/net/Uri$Builder;->appendPath(Ljava/lang/String;)Landroid/net/Uri$Builder;
move-result-object p0
const-string p1, "requestStartTime"
.line 8
invoke-static {v1, v2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object p2
invoke-virtual {p0, p1, p2}, Landroid/net/Uri$Builder;->appendQueryParameter(Ljava/lang/String;Ljava/lang/String;)Landroid/net/Uri$Builder;
move-result-object p0
.line 9
invoke-virtual {p0}, Landroid/net/Uri$Builder;->build()Landroid/net/Uri;
move-result-object v4
const/4 v5, 0x0
const/4 v6, 0x0
const/4 v7, 0x0
const/4 v8, 0x0
.line 10
invoke-virtual/range {v3 .. v8}, Landroid/content/ContentResolver;->query(Landroid/net/Uri;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;)Landroid/database/Cursor;
move-result-object p0
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_1
.catchall {:try_start_0 .. :try_end_0} :catchall_1
if-eqz p0, :cond_7
.line 11
:try_start_1
invoke-interface {p0}, Landroid/database/Cursor;->moveToFirst()Z
move-result p1
if-eqz p1, :cond_7
const/4 p1, 0x0
.line 12
invoke-interface {p0, p1}, Landroid/database/Cursor;->getInt(I)I
move-result p2
if-lez p2, :cond_4
const-class v1, Lcom/google/android/gms/dynamite/DynamiteModule;
monitor-enter v1
:try_end_1
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0
.catchall {:try_start_1 .. :try_end_1} :catchall_2
const/4 v2, 0x2
.line 13
:try_start_2
invoke-interface {p0, v2}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v2
sput-object v2, Lcom/google/android/gms/dynamite/DynamiteModule;->zzc:Ljava/lang/String;
const-string v2, "loaderVersion"
.line 14
invoke-interface {p0, v2}, Landroid/database/Cursor;->getColumnIndex(Ljava/lang/String;)I
move-result v2
if-ltz v2, :cond_1
.line 15
invoke-interface {p0, v2}, Landroid/database/Cursor;->getInt(I)I
move-result v2
sput v2, Lcom/google/android/gms/dynamite/DynamiteModule;->zze:I
:cond_1
const-string v2, "disableStandaloneDynamiteLoader"
.line 16
invoke-interface {p0, v2}, Landroid/database/Cursor;->getColumnIndex(Ljava/lang/String;)I
move-result v2
if-ltz v2, :cond_3
.line 17
invoke-interface {p0, v2}, Landroid/database/Cursor;->getInt(I)I
move-result v2
if-eqz v2, :cond_2
goto :goto_0
:cond_2
move v9, p1
:goto_0
sput-boolean v9, Lcom/google/android/gms/dynamite/DynamiteModule;->zzd:Z
move p1, v9
.line 18
:cond_3
monitor-exit v1
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_0
.line 19
:try_start_3
invoke-static {p0}, Lcom/google/android/gms/dynamite/DynamiteModule;->zze(Landroid/database/Cursor;)Z
move-result v1
:try_end_3
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_0
.catchall {:try_start_3 .. :try_end_3} :catchall_2
if-eqz v1, :cond_4
move-object p0, v0
goto :goto_1
:catchall_0
move-exception p1
.line 20
:try_start_4
monitor-exit v1
:try_end_4
.catchall {:try_start_4 .. :try_end_4} :catchall_0
:try_start_5
throw p1
:try_end_5
.catch Ljava/lang/Exception; {:try_start_5 .. :try_end_5} :catch_0
.catchall {:try_start_5 .. :try_end_5} :catchall_2
:cond_4
:goto_1
if-nez p1, :cond_6
if-eqz p0, :cond_5
.line 21
invoke-interface {p0}, Landroid/database/Cursor;->close()V
:cond_5
return p2
.line 22
:cond_6
:try_start_6
new-instance p1, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string p2, "forcing fallback to container DynamiteLoader impl"
.line 23
invoke-direct {p1, p2, v0}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw p1
:catch_0
move-exception p1
goto :goto_2
:cond_7
const-string p1, "DynamiteModule"
const-string p2, "Failed to retrieve remote module version."
.line 24
invoke-static {p1, p2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
new-instance p1, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string p2, "Failed to connect to dynamite module ContentResolver."
.line 25
invoke-direct {p1, p2, v0}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Lcom/google/android/gms/dynamite/zzp;)V
throw p1
:try_end_6
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_6} :catch_0
.catchall {:try_start_6 .. :try_end_6} :catchall_2
:catchall_1
move-exception p0
move-object p1, p0
goto :goto_3
:catch_1
move-exception p0
move-object p1, p0
move-object p0, v0
.line 26
:goto_2
:try_start_7
instance-of p2, p1, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
if-eqz p2, :cond_8
.line 27
throw p1
.line 28
:cond_8
new-instance p2, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v1, "V2 version check failed"
.line 29
invoke-direct {p2, v1, p1, v0}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;Lcom/google/android/gms/dynamite/zzp;)V
throw p2
:try_end_7
.catchall {:try_start_7 .. :try_end_7} :catchall_2
:catchall_2
move-exception p1
move-object v0, p0
:goto_3
if-eqz v0, :cond_9
.line 30
invoke-interface {v0}, Landroid/database/Cursor;->close()V
.line 31
:cond_9
throw p1
.end method
.method private static zzc(Landroid/content/Context;Ljava/lang/String;)Lcom/google/android/gms/dynamite/DynamiteModule;
.locals 2
.line 1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v0
const-string v1, "Selected local version of "
if-eqz v0, :cond_0
invoke-virtual {v1, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_0
.line 2
:cond_0
new-instance p1, Ljava/lang/String;
.line 3
invoke-direct {p1, v1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_0
const-string v0, "DynamiteModule"
invoke-static {v0, p1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
new-instance p1, Lcom/google/android/gms/dynamite/DynamiteModule;
.line 4
invoke-virtual {p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object p0
invoke-direct {p1, p0}, Lcom/google/android/gms/dynamite/DynamiteModule;-><init>(Landroid/content/Context;)V
return-object p1
.end method
.method private static zzd(Ljava/lang/ClassLoader;)V
.locals 3
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
}
.end annotation
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "DynamiteModule.class"
.end annotation
const/4 v0, 0x0
:try_start_0
const-string v1, "com.google.android.gms.dynamiteloader.DynamiteLoaderV2"
.line 1
invoke-virtual {p0, v1}, Ljava/lang/ClassLoader;->loadClass(Ljava/lang/String;)Ljava/lang/Class;
move-result-object p0
const/4 v1, 0x0
new-array v2, v1, [Ljava/lang/Class;
invoke-virtual {p0, v2}, Ljava/lang/Class;->getConstructor([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
move-result-object p0
new-array v1, v1, [Ljava/lang/Object;
invoke-virtual {p0, v1}, Ljava/lang/reflect/Constructor;->newInstance([Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p0
check-cast p0, Landroid/os/IBinder;
if-nez p0, :cond_0
move-object v1, v0
goto :goto_0
:cond_0
const-string v1, "com.google.android.gms.dynamite.IDynamiteLoaderV2"
.line 2
invoke-interface {p0, v1}, Landroid/os/IBinder;->queryLocalInterface(Ljava/lang/String;)Landroid/os/IInterface;
move-result-object v1
.line 3
instance-of v2, v1, Lcom/google/android/gms/dynamite/zzr;
if-eqz v2, :cond_1
.line 4
check-cast v1, Lcom/google/android/gms/dynamite/zzr;
goto :goto_0
.line 5
:cond_1
new-instance v1, Lcom/google/android/gms/dynamite/zzr;
invoke-direct {v1, p0}, Lcom/google/android/gms/dynamite/zzr;-><init>(Landroid/os/IBinder;)V
.line 6
:goto_0
sput-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzk:Lcom/google/android/gms/dynamite/zzr;
:try_end_0
.catch Ljava/lang/ClassNotFoundException; {:try_start_0 .. :try_end_0} :catch_4
.catch Ljava/lang/IllegalAccessException; {:try_start_0 .. :try_end_0} :catch_3
.catch Ljava/lang/InstantiationException; {:try_start_0 .. :try_end_0} :catch_2
.catch Ljava/lang/reflect/InvocationTargetException; {:try_start_0 .. :try_end_0} :catch_1
.catch Ljava/lang/NoSuchMethodException; {:try_start_0 .. :try_end_0} :catch_0
return-void
:catch_0
move-exception p0
goto :goto_1
:catch_1
move-exception p0
goto :goto_1
:catch_2
move-exception p0
goto :goto_1
:catch_3
move-exception p0
goto :goto_1
:catch_4
move-exception p0
.line 7
:goto_1
new-instance v1, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
const-string v2, "Failed to instantiate dynamite loader"
.line 8
invoke-direct {v1, v2, p0, v0}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;Lcom/google/android/gms/dynamite/zzp;)V
throw v1
.end method
.method private static zze(Landroid/database/Cursor;)Z
.locals 2
.line 1
sget-object v0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzf:Ljava/lang/ThreadLocal;
invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/dynamite/zzn;
if-eqz v0, :cond_0
iget-object v1, v0, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
if-nez v1, :cond_0
iput-object p0, v0, Lcom/google/android/gms/dynamite/zzn;->zza:Landroid/database/Cursor;
const/4 p0, 0x1
return p0
:cond_0
const/4 p0, 0x0
return p0
.end method
.method private static zzf(Landroid/content/Context;)Lcom/google/android/gms/dynamite/zzq;
.locals 5
.annotation build Landroidx/annotation/Nullable;
.end annotation
.line 1
const-class v0, Lcom/google/android/gms/dynamite/DynamiteModule;
monitor-enter v0
:try_start_0
sget-object v1, Lcom/google/android/gms/dynamite/DynamiteModule;->zzj:Lcom/google/android/gms/dynamite/zzq;
if-eqz v1, :cond_0
monitor-exit v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
return-object v1
:cond_0
const/4 v1, 0x0
:try_start_1
const-string v2, "com.google.android.gms"
const/4 v3, 0x3
.line 2
invoke-virtual {p0, v2, v3}, Landroid/content/Context;->createPackageContext(Ljava/lang/String;I)Landroid/content/Context;
move-result-object p0
.line 3
invoke-virtual {p0}, Landroid/content/Context;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object p0
const-string v2, "com.google.android.gms.chimera.container.DynamiteLoaderImpl"
.line 4
invoke-virtual {p0, v2}, Ljava/lang/ClassLoader;->loadClass(Ljava/lang/String;)Ljava/lang/Class;
move-result-object p0
.line 5
invoke-virtual {p0}, Ljava/lang/Class;->newInstance()Ljava/lang/Object;
move-result-object p0
check-cast p0, Landroid/os/IBinder;
if-nez p0, :cond_1
move-object v2, v1
goto :goto_0
:cond_1
const-string v2, "com.google.android.gms.dynamite.IDynamiteLoader"
.line 6
invoke-interface {p0, v2}, Landroid/os/IBinder;->queryLocalInterface(Ljava/lang/String;)Landroid/os/IInterface;
move-result-object v2
.line 7
instance-of v3, v2, Lcom/google/android/gms/dynamite/zzq;
if-eqz v3, :cond_2
.line 8
check-cast v2, Lcom/google/android/gms/dynamite/zzq;
goto :goto_0
:cond_2
new-instance v2, Lcom/google/android/gms/dynamite/zzq;
invoke-direct {v2, p0}, Lcom/google/android/gms/dynamite/zzq;-><init>(Landroid/os/IBinder;)V
:goto_0
if-eqz v2, :cond_4
.line 9
sput-object v2, Lcom/google/android/gms/dynamite/DynamiteModule;->zzj:Lcom/google/android/gms/dynamite/zzq;
:try_end_1
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0
.catchall {:try_start_1 .. :try_end_1} :catchall_0
.line 10
:try_start_2
monitor-exit v0
return-object v2
:catch_0
move-exception p0
const-string v2, "DynamiteModule"
const-string v3, "Failed to load IDynamiteLoader from GmsCore: "
.line 11
invoke-virtual {p0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object p0
invoke-static {p0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_3
invoke-virtual {v3, p0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
goto :goto_1
:cond_3
new-instance p0, Ljava/lang/String;
invoke-direct {p0, v3}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_1
invoke-static {v2, p0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 12
:cond_4
monitor-exit v0
return-object v1
:catchall_0
move-exception p0
monitor-exit v0
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_0
throw p0
.end method
# virtual methods
.method public getModuleContext()Landroid/content/Context;
.locals 1
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
iget-object v0, p0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzi:Landroid/content/Context;
return-object v0
.end method
.method public instantiate(Ljava/lang/String;)Landroid/os/IBinder;
.locals 4
.param p1 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.annotation build Landroidx/annotation/NonNull;
.end annotation
.annotation build Lcom/google/android/gms/common/annotation/KeepForSdk;
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
}
.end annotation
.line 1
:try_start_0
iget-object v0, p0, Lcom/google/android/gms/dynamite/DynamiteModule;->zzi:Landroid/content/Context;
invoke-virtual {v0}, Landroid/content/Context;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v0
invoke-virtual {v0, p1}, Ljava/lang/ClassLoader;->loadClass(Ljava/lang/String;)Ljava/lang/Class;
move-result-object v0
.line 2
invoke-virtual {v0}, Ljava/lang/Class;->newInstance()Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/os/IBinder;
:try_end_0
.catch Ljava/lang/ClassNotFoundException; {:try_start_0 .. :try_end_0} :catch_2
.catch Ljava/lang/InstantiationException; {:try_start_0 .. :try_end_0} :catch_1
.catch Ljava/lang/IllegalAccessException; {:try_start_0 .. :try_end_0} :catch_0
return-object v0
:catch_0
move-exception v0
goto :goto_0
:catch_1
move-exception v0
goto :goto_0
:catch_2
move-exception v0
:goto_0
new-instance v1, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;
.line 3
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string v2, "Failed to instantiate module class: "
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v3
if-eqz v3, :cond_0
invoke-virtual {v2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_1
:cond_0
new-instance p1, Ljava/lang/String;
invoke-direct {p1, v2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:goto_1
const/4 v2, 0x0
invoke-direct {v1, p1, v0, v2}, Lcom/google/android/gms/dynamite/DynamiteModule$LoadingException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;Lcom/google/android/gms/dynamite/zzp;)V
throw v1
.end method