zzbde.smali

.class public final Lcom/google/android/gms/internal/ads/zzbde;
.super Lcom/google/android/gms/internal/ads/zzbcx;
.source "com.google.android.gms:play-services-ads@@19.5.0"


# static fields
.field private static final zzeop:Ljava/util/Set;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Set<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field

.field private static final zzeoq:Ljava/text/DecimalFormat;


# instance fields
.field private zzcw:Ljava/io/File;

.field private zzeor:Z


# direct methods
.method static constructor <clinit>()V
    .registers 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/zzbde;->zzeop: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/zzbde;->zzeoq:Ljava/text/DecimalFormat;

    return-void
.end method

.method public constructor <init>(Lcom/google/android/gms/internal/ads/zzbbe;)V
    .registers 5

    .line 1
    invoke-direct {p0, p1}, Lcom/google/android/gms/internal/ads/zzbcx;-><init>(Lcom/google/android/gms/internal/ads/zzbbe;)V

    .line 2
    iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbcx;->mContext:Landroid/content/Context;

    invoke-virtual {p1}, Landroid/content/Context;->getCacheDir()Ljava/io/File;

    move-result-object p1

    if-nez p1, :cond_11

    const-string p1, "Context.getCacheDir() returned null"

    .line 3
    invoke-static {p1}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    return-void

    .line 4
    :cond_11
    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/zzbde;->zzcw:Ljava/io/File;

    .line 5
    iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    invoke-virtual {p1}, Ljava/io/File;->isDirectory()Z

    move-result p1

    const/4 v0, 0x0

    if-nez p1, :cond_4e

    iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    invoke-virtual {p1}, Ljava/io/File;->mkdirs()Z

    move-result p1

    if-nez p1, :cond_4e

    const-string p1, "Could not create preload cache directory at "

    .line 6
    iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw: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_42

    invoke-virtual {p1, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    goto :goto_48

    :cond_42
    new-instance v1, Ljava/lang/String;

    invoke-direct {v1, p1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object p1, v1

    :goto_48
    invoke-static {p1}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    .line 7
    iput-object v0, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    return-void

    .line 8
    :cond_4e
    iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    const/4 v1, 0x0

    const/4 v2, 0x1

    invoke-virtual {p1, v2, v1}, Ljava/io/File;->setReadable(ZZ)Z

    move-result p1

    if-eqz p1, :cond_62

    iget-object p1, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    .line 9
    invoke-virtual {p1, v2, v1}, Ljava/io/File;->setExecutable(ZZ)Z

    move-result p1

    if-nez p1, :cond_61

    goto :goto_62

    :cond_61
    return-void

    :cond_62
    :goto_62
    const-string p1, "Could not set cache file permissions at "

    .line 10
    iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw: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_79

    invoke-virtual {p1, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    goto :goto_7f

    :cond_79
    new-instance v1, Ljava/lang/String;

    invoke-direct {v1, p1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object p1, v1

    :goto_7f
    invoke-static {p1}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    .line 11
    iput-object v0, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    return-void
.end method

.method private final zzd(Ljava/io/File;)Ljava/io/File;
    .registers 5

    .line 1
    new-instance v0, Ljava/io/File;

    iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzcw: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
    .registers 2

    const/4 v0, 0x1

    .line 1
    iput-boolean v0, p0, Lcom/google/android/gms/internal/ads/zzbde;->zzeor:Z

    return-void
.end method

.method public final zzfj(Ljava/lang/String;)Z
    .registers 32

    move-object/from16 v8, p0

    move-object/from16 v9, p1

    .line 1
    iget-object v0, v8, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    const/4 v10, 0x0

    const/4 v11, 0x0

    if-nez v0, :cond_10

    const-string v0, "noCacheDir"

    .line 2
    invoke-virtual {v8, v9, v10, v0, v10}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    return v11

    .line 3
    :cond_10
    iget-object v0, v8, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    if-nez v0, :cond_16

    const/4 v3, 0x0

    goto :goto_32

    .line 4
    :cond_16
    invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;

    move-result-object v0

    array-length v1, v0

    const/4 v2, 0x0

    const/4 v3, 0x0

    :goto_1d
    if-ge v2, v1, :cond_32

    aget-object v4, v0, v2

    .line 5
    invoke-virtual {v4}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v4

    const-string v5, ".done"

    invoke-virtual {v4, v5}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z

    move-result v4

    if-nez v4, :cond_2f

    add-int/lit8 v3, v3, 0x1

    :cond_2f
    add-int/lit8 v2, v2, 0x1

    goto :goto_1d

    .line 6
    :cond_32
    :goto_32
    sget-object v0, Lcom/google/android/gms/internal/ads/zzabf;->zzcmf:Lcom/google/android/gms/internal/ads/zzaaq;

    .line 7
    invoke-static {}, Lcom/google/android/gms/internal/ads/zzwq;->zzqe()Lcom/google/android/gms/internal/ads/zzabb;

    move-result-object v1

    invoke-virtual {v1, v0}, Lcom/google/android/gms/internal/ads/zzabb;->zzd(Lcom/google/android/gms/internal/ads/zzaaq;)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 v3, v0, :cond_96

    .line 9
    iget-object v0, v8, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    if-nez v0, :cond_4a

    :cond_48
    const/4 v0, 0x0

    goto :goto_89

    :cond_4a
    const-wide v1, 0x7fffffffffffffffL

    .line 10
    invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;

    move-result-object v0

    array-length v3, v0

    move-wide v4, v1

    move-object v2, v10

    const/4 v1, 0x0

    :goto_57
    if-ge v1, v3, :cond_74

    aget-object v6, v0, v1

    .line 11
    invoke-virtual {v6}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v7

    const-string v12, ".done"

    invoke-virtual {v7, v12}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z

    move-result v7

    if-nez v7, :cond_71

    .line 12
    invoke-virtual {v6}, Ljava/io/File;->lastModified()J

    move-result-wide v12

    cmp-long v7, v12, v4

    if-gez v7, :cond_71

    move-object v2, v6

    move-wide v4, v12

    :cond_71
    add-int/lit8 v1, v1, 0x1

    goto :goto_57

    :cond_74
    if-eqz v2, :cond_48

    .line 13
    invoke-virtual {v2}, Ljava/io/File;->delete()Z

    move-result v0

    .line 14
    invoke-direct {v8, v2}, Lcom/google/android/gms/internal/ads/zzbde;->zzd(Ljava/io/File;)Ljava/io/File;

    move-result-object v1

    .line 15
    invoke-virtual {v1}, Ljava/io/File;->isFile()Z

    move-result v2

    if-eqz v2, :cond_89

    .line 16
    invoke-virtual {v1}, Ljava/io/File;->delete()Z

    move-result v1

    and-int/2addr v0, v1

    :cond_89
    :goto_89
    if-nez v0, :cond_10

    const-string v0, "Unable to expire stream cache"

    .line 17
    invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    const-string v0, "expireFailed"

    .line 18
    invoke-virtual {v8, v9, v10, v0, v10}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    return v11

    .line 19
    :cond_96
    invoke-virtual/range {p0 .. p1}, Lcom/google/android/gms/internal/ads/zzbcx;->zzfk(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 20
    new-instance v12, Ljava/io/File;

    iget-object v1, v8, Lcom/google/android/gms/internal/ads/zzbde;->zzcw:Ljava/io/File;

    invoke-direct {v12, v1, v0}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V

    .line 21
    invoke-direct {v8, v12}, Lcom/google/android/gms/internal/ads/zzbde;->zzd(Ljava/io/File;)Ljava/io/File;

    move-result-object v0

    .line 22
    invoke-virtual {v12}, Ljava/io/File;->isFile()Z

    move-result v1

    const/4 v13, 0x1

    if-eqz v1, :cond_d9

    invoke-virtual {v0}, Ljava/io/File;->isFile()Z

    move-result v1

    if-eqz v1, :cond_d9

    .line 23
    invoke-virtual {v12}, Ljava/io/File;->length()J

    move-result-wide v0

    long-to-int v1, v0

    const-string v0, "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_c8

    invoke-virtual {v0, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    goto :goto_ce

    :cond_c8
    new-instance v2, Ljava/lang/String;

    invoke-direct {v2, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v0, v2

    :goto_ce
    invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzeb(Ljava/lang/String;)V

    .line 25
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v8, v9, v0, v1}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;I)V

    return v13

    .line 26
    :cond_d9
    iget-object v1, v8, Lcom/google/android/gms/internal/ads/zzbde;->zzcw: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-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_f3

    invoke-virtual {v1, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    move-object v14, v1

    goto :goto_f9

    :cond_f3
    new-instance v2, Ljava/lang/String;

    invoke-direct {v2, v1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v14, v2

    .line 27
    :goto_f9
    sget-object v1, Lcom/google/android/gms/internal/ads/zzbde;->zzeop:Ljava/util/Set;

    monitor-enter v1

    .line 28
    :try_start_fc
    sget-object v2, Lcom/google/android/gms/internal/ads/zzbde;->zzeop:Ljava/util/Set;

    invoke-interface {v2, v14}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z

    move-result v2

    if-eqz v2, :cond_129

    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 v2

    invoke-virtual {v2}, Ljava/lang/String;->length()I

    move-result v3

    if-eqz v3, :cond_115

    invoke-virtual {v0, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    goto :goto_11b

    :cond_115
    new-instance v2, Ljava/lang/String;

    invoke-direct {v2, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v0, v2

    :goto_11b
    invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    .line 30
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v0

    const-string v2, "inProgress"

    invoke-virtual {v8, v9, v0, v2, v10}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    .line 31
    monitor-exit v1

    return v11

    .line 32
    :cond_129
    sget-object v2, Lcom/google/android/gms/internal/ads/zzbde;->zzeop:Ljava/util/Set;

    invoke-interface {v2, v14}, Ljava/util/Set;->add(Ljava/lang/Object;)Z

    .line 33
    monitor-exit v1
    :try_end_12f
    .catchall {:try_start_fc .. :try_end_12f} :catchall_5c0

    const-string v15, "error"

    .line 34
    :try_start_131
    invoke-static {}, Lcom/google/android/gms/ads/internal/zzp;->zzlc()Lcom/google/android/gms/internal/ads/zzazt;

    sget-object v1, Lcom/google/android/gms/internal/ads/zzabf;->zzcmk:Lcom/google/android/gms/internal/ads/zzaaq;

    .line 35
    invoke-static {}, Lcom/google/android/gms/internal/ads/zzwq;->zzqe()Lcom/google/android/gms/internal/ads/zzabb;

    move-result-object v2

    invoke-virtual {v2, v1}, Lcom/google/android/gms/internal/ads/zzabb;->zzd(Lcom/google/android/gms/internal/ads/zzaaq;)Ljava/lang/Object;

    move-result-object v1

    .line 36
    check-cast v1, Ljava/lang/Integer;

    invoke-virtual {v1}, Ljava/lang/Integer;->intValue()I

    move-result v1

    .line 37
    new-instance v2, Ljava/net/URL;

    invoke-direct {v2, v9}, Ljava/net/URL;-><init>(Ljava/lang/String;)V

    move-object v3, v2

    const/4 v2, 0x0

    :goto_14b
    add-int/2addr v2, v13

    const/16 v4, 0x14

    if-gt v2, v4, :cond_514

    .line 38
    invoke-virtual {v3}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection;

    move-result-object v5

    .line 39
    invoke-virtual {v5, v1}, Ljava/net/URLConnection;->setConnectTimeout(I)V

    .line 40
    invoke-virtual {v5, v1}, Ljava/net/URLConnection;->setReadTimeout(I)V

    .line 41
    instance-of v6, v5, Ljava/net/HttpURLConnection;

    if-eqz v6, :cond_509

    .line 42
    check-cast v5, Ljava/net/HttpURLConnection;

    .line 43
    new-instance v6, Lcom/google/android/gms/internal/ads/zzayu;

    invoke-direct {v6}, Lcom/google/android/gms/internal/ads/zzayu;-><init>()V

    .line 44
    invoke-virtual {v6, v5, v10}, Lcom/google/android/gms/internal/ads/zzayu;->zza(Ljava/net/HttpURLConnection;[B)V

    .line 45
    invoke-virtual {v5, v11}, Ljava/net/HttpURLConnection;->setInstanceFollowRedirects(Z)V

    .line 46
    invoke-virtual {v5}, Ljava/net/HttpURLConnection;->getResponseCode()I

    move-result v7

    .line 47
    invoke-virtual {v6, v5, v7}, Lcom/google/android/gms/internal/ads/zzayu;->zza(Ljava/net/HttpURLConnection;I)V

    .line 48
    div-int/lit8 v7, v7, 0x64
    :try_end_174
    .catch Ljava/io/IOException; {:try_start_131 .. :try_end_174} :catch_527
    .catch Ljava/lang/RuntimeException; {:try_start_131 .. :try_end_174} :catch_525

    const/4 v6, 0x3

    if-ne v7, v6, :cond_1ee

    :try_start_177
    const-string v4, "Location"

    .line 49
    invoke-virtual {v5, v4}, Ljava/net/HttpURLConnection;->getHeaderField(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v4

    if-eqz v4, :cond_1df

    .line 50
    new-instance v6, Ljava/net/URL;

    invoke-direct {v6, v3, v4}, Ljava/net/URL;-><init>(Ljava/net/URL;Ljava/lang/String;)V

    .line 51
    invoke-virtual {v6}, Ljava/net/URL;->getProtocol()Ljava/lang/String;

    move-result-object v3

    if-eqz v3, :cond_1d7

    const-string v7, "http"

    .line 52
    invoke-virtual {v3, v7}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v7

    if-nez v7, :cond_1b7

    const-string v7, "https"

    invoke-virtual {v3, v7}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v7

    if-nez v7, :cond_1b7

    .line 53
    new-instance v0, Ljava/io/IOException;

    const-string v1, "Unsupported scheme: "

    invoke-static {v3}, 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_1ad

    invoke-virtual {v1, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    goto :goto_1b3

    :cond_1ad
    new-instance v2, Ljava/lang/String;

    invoke-direct {v2, v1}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v1, v2

    :goto_1b3
    invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V

    throw v0

    :cond_1b7
    const-string v3, "Redirecting to "

    .line 54
    invoke-static {v4}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v4

    invoke-virtual {v4}, Ljava/lang/String;->length()I

    move-result v7

    if-eqz v7, :cond_1c8

    invoke-virtual {v3, v4}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v3

    goto :goto_1ce

    :cond_1c8
    new-instance v4, Ljava/lang/String;

    invoke-direct {v4, v3}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v3, v4

    :goto_1ce
    invoke-static {v3}, Lcom/google/android/gms/internal/ads/zzaza;->zzeb(Ljava/lang/String;)V

    .line 55
    invoke-virtual {v5}, Ljava/net/HttpURLConnection;->disconnect()V

    move-object v3, v6

    goto/16 :goto_14b

    .line 56
    :cond_1d7
    new-instance v0, Ljava/io/IOException;

    const-string v1, "Protocol is null"

    invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V

    throw v0

    .line 57
    :cond_1df
    new-instance v0, Ljava/io/IOException;

    const-string v1, "Missing Location header in redirect"

    invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V

    throw v0
    :try_end_1e7
    .catch Ljava/io/IOException; {:try_start_177 .. :try_end_1e7} :catch_1e9
    .catch Ljava/lang/RuntimeException; {:try_start_177 .. :try_end_1e7} :catch_1e7

    :catch_1e7
    move-exception v0

    goto :goto_1ea

    :catch_1e9
    move-exception v0

    :goto_1ea
    move-object v2, v10

    :goto_1eb
    move-object v1, v14

    goto/16 :goto_52d

    .line 58
    :cond_1ee
    :try_start_1ee
    instance-of v1, v5, Ljava/net/HttpURLConnection;
    :try_end_1f0
    .catch Ljava/io/IOException; {:try_start_1ee .. :try_end_1f0} :catch_527
    .catch Ljava/lang/RuntimeException; {:try_start_1ee .. :try_end_1f0} :catch_525

    if-eqz v1, :cond_244

    .line 59
    :try_start_1f2
    invoke-virtual {v5}, Ljava/net/HttpURLConnection;->getResponseCode()I

    move-result v1

    const/16 v2, 0x190

    if-lt v1, v2, :cond_244

    const-string v15, "badUrl"

    const-string v0, "HTTP request failed. Code: "

    .line 60
    invoke-static {v1}, 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 v3

    if-eqz v3, :cond_212

    invoke-virtual {v0, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    move-object v2, v0

    goto :goto_217

    :cond_212
    new-instance v2, Ljava/lang/String;

    invoke-direct {v2, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
    :try_end_217
    .catch Ljava/io/IOException; {:try_start_1f2 .. :try_end_217} :catch_1e9
    .catch Ljava/lang/RuntimeException; {:try_start_1f2 .. :try_end_217} :catch_1e7

    .line 61
    :goto_217
    :try_start_217
    new-instance v0, Ljava/io/IOException;

    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 v3

    add-int/lit8 v3, v3, 0x20

    new-instance v4, Ljava/lang/StringBuilder;

    invoke-direct {v4, v3}, Ljava/lang/StringBuilder;-><init>(I)V

    const-string v3, "HTTP status code "

    invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v1, " at "

    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-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V

    throw v0
    :try_end_240
    .catch Ljava/io/IOException; {:try_start_217 .. :try_end_240} :catch_242
    .catch Ljava/lang/RuntimeException; {:try_start_217 .. :try_end_240} :catch_240

    :catch_240
    move-exception v0

    goto :goto_1eb

    :catch_242
    move-exception v0

    goto :goto_1eb

    .line 62
    :cond_244
    :try_start_244
    invoke-virtual {v5}, Ljava/net/URLConnection;->getContentLength()I

    move-result v7
    :try_end_248
    .catch Ljava/io/IOException; {:try_start_244 .. :try_end_248} :catch_527
    .catch Ljava/lang/RuntimeException; {:try_start_244 .. :try_end_248} :catch_525

    if-gez v7, :cond_273

    :try_start_24a
    const-string v0, "Stream cache aborted, missing content-length header at "

    .line 63
    invoke-static/range {p1 .. p1}, 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_25b

    invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    goto :goto_261

    :cond_25b
    new-instance v1, Ljava/lang/String;

    invoke-direct {v1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v0, v1

    :goto_261
    invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    .line 64
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v0

    const-string v1, "contentLengthMissing"

    invoke-virtual {v8, v9, v0, v1, v10}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    .line 65
    sget-object v0, Lcom/google/android/gms/internal/ads/zzbde;->zzeop:Ljava/util/Set;

    invoke-interface {v0, v14}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
    :try_end_272
    .catch Ljava/io/IOException; {:try_start_24a .. :try_end_272} :catch_1e9
    .catch Ljava/lang/RuntimeException; {:try_start_24a .. :try_end_272} :catch_1e7

    return v11

    .line 66
    :cond_273
    :try_start_273
    sget-object v1, Lcom/google/android/gms/internal/ads/zzbde;->zzeoq:Ljava/text/DecimalFormat;

    int-to-long v2, v7

    invoke-virtual {v1, v2, v3}, Ljava/text/DecimalFormat;->format(J)Ljava/lang/String;

    move-result-object v1

    .line 67
    sget-object v2, Lcom/google/android/gms/internal/ads/zzabf;->zzcmg:Lcom/google/android/gms/internal/ads/zzaaq;

    .line 68
    invoke-static {}, Lcom/google/android/gms/internal/ads/zzwq;->zzqe()Lcom/google/android/gms/internal/ads/zzabb;

    move-result-object v3

    invoke-virtual {v3, v2}, Lcom/google/android/gms/internal/ads/zzabb;->zzd(Lcom/google/android/gms/internal/ads/zzaaq;)Ljava/lang/Object;

    move-result-object v2

    .line 69
    check-cast v2, Ljava/lang/Integer;

    invoke-virtual {v2}, Ljava/lang/Integer;->intValue()I

    move-result v3
    :try_end_28a
    .catch Ljava/io/IOException; {:try_start_273 .. :try_end_28a} :catch_527
    .catch Ljava/lang/RuntimeException; {:try_start_273 .. :try_end_28a} :catch_525

    if-le v7, v3, :cond_2e1

    .line 70
    :try_start_28c
    invoke-static {v1}, 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 v2

    invoke-virtual {v2}, Ljava/lang/String;->length()I

    move-result v2

    add-int/2addr v0, v2

    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2, v0}, Ljava/lang/StringBuilder;-><init>(I)V

    const-string v0, "Content length "

    invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v0, " exceeds limit at "

    invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    const-string v0, "File too big for full file cache. Size: "

    .line 71
    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_2cc

    invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    goto :goto_2d2

    :cond_2cc
    new-instance v1, Ljava/lang/String;

    invoke-direct {v1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v0, v1

    .line 72
    :goto_2d2
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v1

    const-string v2, "sizeExceeded"

    invoke-virtual {v8, v9, v1, v2, v0}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    .line 73
    sget-object v0, Lcom/google/android/gms/internal/ads/zzbde;->zzeop:Ljava/util/Set;

    invoke-interface {v0, v14}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
    :try_end_2e0
    .catch Ljava/io/IOException; {:try_start_28c .. :try_end_2e0} :catch_1e9
    .catch Ljava/lang/RuntimeException; {:try_start_28c .. :try_end_2e0} :catch_1e7

    return v11

    .line 74
    :cond_2e1
    :try_start_2e1
    invoke-static {v1}, 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/2addr v2, v4

    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 v2, v4

    new-instance v4, Ljava/lang/StringBuilder;

    invoke-direct {v4, v2}, Ljava/lang/StringBuilder;-><init>(I)V

    const-string v2, "Caching "

    invoke-virtual {v4, v2}, 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/zzaza;->zzeb(Ljava/lang/String;)V

    .line 75
    invoke-virtual {v5}, Ljava/net/URLConnection;->getInputStream()Ljava/io/InputStream;

    move-result-object v1

    .line 76
    invoke-static {v1}, Ljava/nio/channels/Channels;->newChannel(Ljava/io/InputStream;)Ljava/nio/channels/ReadableByteChannel;

    move-result-object v5

    .line 77
    new-instance v4, Ljava/io/FileOutputStream;

    invoke-direct {v4, v12}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
    :try_end_31c
    .catch Ljava/io/IOException; {:try_start_2e1 .. :try_end_31c} :catch_527
    .catch Ljava/lang/RuntimeException; {:try_start_2e1 .. :try_end_31c} :catch_525

    .line 78
    :try_start_31c
    invoke-virtual {v4}, Ljava/io/FileOutputStream;->getChannel()Ljava/nio/channels/FileChannel;

    move-result-object v2

    const/high16 v1, 0x100000

    .line 79
    invoke-static {v1}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;

    move-result-object v1

    .line 80
    invoke-static {}, Lcom/google/android/gms/ads/internal/zzp;->zzkx()Lcom/google/android/gms/common/util/Clock;

    move-result-object v16

    .line 81
    invoke-interface/range {v16 .. v16}, Lcom/google/android/gms/common/util/Clock;->currentTimeMillis()J

    move-result-wide v17

    .line 82
    sget-object v6, Lcom/google/android/gms/internal/ads/zzabf;->zzcmj:Lcom/google/android/gms/internal/ads/zzaaq;

    .line 83
    invoke-static {}, Lcom/google/android/gms/internal/ads/zzwq;->zzqe()Lcom/google/android/gms/internal/ads/zzabb;

    move-result-object v10

    invoke-virtual {v10, v6}, Lcom/google/android/gms/internal/ads/zzabb;->zzd(Lcom/google/android/gms/internal/ads/zzaaq;)Ljava/lang/Object;

    move-result-object v6

    .line 84
    check-cast v6, Ljava/lang/Long;
    :try_end_33a
    .catch Ljava/io/IOException; {:try_start_31c .. :try_end_33a} :catch_4ff
    .catch Ljava/lang/RuntimeException; {:try_start_31c .. :try_end_33a} :catch_4fd

    move-object v10, v14

    :try_start_33b
    invoke-virtual {v6}, Ljava/lang/Long;->longValue()J

    move-result-wide v13

    .line 85
    new-instance v6, Lcom/google/android/gms/ads/internal/util/zzbs;

    invoke-direct {v6, v13, v14}, Lcom/google/android/gms/ads/internal/util/zzbs;-><init>(J)V

    .line 86
    sget-object v13, Lcom/google/android/gms/internal/ads/zzabf;->zzcmi:Lcom/google/android/gms/internal/ads/zzaaq;

    .line 87
    invoke-static {}, Lcom/google/android/gms/internal/ads/zzwq;->zzqe()Lcom/google/android/gms/internal/ads/zzabb;

    move-result-object v14

    invoke-virtual {v14, v13}, Lcom/google/android/gms/internal/ads/zzabb;->zzd(Lcom/google/android/gms/internal/ads/zzaaq;)Ljava/lang/Object;

    move-result-object v13

    .line 88
    check-cast v13, Ljava/lang/Long;

    invoke-virtual {v13}, Ljava/lang/Long;->longValue()J

    move-result-wide v13

    .line 89
    :goto_354
    invoke-interface {v5, v1}, Ljava/nio/channels/ReadableByteChannel;->read(Ljava/nio/ByteBuffer;)I

    move-result v20
    :try_end_358
    .catch Ljava/io/IOException; {:try_start_33b .. :try_end_358} :catch_4f8
    .catch Ljava/lang/RuntimeException; {:try_start_33b .. :try_end_358} :catch_4f6

    if-ltz v20, :cond_474

    add-int v11, v11, v20

    if-le v11, v3, :cond_391

    :try_start_35e
    const-string v15, "sizeExceeded"

    const-string v0, "File too big for full file cache. Size: "

    .line 90
    invoke-static {v11}, 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_376

    invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    move-object v1, v0

    goto :goto_37b

    :cond_376
    new-instance v1, Ljava/lang/String;

    invoke-direct {v1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
    :try_end_37b
    .catch Ljava/io/IOException; {:try_start_35e .. :try_end_37b} :catch_38b
    .catch Ljava/lang/RuntimeException; {:try_start_35e .. :try_end_37b} :catch_389

    .line 91
    :goto_37b
    :try_start_37b
    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_383
    .catch Ljava/io/IOException; {:try_start_37b .. :try_end_383} :catch_385
    .catch Ljava/lang/RuntimeException; {:try_start_37b .. :try_end_383} :catch_383

    :catch_383
    move-exception v0

    goto :goto_386

    :catch_385
    move-exception v0

    :goto_386
    move-object v2, v1

    move-object v1, v10

    goto :goto_38e

    :catch_389
    move-exception v0

    goto :goto_38c

    :catch_38b
    move-exception v0

    :goto_38c
    move-object v1, v10

    const/4 v2, 0x0

    :goto_38e
    move-object v10, v4

    goto/16 :goto_52d

    .line 92
    :cond_391
    :try_start_391
    invoke-virtual {v1}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;

    .line 93
    :goto_394
    invoke-virtual {v2, v1}, Ljava/nio/channels/FileChannel;->write(Ljava/nio/ByteBuffer;)I

    move-result v20

    if-gtz v20, :cond_466

    .line 94
    invoke-virtual {v1}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;

    .line 95
    invoke-interface/range {v16 .. v16}, Lcom/google/android/gms/common/util/Clock;->currentTimeMillis()J

    move-result-wide v20

    sub-long v20, v20, v17

    const-wide/16 v22, 0x3e8

    mul-long v22, v22, v13

    cmp-long v24, v20, v22

    if-gtz v24, :cond_424

    move-object/from16 v20, v1

    .line 96
    iget-boolean v1, v8, Lcom/google/android/gms/internal/ads/zzbde;->zzeor:Z

    if-nez v1, :cond_414

    .line 97
    invoke-virtual {v6}, Lcom/google/android/gms/ads/internal/util/zzbs;->tryAcquire()Z

    move-result v1

    if-eqz v1, :cond_3ee

    .line 98
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v21

    .line 99
    sget-object v1, Lcom/google/android/gms/internal/ads/zzayr;->zzzz:Landroid/os/Handler;
    :try_end_3bd
    .catch Ljava/io/IOException; {:try_start_391 .. :try_end_3bd} :catch_46c
    .catch Ljava/lang/RuntimeException; {:try_start_391 .. :try_end_3bd} :catch_46a

    move-object/from16 v22, v15

    :try_start_3bf
    new-instance v15, Lcom/google/android/gms/internal/ads/zzbcw;
    :try_end_3c1
    .catch Ljava/io/IOException; {:try_start_3bf .. :try_end_3c1} :catch_3e8
    .catch Ljava/lang/RuntimeException; {:try_start_3bf .. :try_end_3c1} :catch_3e6

    const/16 v23, 0x0

    move-object/from16 v24, v10

    move-object v10, v1

    move-object v1, v15

    move-object/from16 v25, v2

    move-object/from16 v2, p0

    move/from16 v26, v3

    move-object/from16 v3, p1

    move-object/from16 v27, v4

    move-object/from16 v4, v21

    move-object/from16 v21, v5

    move v5, v11

    move-object/from16 v19, v6

    const/16 v28, 0x3

    move v6, v7

    move/from16 v29, v7

    move/from16 v7, v23

    :try_start_3df
    invoke-direct/range {v1 .. v7}, Lcom/google/android/gms/internal/ads/zzbcw;-><init>(Lcom/google/android/gms/internal/ads/zzbcx;Ljava/lang/String;Ljava/lang/String;IIZ)V

    invoke-virtual {v10, v15}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    goto :goto_400

    :catch_3e6
    move-exception v0

    goto :goto_3e9

    :catch_3e8
    move-exception v0

    :goto_3e9
    move-object/from16 v27, v4

    move-object v1, v10

    goto/16 :goto_4f3

    :cond_3ee
    move-object/from16 v25, v2

    move/from16 v26, v3

    move-object/from16 v27, v4

    move-object/from16 v21, v5

    move-object/from16 v19, v6

    move/from16 v29, v7

    move-object/from16 v24, v10

    move-object/from16 v22, v15

    const/16 v28, 0x3

    :goto_400
    move-object/from16 v6, v19

    move-object/from16 v1, v20

    move-object/from16 v5, v21

    move-object/from16 v15, v22

    move-object/from16 v10, v24

    move-object/from16 v2, v25

    move/from16 v3, v26

    move-object/from16 v4, v27

    move/from16 v7, v29

    goto/16 :goto_354

    :cond_414
    move-object/from16 v27, v4

    move-object/from16 v24, v10

    move-object/from16 v22, v15

    const-string v15, "externalAbort"
    :try_end_41c
    .catch Ljava/io/IOException; {:try_start_3df .. :try_end_41c} :catch_4be
    .catch Ljava/lang/RuntimeException; {:try_start_3df .. :try_end_41c} :catch_4bc

    .line 100
    :try_start_41c
    new-instance v0, Ljava/io/IOException;

    const-string v1, "abort requested"

    invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V

    throw v0
    :try_end_424
    .catch Ljava/io/IOException; {:try_start_41c .. :try_end_424} :catch_464
    .catch Ljava/lang/RuntimeException; {:try_start_41c .. :try_end_424} :catch_462

    :cond_424
    move-object/from16 v27, v4

    move-object/from16 v24, v10

    move-object/from16 v22, v15

    :try_start_42a
    const-string v15, "downloadTimeout"
    :try_end_42c
    .catch Ljava/io/IOException; {:try_start_42a .. :try_end_42c} :catch_4be
    .catch Ljava/lang/RuntimeException; {:try_start_42a .. :try_end_42c} :catch_4bc

    .line 101
    :try_start_42c
    invoke-static {v13, v14}, 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 v10
    :try_end_450
    .catch Ljava/io/IOException; {:try_start_42c .. :try_end_450} :catch_464
    .catch Ljava/lang/RuntimeException; {:try_start_42c .. :try_end_450} :catch_462

    .line 102
    :try_start_450
    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_458
    .catch Ljava/io/IOException; {:try_start_450 .. :try_end_458} :catch_45a
    .catch Ljava/lang/RuntimeException; {:try_start_450 .. :try_end_458} :catch_458

    :catch_458
    move-exception v0

    goto :goto_45b

    :catch_45a
    move-exception v0

    :goto_45b
    move-object v2, v10

    move-object/from16 v1, v24

    move-object/from16 v10, v27

    goto/16 :goto_52d

    :catch_462
    move-exception v0

    goto :goto_4c1

    :catch_464
    move-exception v0

    goto :goto_4c1

    :cond_466
    const/16 v28, 0x3

    goto/16 :goto_394

    :catch_46a
    move-exception v0

    goto :goto_46d

    :catch_46c
    move-exception v0

    :goto_46d
    move-object/from16 v27, v4

    move-object/from16 v22, v15

    move-object v1, v10

    goto/16 :goto_505

    :cond_474
    move-object/from16 v27, v4

    move-object/from16 v24, v10

    move-object/from16 v22, v15

    const/16 v28, 0x3

    .line 103
    :try_start_47c
    invoke-virtual/range {v27 .. v27}, Ljava/io/FileOutputStream;->close()V

    .line 104
    invoke-static/range {v28 .. v28}, Lcom/google/android/gms/internal/ads/zzaza;->isLoggable(I)Z

    move-result v1
    :try_end_483
    .catch Ljava/io/IOException; {:try_start_47c .. :try_end_483} :catch_4f0
    .catch Ljava/lang/RuntimeException; {:try_start_47c .. :try_end_483} :catch_4ee

    if-eqz v1, :cond_4c4

    .line 105
    :try_start_485
    sget-object v1, Lcom/google/android/gms/internal/ads/zzbde;->zzeoq:Ljava/text/DecimalFormat;

    int-to-long v2, v11

    invoke-virtual {v1, v2, v3}, Ljava/text/DecimalFormat;->format(J)Ljava/lang/String;

    move-result-object v1

    .line 106
    invoke-static {v1}, 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, 0x16

    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 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, "Preloaded "

    invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v1, " bytes from "

    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;

    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v1

    invoke-static {v1}, Lcom/google/android/gms/internal/ads/zzaza;->zzeb(Ljava/lang/String;)V
    :try_end_4bb
    .catch Ljava/io/IOException; {:try_start_485 .. :try_end_4bb} :catch_4be
    .catch Ljava/lang/RuntimeException; {:try_start_485 .. :try_end_4bb} :catch_4bc

    goto :goto_4c4

    :catch_4bc
    move-exception v0

    goto :goto_4bf

    :catch_4be
    move-exception v0

    :goto_4bf
    move-object/from16 v15, v22

    :goto_4c1
    move-object/from16 v1, v24

    goto :goto_505

    :cond_4c4
    :goto_4c4
    const/4 v1, 0x1

    const/4 v2, 0x0

    .line 107
    :try_start_4c6
    invoke-virtual {v12, v1, v2}, Ljava/io/File;->setReadable(ZZ)Z

    .line 108
    invoke-virtual {v0}, Ljava/io/File;->isFile()Z

    move-result v1
    :try_end_4cd
    .catch Ljava/io/IOException; {:try_start_4c6 .. :try_end_4cd} :catch_4f0
    .catch Ljava/lang/RuntimeException; {:try_start_4c6 .. :try_end_4cd} :catch_4ee

    if-eqz v1, :cond_4d7

    .line 109
    :try_start_4cf
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v1

    invoke-virtual {v0, v1, v2}, Ljava/io/File;->setLastModified(J)Z
    :try_end_4d6
    .catch Ljava/io/IOException; {:try_start_4cf .. :try_end_4d6} :catch_4be
    .catch Ljava/lang/RuntimeException; {:try_start_4cf .. :try_end_4d6} :catch_4bc

    goto :goto_4da

    .line 110
    :cond_4d7
    :try_start_4d7
    invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z
    :try_end_4da
    .catch Ljava/io/IOException; {:try_start_4d7 .. :try_end_4da} :catch_4da
    .catch Ljava/lang/RuntimeException; {:try_start_4d7 .. :try_end_4da} :catch_4bc

    .line 111
    :catch_4da
    :goto_4da
    :try_start_4da
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v8, v9, v0, v11}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;I)V

    .line 112
    sget-object v0, Lcom/google/android/gms/internal/ads/zzbde;->zzeop:Ljava/util/Set;
    :try_end_4e3
    .catch Ljava/io/IOException; {:try_start_4da .. :try_end_4e3} :catch_4f0
    .catch Ljava/lang/RuntimeException; {:try_start_4da .. :try_end_4e3} :catch_4ee

    move-object/from16 v1, v24

    :try_start_4e5
    invoke-interface {v0, v1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
    :try_end_4e8
    .catch Ljava/io/IOException; {:try_start_4e5 .. :try_end_4e8} :catch_4ec
    .catch Ljava/lang/RuntimeException; {:try_start_4e5 .. :try_end_4e8} :catch_4ea

    const/4 v0, 0x1

    return v0

    :catch_4ea
    move-exception v0

    goto :goto_4f3

    :catch_4ec
    move-exception v0

    goto :goto_4f3

    :catch_4ee
    move-exception v0

    goto :goto_4f1

    :catch_4f0
    move-exception v0

    :goto_4f1
    move-object/from16 v1, v24

    :goto_4f3
    move-object/from16 v15, v22

    goto :goto_505

    :catch_4f6
    move-exception v0

    goto :goto_4f9

    :catch_4f8
    move-exception v0

    :goto_4f9
    move-object/from16 v27, v4

    move-object v1, v10

    goto :goto_503

    :catch_4fd
    move-exception v0

    goto :goto_500

    :catch_4ff
    move-exception v0

    :goto_500
    move-object/from16 v27, v4

    move-object v1, v14

    :goto_503
    move-object/from16 v22, v15

    :goto_505
    move-object/from16 v10, v27

    const/4 v2, 0x0

    goto :goto_52d

    :cond_509
    move-object v1, v14

    move-object/from16 v22, v15

    .line 113
    :try_start_50c
    new-instance v0, Ljava/io/IOException;

    const-string v2, "Invalid protocol."

    invoke-direct {v0, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V

    throw v0

    :cond_514
    move-object v1, v14

    move-object/from16 v22, v15

    .line 114
    new-instance v0, Ljava/io/IOException;

    const-string v2, "Too many redirects (20)"

    invoke-direct {v0, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V

    throw v0
    :try_end_51f
    .catch Ljava/io/IOException; {:try_start_50c .. :try_end_51f} :catch_521
    .catch Ljava/lang/RuntimeException; {:try_start_50c .. :try_end_51f} :catch_51f

    :catch_51f
    move-exception v0

    goto :goto_522

    :catch_521
    move-exception v0

    :goto_522
    move-object/from16 v15, v22

    goto :goto_52b

    :catch_525
    move-exception v0

    goto :goto_528

    :catch_527
    move-exception v0

    :goto_528
    move-object v1, v14

    move-object/from16 v22, v15

    :goto_52b
    const/4 v2, 0x0

    const/4 v10, 0x0

    .line 115
    :goto_52d
    instance-of v3, v0, Ljava/lang/RuntimeException;

    if-eqz v3, :cond_53a

    .line 116
    invoke-static {}, Lcom/google/android/gms/ads/internal/zzp;->zzku()Lcom/google/android/gms/internal/ads/zzayg;

    move-result-object v3

    const-string v4, "VideoStreamFullFileCache.preload"

    invoke-virtual {v3, v0, v4}, Lcom/google/android/gms/internal/ads/zzayg;->zza(Ljava/lang/Throwable;Ljava/lang/String;)V

    .line 117
    :cond_53a
    :try_start_53a
    invoke-virtual {v10}, Ljava/io/FileOutputStream;->close()V
    :try_end_53d
    .catch Ljava/io/IOException; {:try_start_53a .. :try_end_53d} :catch_53d
    .catch Ljava/lang/NullPointerException; {:try_start_53a .. :try_end_53d} :catch_53d

    .line 118
    :catch_53d
    iget-boolean v3, v8, Lcom/google/android/gms/internal/ads/zzbde;->zzeor:Z

    if-eqz v3, :cond_565

    .line 119
    invoke-static/range {p1 .. p1}, 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, 0x1a

    new-instance v3, Ljava/lang/StringBuilder;

    invoke-direct {v3, v0}, Ljava/lang/StringBuilder;-><init>(I)V

    const-string v0, "Preload aborted for URL \""

    invoke-virtual {v3, v0}, 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 v0, "\""

    invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzez(Ljava/lang/String;)V

    goto :goto_588

    .line 120
    :cond_565
    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 v3

    add-int/lit8 v3, v3, 0x19

    new-instance v4, Ljava/lang/StringBuilder;

    invoke-direct {v4, v3}, Ljava/lang/StringBuilder;-><init>(I)V

    const-string v3, "Preload failed for URL \""

    invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v4, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v3, "\""

    invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-static {v3, v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzd(Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 121
    :goto_588
    invoke-virtual {v12}, Ljava/io/File;->exists()Z

    move-result v0

    if-eqz v0, :cond_5b2

    invoke-virtual {v12}, Ljava/io/File;->delete()Z

    move-result v0

    if-nez v0, :cond_5b2

    const-string v0, "Could not delete partial cache file at "

    .line 122
    invoke-virtual {v12}, 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-virtual {v3}, Ljava/lang/String;->length()I

    move-result v4

    if-eqz v4, :cond_5a9

    invoke-virtual {v0, v3}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    goto :goto_5af

    :cond_5a9
    new-instance v3, Ljava/lang/String;

    invoke-direct {v3, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V

    move-object v0, v3

    :goto_5af
    invoke-static {v0}, Lcom/google/android/gms/internal/ads/zzaza;->zzfa(Ljava/lang/String;)V

    .line 123
    :cond_5b2
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v8, v9, v0, v15, v2}, Lcom/google/android/gms/internal/ads/zzbcx;->zza(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    .line 124
    sget-object v0, Lcom/google/android/gms/internal/ads/zzbde;->zzeop:Ljava/util/Set;

    invoke-interface {v0, v1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z

    const/4 v1, 0x0

    return v1

    :catchall_5c0
    move-exception v0

    .line 125
    :try_start_5c1
    monitor-exit v1
    :try_end_5c2
    .catchall {:try_start_5c1 .. :try_end_5c2} :catchall_5c0

    goto :goto_5c4

    :goto_5c3
    throw v0

    :goto_5c4
    goto :goto_5c3
.end method