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

1942 lines
46 KiB
Smali

.class public final Lcom/google/android/gms/internal/ads/zzbdw;
.super Lcom/google/android/gms/internal/ads/zzbdl;
.source "com.google.android.gms:play-services-ads@@19.1.0"
# static fields
.field private static final zzeha:Ljava/util/Set;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private static final zzehb:Ljava/text/DecimalFormat;
# instance fields
.field private zzco:Ljava/io/File;
.field private zzehc:Z
# direct methods
.method public static constructor <clinit>()V
.locals 2
.line 1
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
invoke-static {v0}, Ljava/util/Collections;->synchronizedSet(Ljava/util/Set;)Ljava/util/Set;
move-result-object v0
sput-object v0, Lcom/google/android/gms/internal/ads/zzbdw;->zzeha:Ljava/util/Set;
.line 2
new-instance v0, Ljava/text/DecimalFormat;
const-string v1, "#,###"
invoke-direct {v0, v1}, Ljava/text/DecimalFormat;-><init>(Ljava/lang/String;)V
sput-object v0, Lcom/google/android/gms/internal/ads/zzbdw;->zzehb:Ljava/text/DecimalFormat;
return-void
.end method
.method public constructor <init>(Lcom/google/android/gms/internal/ads/zzbbx;)V
.locals 3
.line 1
invoke-direct {p0, p1}, Lcom/google/android/gms/internal/ads/zzbdl;-><init>(Lcom/google/android/gms/internal/ads/zzbbx;)V
.line 2
iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbdl;->mContext:Landroid/content/Context;
invoke-virtual {p1}, Landroid/content/Context;->getCacheDir()Ljava/io/File;
move-result-object p1
if-nez p1, :cond_0
const-string p1, "Context.getCacheDir() returned null"
.line 3
invoke-static {p1}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
return-void
.line 4
:cond_0
new-instance v0, Ljava/io/File;
const-string v1, "admobVideoStreams"
invoke-direct {v0, p1, v1}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
iput-object v0, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
.line 5
invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z
move-result p1
const/4 v0, 0x0
if-nez p1, :cond_2
iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
invoke-virtual {p1}, Ljava/io/File;->mkdirs()Z
move-result p1
if-nez p1, :cond_2
const-string p1, "Could not create preload cache directory at "
.line 6
iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_1
invoke-virtual {p1, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_0
:cond_1
new-instance v1, Ljava/lang/String;
invoke-direct {v1, p1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object p1, v1
:goto_0
invoke-static {p1}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
.line 7
iput-object v0, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
return-void
.line 8
:cond_2
iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
const/4 v1, 0x1
const/4 v2, 0x0
invoke-virtual {p1, v1, v2}, Ljava/io/File;->setReadable(ZZ)Z
move-result p1
if-eqz p1, :cond_4
iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
.line 9
invoke-virtual {p1, v1, v2}, Ljava/io/File;->setExecutable(ZZ)Z
move-result p1
if-nez p1, :cond_3
goto :goto_1
:cond_3
return-void
:cond_4
:goto_1
const-string p1, "Could not set cache file permissions at "
.line 10
iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_5
invoke-virtual {p1, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
goto :goto_2
:cond_5
new-instance v1, Ljava/lang/String;
invoke-direct {v1, p1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object p1, v1
:goto_2
invoke-static {p1}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
.line 11
iput-object v0, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
return-void
.end method
.method private final zzc(Ljava/io/File;)Ljava/io/File;
.locals 3
.line 1
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
invoke-virtual {p1}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string v2, ".done"
invoke-virtual {p1, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-direct {v0, v1, p1}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
return-object v0
.end method
# virtual methods
.method public final abort()V
.locals 1
const/4 v0, 0x1
.line 1
iput-boolean v0, p0, Lcom/google/android/gms/internal/ads/zzbdw;->zzehc:Z
return-void
.end method
.method public final zzfl(Ljava/lang/String;)Z
.locals 29
move-object/from16 v8, p0
move-object/from16 v9, p1
.line 1
iget-object v0, v8, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
const/4 v1, 0x0
const/4 v2, 0x0
if-nez v0, :cond_0
const-string v0, "noCacheDir"
.line 2
invoke-virtual {v8, v9, v1, v0, v1}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
return v2
.line 3
:cond_0
iget-object v0, v8, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
if-nez v0, :cond_1
move v5, v2
goto :goto_1
.line 4
:cond_1
invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v0
array-length v3, v0
move v4, v2
move v5, v4
:goto_0
if-ge v4, v3, :cond_3
aget-object v6, v0, v4
.line 5
invoke-virtual {v6}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v6
const-string v7, ".done"
invoke-virtual {v6, v7}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v6
if-nez v6, :cond_2
add-int/lit8 v5, v5, 0x1
:cond_2
add-int/lit8 v4, v4, 0x1
goto :goto_0
.line 6
:cond_3
:goto_1
sget-object v0, Lcom/google/android/gms/internal/ads/zzzz;->zzcjh:Lcom/google/android/gms/internal/ads/zzzk;
.line 7
invoke-static {}, Lcom/google/android/gms/internal/ads/zzvj;->zzpv()Lcom/google/android/gms/internal/ads/zzzv;
move-result-object v3
invoke-virtual {v3, v0}, Lcom/google/android/gms/internal/ads/zzzv;->zzd(Lcom/google/android/gms/internal/ads/zzzk;)Ljava/lang/Object;
move-result-object v0
.line 8
check-cast v0, Ljava/lang/Integer;
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v0
if-le v5, v0, :cond_9
.line 9
iget-object v0, v8, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
if-nez v0, :cond_4
goto :goto_3
:cond_4
const-wide v3, 0x7fffffffffffffffL
.line 10
invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v0
array-length v5, v0
move-object v7, v1
move v6, v2
:goto_2
if-ge v6, v5, :cond_6
aget-object v10, v0, v6
.line 11
invoke-virtual {v10}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v11
const-string v12, ".done"
invoke-virtual {v11, v12}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v11
if-nez v11, :cond_5
.line 12
invoke-virtual {v10}, Ljava/io/File;->lastModified()J
move-result-wide v11
cmp-long v13, v11, v3
if-gez v13, :cond_5
move-object v7, v10
move-wide v3, v11
:cond_5
add-int/lit8 v6, v6, 0x1
goto :goto_2
:cond_6
if-eqz v7, :cond_7
.line 13
invoke-virtual {v7}, Ljava/io/File;->delete()Z
move-result v0
.line 14
invoke-direct {v8, v7}, Lcom/google/android/gms/internal/ads/zzbdw;->zzc(Ljava/io/File;)Ljava/io/File;
move-result-object v3
.line 15
invoke-virtual {v3}, Ljava/io/File;->isFile()Z
move-result v4
if-eqz v4, :cond_8
.line 16
invoke-virtual {v3}, Ljava/io/File;->delete()Z
move-result v3
and-int/2addr v0, v3
goto :goto_4
:cond_7
:goto_3
move v0, v2
:cond_8
:goto_4
if-nez v0, :cond_0
const-string v0, "Unable to expire stream cache"
.line 17
invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
const-string v0, "expireFailed"
.line 18
invoke-virtual {v8, v9, v1, v0, v1}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
return v2
.line 19
:cond_9
invoke-virtual/range {p0 .. p1}, Lcom/google/android/gms/internal/ads/zzbdl;->zzfm(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 20
new-instance v10, Ljava/io/File;
iget-object v3, v8, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
invoke-direct {v10, v3, v0}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 21
invoke-direct {v8, v10}, Lcom/google/android/gms/internal/ads/zzbdw;->zzc(Ljava/io/File;)Ljava/io/File;
move-result-object v0
.line 22
invoke-virtual {v10}, Ljava/io/File;->isFile()Z
move-result v3
const/4 v4, 0x1
if-eqz v3, :cond_b
invoke-virtual {v0}, Ljava/io/File;->isFile()Z
move-result v3
if-eqz v3, :cond_b
.line 23
invoke-virtual {v10}, Ljava/io/File;->length()J
move-result-wide v0
long-to-int v0, v0
const-string v1, "Stream cache hit at "
.line 24
invoke-static/range {p1 .. 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 v3
if-eqz v3, :cond_a
invoke-virtual {v1, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
goto :goto_5
:cond_a
new-instance v2, Ljava/lang/String;
invoke-direct {v2, v1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v1, v2
:goto_5
invoke-static {v1}, Lcom/google/android/gms/internal/ads/zzazw;->zzed(Ljava/lang/String;)V
.line 25
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v1
invoke-virtual {v8, v9, v1, v0}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;I)V
return v4
.line 26
:cond_b
iget-object v3, v8, Lcom/google/android/gms/internal/ads/zzbdw;->zzco:Ljava/io/File;
invoke-virtual {v3}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v3
invoke-static {v3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
invoke-static/range {p1 .. p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/String;->length()I
move-result v6
if-eqz v6, :cond_c
invoke-virtual {v3, v5}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
move-object v11, v3
goto :goto_6
:cond_c
new-instance v5, Ljava/lang/String;
invoke-direct {v5, v3}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v11, v5
.line 27
:goto_6
sget-object v3, Lcom/google/android/gms/internal/ads/zzbdw;->zzeha:Ljava/util/Set;
monitor-enter v3
.line 28
:try_start_0
invoke-interface {v3, v11}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v5
if-eqz v5, :cond_e
const-string v0, "Stream cache already in progress at "
.line 29
invoke-static/range {p1 .. p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/String;->length()I
move-result v5
if-eqz v5, :cond_d
invoke-virtual {v0, v4}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_7
:cond_d
new-instance v4, Ljava/lang/String;
invoke-direct {v4, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v0, v4
:goto_7
invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
.line 30
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
const-string v4, "inProgress"
invoke-virtual {v8, v9, v0, v4, v1}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 31
monitor-exit v3
return v2
.line 32
:cond_e
invoke-interface {v3, v11}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 33
monitor-exit v3
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
const-string v12, "error"
.line 34
:try_start_1
invoke-static {}, Lcom/google/android/gms/ads/internal/zzq;->zzli()Lcom/google/android/gms/internal/ads/zzbam;
sget-object v3, Lcom/google/android/gms/internal/ads/zzzz;->zzcjm:Lcom/google/android/gms/internal/ads/zzzk;
.line 35
invoke-static {}, Lcom/google/android/gms/internal/ads/zzvj;->zzpv()Lcom/google/android/gms/internal/ads/zzzv;
move-result-object v5
invoke-virtual {v5, v3}, Lcom/google/android/gms/internal/ads/zzzv;->zzd(Lcom/google/android/gms/internal/ads/zzzk;)Ljava/lang/Object;
move-result-object v3
.line 36
check-cast v3, Ljava/lang/Integer;
invoke-virtual {v3}, Ljava/lang/Integer;->intValue()I
move-result v3
.line 37
new-instance v5, Ljava/net/URL;
invoke-direct {v5, v9}, Ljava/net/URL;-><init>(Ljava/lang/String;)V
move v6, v2
:goto_8
add-int/2addr v6, v4
const/16 v7, 0x14
if-gt v6, v7, :cond_25
.line 38
invoke-virtual {v5}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection;
move-result-object v13
.line 39
invoke-virtual {v13, v3}, Ljava/net/URLConnection;->setConnectTimeout(I)V
.line 40
invoke-virtual {v13, v3}, Ljava/net/URLConnection;->setReadTimeout(I)V
.line 41
instance-of v14, v13, Ljava/net/HttpURLConnection;
if-eqz v14, :cond_24
.line 42
check-cast v13, Ljava/net/HttpURLConnection;
.line 43
new-instance v14, Lcom/google/android/gms/internal/ads/zzazq;
invoke-direct {v14}, Lcom/google/android/gms/internal/ads/zzazq;-><init>()V
.line 44
invoke-virtual {v14, v13, v1}, Lcom/google/android/gms/internal/ads/zzazq;->zza(Ljava/net/HttpURLConnection;[B)V
.line 45
invoke-virtual {v13, v2}, Ljava/net/HttpURLConnection;->setInstanceFollowRedirects(Z)V
.line 46
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result v15
.line 47
invoke-virtual {v14, v13, v15}, Lcom/google/android/gms/internal/ads/zzazq;->zza(Ljava/net/HttpURLConnection;I)V
.line 48
div-int/lit8 v15, v15, 0x64
:try_end_1
.catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_12
.catch Ljava/lang/RuntimeException; {:try_start_1 .. :try_end_1} :catch_11
const/4 v14, 0x3
if-ne v15, v14, :cond_14
:try_start_2
const-string v7, "Location"
.line 49
invoke-virtual {v13, v7}, Ljava/net/HttpURLConnection;->getHeaderField(Ljava/lang/String;)Ljava/lang/String;
move-result-object v7
if-eqz v7, :cond_13
.line 50
new-instance v14, Ljava/net/URL;
invoke-direct {v14, v5, v7}, Ljava/net/URL;-><init>(Ljava/net/URL;Ljava/lang/String;)V
.line 51
invoke-virtual {v14}, Ljava/net/URL;->getProtocol()Ljava/lang/String;
move-result-object v5
if-eqz v5, :cond_12
const-string v15, "http"
.line 52
invoke-virtual {v5, v15}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v15
if-nez v15, :cond_10
const-string v15, "https"
invoke-virtual {v5, v15}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v15
if-nez v15, :cond_10
.line 53
new-instance v0, Ljava/io/IOException;
const-string v2, "Unsupported scheme: "
invoke-virtual {v5}, Ljava/lang/String;->length()I
move-result v3
if-eqz v3, :cond_f
invoke-virtual {v2, v5}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v2
goto :goto_9
:cond_f
new-instance v3, Ljava/lang/String;
invoke-direct {v3, v2}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v2, v3
:goto_9
invoke-direct {v0, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:cond_10
const-string v5, "Redirecting to "
.line 54
invoke-virtual {v7}, Ljava/lang/String;->length()I
move-result v15
if-eqz v15, :cond_11
invoke-virtual {v5, v7}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v5
goto :goto_a
:cond_11
new-instance v7, Ljava/lang/String;
invoke-direct {v7, v5}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v5, v7
:goto_a
invoke-static {v5}, Lcom/google/android/gms/internal/ads/zzazw;->zzed(Ljava/lang/String;)V
.line 55
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->disconnect()V
move-object v5, v14
goto/16 :goto_8
.line 56
:cond_12
new-instance v0, Ljava/io/IOException;
const-string v2, "Protocol is null"
invoke-direct {v0, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
.line 57
:cond_13
new-instance v0, Ljava/io/IOException;
const-string v2, "Missing Location header in redirect"
invoke-direct {v0, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_2
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_1
.catch Ljava/lang/RuntimeException; {:try_start_2 .. :try_end_2} :catch_0
:catch_0
move-exception v0
goto/16 :goto_e
:catch_1
move-exception v0
goto/16 :goto_e
.line 58
:cond_14
:try_start_3
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result v3
:try_end_3
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_3} :catch_12
.catch Ljava/lang/RuntimeException; {:try_start_3 .. :try_end_3} :catch_11
const/16 v4, 0x190
if-lt v3, v4, :cond_16
:try_start_4
const-string v12, "badUrl"
const-string v0, "HTTP request failed. Code: "
.line 59
invoke-static {v3}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v2
invoke-static {v2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_15
invoke-virtual {v0, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
move-object v2, v0
goto :goto_b
:cond_15
new-instance v2, Ljava/lang/String;
invoke-direct {v2, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:try_end_4
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_1
.catch Ljava/lang/RuntimeException; {:try_start_4 .. :try_end_4} :catch_0
.line 60
:goto_b
:try_start_5
new-instance v0, Ljava/io/IOException;
invoke-static/range {p1 .. p1}, 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, 0x20
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5, v4}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v4, "HTTP status code "
invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, " at "
invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v9}, 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-direct {v0, v3}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_5
.catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_3
.catch Ljava/lang/RuntimeException; {:try_start_5 .. :try_end_5} :catch_2
:catch_2
move-exception v0
goto/16 :goto_1a
:catch_3
move-exception v0
goto/16 :goto_1a
.line 61
:cond_16
:try_start_6
invoke-virtual {v13}, Ljava/net/URLConnection;->getContentLength()I
move-result v14
:try_end_6
.catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_12
.catch Ljava/lang/RuntimeException; {:try_start_6 .. :try_end_6} :catch_11
if-gez v14, :cond_18
:try_start_7
const-string v0, "Stream cache aborted, missing content-length header at "
.line 62
invoke-static/range {p1 .. 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 v4
if-eqz v4, :cond_17
invoke-virtual {v0, v3}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_c
:cond_17
new-instance v3, Ljava/lang/String;
invoke-direct {v3, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v0, v3
:goto_c
invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
.line 63
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
const-string v3, "contentLengthMissing"
invoke-virtual {v8, v9, v0, v3, v1}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 64
sget-object v0, Lcom/google/android/gms/internal/ads/zzbdw;->zzeha:Ljava/util/Set;
invoke-interface {v0, v11}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
:try_end_7
.catch Ljava/io/IOException; {:try_start_7 .. :try_end_7} :catch_1
.catch Ljava/lang/RuntimeException; {:try_start_7 .. :try_end_7} :catch_0
return v2
.line 65
:cond_18
:try_start_8
sget-object v3, Lcom/google/android/gms/internal/ads/zzbdw;->zzehb:Ljava/text/DecimalFormat;
int-to-long v4, v14
invoke-virtual {v3, v4, v5}, Ljava/text/DecimalFormat;->format(J)Ljava/lang/String;
move-result-object v3
.line 66
sget-object v4, Lcom/google/android/gms/internal/ads/zzzz;->zzcji:Lcom/google/android/gms/internal/ads/zzzk;
.line 67
invoke-static {}, Lcom/google/android/gms/internal/ads/zzvj;->zzpv()Lcom/google/android/gms/internal/ads/zzzv;
move-result-object v5
invoke-virtual {v5, v4}, Lcom/google/android/gms/internal/ads/zzzv;->zzd(Lcom/google/android/gms/internal/ads/zzzk;)Ljava/lang/Object;
move-result-object v4
.line 68
check-cast v4, Ljava/lang/Integer;
invoke-virtual {v4}, Ljava/lang/Integer;->intValue()I
move-result v15
:try_end_8
.catch Ljava/io/IOException; {:try_start_8 .. :try_end_8} :catch_12
.catch Ljava/lang/RuntimeException; {:try_start_8 .. :try_end_8} :catch_11
if-le v14, v15, :cond_1a
.line 69
:try_start_9
invoke-static {v3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v0
add-int/lit8 v0, v0, 0x21
invoke-static/range {p1 .. p1}, 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/2addr v0, v4
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4, v0}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v0, "Content length "
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, " exceeds limit at "
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
const-string v0, "File too big for full file cache. Size: "
.line 70
invoke-static {v3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/String;->length()I
move-result v4
if-eqz v4, :cond_19
invoke-virtual {v0, v3}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_d
:cond_19
new-instance v3, Ljava/lang/String;
invoke-direct {v3, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v0, v3
.line 71
:goto_d
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v3
const-string v4, "sizeExceeded"
invoke-virtual {v8, v9, v3, v4, v0}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 72
sget-object v0, Lcom/google/android/gms/internal/ads/zzbdw;->zzeha:Ljava/util/Set;
invoke-interface {v0, v11}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
:try_end_9
.catch Ljava/io/IOException; {:try_start_9 .. :try_end_9} :catch_1
.catch Ljava/lang/RuntimeException; {:try_start_9 .. :try_end_9} :catch_0
return v2
:goto_e
move-object v2, v1
goto/16 :goto_1a
.line 73
:cond_1a
:try_start_a
invoke-static {v3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v1
add-int/2addr v1, v7
invoke-static/range {p1 .. p1}, 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/2addr v1, v4
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4, v1}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v1, "Caching "
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " bytes from "
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v9}, 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-static {v1}, Lcom/google/android/gms/internal/ads/zzazw;->zzed(Ljava/lang/String;)V
.line 74
invoke-virtual {v13}, Ljava/net/URLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v1
.line 75
invoke-static {v1}, Ljava/nio/channels/Channels;->newChannel(Ljava/io/InputStream;)Ljava/nio/channels/ReadableByteChannel;
move-result-object v13
.line 76
new-instance v7, Ljava/io/FileOutputStream;
invoke-direct {v7, v10}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
:try_end_a
.catch Ljava/io/IOException; {:try_start_a .. :try_end_a} :catch_12
.catch Ljava/lang/RuntimeException; {:try_start_a .. :try_end_a} :catch_11
.line 77
:try_start_b
invoke-virtual {v7}, Ljava/io/FileOutputStream;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v6
const/high16 v1, 0x100000
.line 78
invoke-static {v1}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v5
.line 79
invoke-static {}, Lcom/google/android/gms/ads/internal/zzq;->zzld()Lcom/google/android/gms/common/util/Clock;
move-result-object v16
.line 80
invoke-interface/range {v16 .. v16}, Lcom/google/android/gms/common/util/Clock;->currentTimeMillis()J
move-result-wide v17
.line 81
sget-object v1, Lcom/google/android/gms/internal/ads/zzzz;->zzcjl:Lcom/google/android/gms/internal/ads/zzzk;
.line 82
invoke-static {}, Lcom/google/android/gms/internal/ads/zzvj;->zzpv()Lcom/google/android/gms/internal/ads/zzzv;
move-result-object v3
invoke-virtual {v3, v1}, Lcom/google/android/gms/internal/ads/zzzv;->zzd(Lcom/google/android/gms/internal/ads/zzzk;)Ljava/lang/Object;
move-result-object v1
.line 83
check-cast v1, Ljava/lang/Long;
invoke-virtual {v1}, Ljava/lang/Long;->longValue()J
move-result-wide v3
.line 84
new-instance v1, Lcom/google/android/gms/internal/ads/zzazc;
invoke-direct {v1, v3, v4}, Lcom/google/android/gms/internal/ads/zzazc;-><init>(J)V
.line 85
sget-object v3, Lcom/google/android/gms/internal/ads/zzzz;->zzcjk:Lcom/google/android/gms/internal/ads/zzzk;
.line 86
invoke-static {}, Lcom/google/android/gms/internal/ads/zzvj;->zzpv()Lcom/google/android/gms/internal/ads/zzzv;
move-result-object v4
invoke-virtual {v4, v3}, Lcom/google/android/gms/internal/ads/zzzv;->zzd(Lcom/google/android/gms/internal/ads/zzzk;)Ljava/lang/Object;
move-result-object v3
.line 87
check-cast v3, Ljava/lang/Long;
invoke-virtual {v3}, Ljava/lang/Long;->longValue()J
move-result-wide v19
.line 88
:goto_f
invoke-interface {v13, v5}, Ljava/nio/channels/ReadableByteChannel;->read(Ljava/nio/ByteBuffer;)I
move-result v3
:try_end_b
.catch Ljava/io/IOException; {:try_start_b .. :try_end_b} :catch_9
.catch Ljava/lang/RuntimeException; {:try_start_b .. :try_end_b} :catch_8
if-ltz v3, :cond_21
add-int v4, v2, v3
if-le v4, v15, :cond_1c
:try_start_c
const-string v12, "sizeExceeded"
const-string v0, "File too big for full file cache. Size: "
.line 89
invoke-static {v4}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_1b
invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
move-object v1, v0
goto :goto_10
:cond_1b
new-instance v1, Ljava/lang/String;
invoke-direct {v1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
:try_end_c
.catch Ljava/io/IOException; {:try_start_c .. :try_end_c} :catch_7
.catch Ljava/lang/RuntimeException; {:try_start_c .. :try_end_c} :catch_6
.line 90
:goto_10
:try_start_d
new-instance v0, Ljava/io/IOException;
const-string v2, "stream cache file size limit exceeded"
invoke-direct {v0, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_d
.catch Ljava/io/IOException; {:try_start_d .. :try_end_d} :catch_5
.catch Ljava/lang/RuntimeException; {:try_start_d .. :try_end_d} :catch_4
:catch_4
move-exception v0
goto :goto_12
:catch_5
move-exception v0
goto :goto_12
:catch_6
move-exception v0
goto :goto_11
:catch_7
move-exception v0
:goto_11
const/4 v1, 0x0
:goto_12
move-object v2, v1
move-object v1, v7
goto/16 :goto_1a
.line 91
:cond_1c
:try_start_e
invoke-virtual {v5}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;
.line 92
:cond_1d
invoke-virtual {v6, v5}, Ljava/nio/channels/FileChannel;->write(Ljava/nio/ByteBuffer;)I
move-result v2
if-gtz v2, :cond_1d
.line 93
invoke-virtual {v5}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;
.line 94
invoke-interface/range {v16 .. v16}, Lcom/google/android/gms/common/util/Clock;->currentTimeMillis()J
move-result-wide v2
sub-long v2, v2, v17
const-wide/16 v21, 0x3e8
mul-long v21, v21, v19
cmp-long v2, v2, v21
if-gtz v2, :cond_20
.line 95
iget-boolean v2, v8, Lcom/google/android/gms/internal/ads/zzbdw;->zzehc:Z
if-nez v2, :cond_1f
.line 96
invoke-virtual {v1}, Lcom/google/android/gms/internal/ads/zzazc;->tryAcquire()Z
move-result v2
if-eqz v2, :cond_1e
.line 97
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v21
.line 98
sget-object v3, Lcom/google/android/gms/internal/ads/zzazm;->zzzn:Landroid/os/Handler;
new-instance v2, Lcom/google/android/gms/internal/ads/zzbdo;
:try_end_e
.catch Ljava/io/IOException; {:try_start_e .. :try_end_e} :catch_9
.catch Ljava/lang/RuntimeException; {:try_start_e .. :try_end_e} :catch_8
const/16 v22, 0x0
move-object/from16 v23, v1
move-object v1, v2
move-object/from16 v24, v2
move-object/from16 v2, p0
move-object/from16 v25, v3
move-object/from16 v3, p1
move/from16 v26, v4
move-object/from16 v4, v21
move-object/from16 v21, v5
move/from16 v5, v26
move-object/from16 v27, v6
move v6, v14
move-object/from16 v28, v7
move/from16 v7, v22
:try_start_f
invoke-direct/range {v1 .. v7}, Lcom/google/android/gms/internal/ads/zzbdo;-><init>(Lcom/google/android/gms/internal/ads/zzbdl;Ljava/lang/String;Ljava/lang/String;IIZ)V
move-object/from16 v2, v24
move-object/from16 v1, v25
invoke-virtual {v1, v2}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
goto :goto_14
:catch_8
move-exception v0
:goto_13
move-object/from16 v28, v7
goto/16 :goto_17
:catch_9
move-exception v0
goto :goto_13
:cond_1e
move-object/from16 v23, v1
move/from16 v26, v4
move-object/from16 v21, v5
move-object/from16 v27, v6
move-object/from16 v28, v7
:goto_14
move-object/from16 v5, v21
move-object/from16 v1, v23
move/from16 v2, v26
move-object/from16 v6, v27
move-object/from16 v7, v28
goto/16 :goto_f
:cond_1f
move-object/from16 v28, v7
const-string v1, "externalAbort"
:try_end_f
.catch Ljava/io/IOException; {:try_start_f .. :try_end_f} :catch_f
.catch Ljava/lang/RuntimeException; {:try_start_f .. :try_end_f} :catch_e
.line 99
:try_start_10
new-instance v0, Ljava/io/IOException;
const-string v2, "abort requested"
invoke-direct {v0, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_10
.catch Ljava/io/IOException; {:try_start_10 .. :try_end_10} :catch_b
.catch Ljava/lang/RuntimeException; {:try_start_10 .. :try_end_10} :catch_a
:catch_a
move-exception v0
:goto_15
move-object v12, v1
goto/16 :goto_17
:catch_b
move-exception v0
goto :goto_15
:cond_20
move-object/from16 v28, v7
:try_start_11
const-string v12, "downloadTimeout"
.line 100
invoke-static/range {v19 .. v20}, Ljava/lang/Long;->toString(J)Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v1
add-int/lit8 v1, v1, 0x1d
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2, v1}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v1, "Timeout exceeded. Limit: "
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, " sec"
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 v2
:try_end_11
.catch Ljava/io/IOException; {:try_start_11 .. :try_end_11} :catch_f
.catch Ljava/lang/RuntimeException; {:try_start_11 .. :try_end_11} :catch_e
.line 101
:try_start_12
new-instance v0, Ljava/io/IOException;
const-string v1, "stream cache time limit exceeded"
invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_12
.catch Ljava/io/IOException; {:try_start_12 .. :try_end_12} :catch_d
.catch Ljava/lang/RuntimeException; {:try_start_12 .. :try_end_12} :catch_c
:catch_c
move-exception v0
goto :goto_18
:catch_d
move-exception v0
goto :goto_18
:catch_e
move-exception v0
goto :goto_17
:catch_f
move-exception v0
goto :goto_17
:cond_21
move-object/from16 v28, v7
const/4 v1, 0x3
.line 102
:try_start_13
invoke-virtual/range {v28 .. v28}, Ljava/io/FileOutputStream;->close()V
.line 103
invoke-static {v1}, Lcom/google/android/gms/internal/ads/zzazw;->isLoggable(I)Z
move-result v1
if-eqz v1, :cond_22
.line 104
sget-object v1, Lcom/google/android/gms/internal/ads/zzbdw;->zzehb:Ljava/text/DecimalFormat;
int-to-long v3, v2
invoke-virtual {v1, v3, v4}, Ljava/text/DecimalFormat;->format(J)Ljava/lang/String;
move-result-object v1
.line 105
invoke-static {v1}, 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/lit8 v3, v3, 0x16
invoke-static/range {p1 .. p1}, 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/2addr v3, v4
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4, v3}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v3, "Preloaded "
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " bytes from "
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v9}, 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-static {v1}, Lcom/google/android/gms/internal/ads/zzazw;->zzed(Ljava/lang/String;)V
:cond_22
const/4 v1, 0x1
const/4 v3, 0x0
.line 106
invoke-virtual {v10, v1, v3}, Ljava/io/File;->setReadable(ZZ)Z
.line 107
invoke-virtual {v0}, Ljava/io/File;->isFile()Z
move-result v1
if-eqz v1, :cond_23
.line 108
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v3
invoke-virtual {v0, v3, v4}, Ljava/io/File;->setLastModified(J)Z
:try_end_13
.catch Ljava/io/IOException; {:try_start_13 .. :try_end_13} :catch_f
.catch Ljava/lang/RuntimeException; {:try_start_13 .. :try_end_13} :catch_e
goto :goto_16
.line 109
:cond_23
:try_start_14
invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z
:try_end_14
.catch Ljava/io/IOException; {:try_start_14 .. :try_end_14} :catch_10
.catch Ljava/lang/RuntimeException; {:try_start_14 .. :try_end_14} :catch_e
.line 110
:catch_10
:goto_16
:try_start_15
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
invoke-virtual {v8, v9, v0, v2}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;I)V
.line 111
sget-object v0, Lcom/google/android/gms/internal/ads/zzbdw;->zzeha:Ljava/util/Set;
invoke-interface {v0, v11}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
:try_end_15
.catch Ljava/io/IOException; {:try_start_15 .. :try_end_15} :catch_f
.catch Ljava/lang/RuntimeException; {:try_start_15 .. :try_end_15} :catch_e
const/4 v0, 0x1
return v0
:goto_17
const/4 v2, 0x0
:goto_18
move-object/from16 v1, v28
goto :goto_1a
.line 112
:cond_24
:try_start_16
new-instance v0, Ljava/io/IOException;
const-string v1, "Invalid protocol."
invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
.line 113
:cond_25
new-instance v0, Ljava/io/IOException;
const-string v1, "Too many redirects (20)"
invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_16
.catch Ljava/io/IOException; {:try_start_16 .. :try_end_16} :catch_12
.catch Ljava/lang/RuntimeException; {:try_start_16 .. :try_end_16} :catch_11
:catch_11
move-exception v0
goto :goto_19
:catch_12
move-exception v0
:goto_19
const/4 v2, 0x0
const/4 v1, 0x0
.line 114
:goto_1a
instance-of v3, v0, Ljava/lang/RuntimeException;
if-eqz v3, :cond_26
.line 115
invoke-static {}, Lcom/google/android/gms/ads/internal/zzq;->zzla()Lcom/google/android/gms/internal/ads/zzawd;
move-result-object v3
const-string v4, "VideoStreamFullFileCache.preload"
invoke-virtual {v3, v0, v4}, Lcom/google/android/gms/internal/ads/zzawd;->zza(Ljava/lang/Throwable;Ljava/lang/String;)V
.line 116
:cond_26
:try_start_17
invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V
:try_end_17
.catch Ljava/io/IOException; {:try_start_17 .. :try_end_17} :catch_13
.catch Ljava/lang/NullPointerException; {:try_start_17 .. :try_end_17} :catch_13
.line 117
:catch_13
iget-boolean v1, v8, Lcom/google/android/gms/internal/ads/zzbdw;->zzehc:Z
if-eqz v1, :cond_27
const/16 v0, 0x1a
.line 118
invoke-static {v9, v0}, Lcom/android/billingclient/api/d;->a(Ljava/lang/String;I)I
move-result v0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1, v0}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v0, "Preload aborted for URL \""
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string 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
invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzazw;->zzfb(Ljava/lang/String;)V
goto :goto_1b
:cond_27
const/16 v1, 0x19
.line 119
invoke-static {v9, v1}, Lcom/android/billingclient/api/d;->a(Ljava/lang/String;I)I
move-result v1
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3, v1}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v1, "Preload failed for URL \""
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "\""
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v1, v0}, Lcom/google/android/gms/internal/ads/zzazw;->zzd(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 120
:goto_1b
invoke-virtual {v10}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_29
invoke-virtual {v10}, Ljava/io/File;->delete()Z
move-result v0
if-nez v0, :cond_29
const-string v0, "Could not delete partial cache file at "
.line 121
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v3
if-eqz v3, :cond_28
invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_1c
:cond_28
new-instance v1, Ljava/lang/String;
invoke-direct {v1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v0, v1
:goto_1c
invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzazw;->zzfc(Ljava/lang/String;)V
.line 122
:cond_29
invoke-virtual {v10}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
invoke-virtual {v8, v9, v0, v12, v2}, Lcom/google/android/gms/internal/ads/zzbdl;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 123
sget-object v0, Lcom/google/android/gms/internal/ads/zzbdw;->zzeha:Ljava/util/Set;
invoke-interface {v0, v11}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
const/4 v0, 0x0
return v0
:catchall_0
move-exception v0
.line 124
:try_start_18
monitor-exit v3
:try_end_18
.catchall {:try_start_18 .. :try_end_18} :catchall_0
throw v0
.end method