DiskBasedCache.smali
.class public Lcom/mopub/volley/toolbox/DiskBasedCache;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/mopub/volley/Cache;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;,
Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
}
.end annotation
# static fields
.field private static final CACHE_MAGIC:I = 0x20150306
.field private static final DEFAULT_DISK_USAGE_BYTES:I = 0x500000
.field private static final HYSTERESIS_FACTOR:F = 0.9f
# instance fields
.field private final mEntries:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;",
">;"
}
.end annotation
.end field
.field private final mMaxCacheSizeInBytes:I
.field private final mRootDirectory:Ljava/io/File;
.field private mTotalSize:J
# direct methods
.method public constructor <init>(Ljava/io/File;)V
.registers 3
const/high16 v0, 0x500000
.line 91
invoke-direct {p0, p1, v0}, Lcom/mopub/volley/toolbox/DiskBasedCache;-><init>(Ljava/io/File;I)V
return-void
.end method
.method public constructor <init>(Ljava/io/File;I)V
.registers 7
.line 80
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 54
new-instance v0, Ljava/util/LinkedHashMap;
const/16 v1, 0x10
const/high16 v2, 0x3f400000 # 0.75f
const/4 v3, 0x1
invoke-direct {v0, v1, v2, v3}, Ljava/util/LinkedHashMap;-><init>(IFZ)V
iput-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
const-wide/16 v0, 0x0
.line 58
iput-wide v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
.line 81
iput-object p1, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mRootDirectory:Ljava/io/File;
.line 82
iput p2, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mMaxCacheSizeInBytes:I
return-void
.end method
.method private getFilenameForKey(Ljava/lang/String;)Ljava/lang/String;
.registers 5
.line 251
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v0
div-int/lit8 v0, v0, 0x2
const/4 v1, 0x0
.line 252
invoke-virtual {p1, v1, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->hashCode()I
move-result v1
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
.line 253
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, v0}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/String;->hashCode()I
move-result p1
invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private pruneIfNeeded(I)V
.registers 19
move-object/from16 v0, p0
.line 269
iget-wide v1, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
move/from16 v3, p1
int-to-long v3, v3
add-long/2addr v1, v3
iget v5, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mMaxCacheSizeInBytes:I
int-to-long v5, v5
cmp-long v7, v1, v5
if-gez v7, :cond_10
return-void
.line 272
:cond_10
sget-boolean v1, Lcom/mopub/volley/VolleyLog;->DEBUG:Z
const/4 v2, 0x0
if-eqz v1, :cond_1c
new-array v1, v2, [Ljava/lang/Object;
const-string v5, "Pruning old cache entries."
.line 273
invoke-static {v5, v1}, Lcom/mopub/volley/VolleyLog;->v(Ljava/lang/String;[Ljava/lang/Object;)V
.line 276
:cond_1c
iget-wide v5, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
.line 278
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v7
.line 280
iget-object v1, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v1
invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v1
const/4 v9, 0x0
.line 281
:goto_2d
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v10
const/4 v11, 0x2
const/4 v12, 0x1
if-eqz v10, :cond_84
.line 282
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v10
check-cast v10, Ljava/util/Map$Entry;
.line 283
invoke-interface {v10}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v10
check-cast v10, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
.line 284
iget-object v13, v10, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->key:Ljava/lang/String;
invoke-virtual {v0, v13}, Lcom/mopub/volley/toolbox/DiskBasedCache;->getFileForKey(Ljava/lang/String;)Ljava/io/File;
move-result-object v13
invoke-virtual {v13}, Ljava/io/File;->delete()Z
move-result v13
if-eqz v13, :cond_56
.line 286
iget-wide v13, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
move-wide v15, v3
iget-wide v2, v10, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->size:J
sub-long/2addr v13, v2
iput-wide v13, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
goto :goto_6b
:cond_56
move-wide v15, v3
new-array v2, v11, [Ljava/lang/Object;
.line 288
iget-object v3, v10, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->key:Ljava/lang/String;
const/4 v4, 0x0
aput-object v3, v2, v4
iget-object v3, v10, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->key:Ljava/lang/String;
.line 289
invoke-direct {v0, v3}, Lcom/mopub/volley/toolbox/DiskBasedCache;->getFilenameForKey(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
aput-object v3, v2, v12
const-string v3, "Could not delete cache entry for key=%s, filename=%s"
.line 288
invoke-static {v3, v2}, Lcom/mopub/volley/VolleyLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
.line 291
:goto_6b
invoke-interface {v1}, Ljava/util/Iterator;->remove()V
add-int/lit8 v9, v9, 0x1
.line 294
iget-wide v2, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
add-long/2addr v2, v15
long-to-float v2, v2
iget v3, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mMaxCacheSizeInBytes:I
int-to-float v3, v3
const v4, 0x3f666666 # 0.9f
mul-float v3, v3, v4
cmpg-float v2, v2, v3
if-gez v2, :cond_81
goto :goto_84
:cond_81
move-wide v3, v15
const/4 v2, 0x0
goto :goto_2d
.line 299
:cond_84
:goto_84
sget-boolean v1, Lcom/mopub/volley/VolleyLog;->DEBUG:Z
if-eqz v1, :cond_ab
const/4 v1, 0x3
new-array v1, v1, [Ljava/lang/Object;
.line 301
invoke-static {v9}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
const/4 v3, 0x0
aput-object v2, v1, v3
iget-wide v2, v0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
sub-long/2addr v2, v5
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
aput-object v2, v1, v12
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
sub-long/2addr v2, v7
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
aput-object v2, v1, v11
const-string v2, "pruned %d files, %d bytes, %d ms"
.line 300
invoke-static {v2, v1}, Lcom/mopub/volley/VolleyLog;->v(Ljava/lang/String;[Ljava/lang/Object;)V
:cond_ab
return-void
.end method
.method private putEntry(Ljava/lang/String;Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;)V
.registers 10
.line 311
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_10
.line 312
iget-wide v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
iget-wide v2, p2, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->size:J
add-long/2addr v0, v2
iput-wide v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
goto :goto_22
.line 314
:cond_10
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
.line 315
iget-wide v1, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
iget-wide v3, p2, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->size:J
iget-wide v5, v0, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->size:J
sub-long/2addr v3, v5
add-long/2addr v1, v3
iput-wide v1, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
.line 317
:goto_22
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
invoke-interface {v0, p1, p2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
return-void
.end method
.method private static read(Ljava/io/InputStream;)I
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 532
invoke-virtual {p0}, Ljava/io/InputStream;->read()I
move-result p0
const/4 v0, -0x1
if-eq p0, v0, :cond_8
return p0
.line 534
:cond_8
new-instance p0, Ljava/io/EOFException;
invoke-direct {p0}, Ljava/io/EOFException;-><init>()V
throw p0
.end method
.method static readHeaderList(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;)Ljava/util/List;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;",
")",
"Ljava/util/List<",
"Lcom/mopub/volley/Header;",
">;"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 604
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->readInt(Ljava/io/InputStream;)I
move-result v0
if-ltz v0, :cond_31
if-nez v0, :cond_d
.line 609
invoke-static {}, Ljava/util/Collections;->emptyList()Ljava/util/List;
move-result-object v1
goto :goto_12
:cond_d
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
:goto_12
const/4 v2, 0x0
:goto_13
if-ge v2, v0, :cond_30
.line 612
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->readString(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/String;->intern()Ljava/lang/String;
move-result-object v3
.line 613
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->readString(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;)Ljava/lang/String;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/String;->intern()Ljava/lang/String;
move-result-object v4
.line 614
new-instance v5, Lcom/mopub/volley/Header;
invoke-direct {v5, v3, v4}, Lcom/mopub/volley/Header;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-interface {v1, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
add-int/lit8 v2, v2, 0x1
goto :goto_13
:cond_30
return-object v1
.line 606
:cond_31
new-instance p0, Ljava/io/IOException;
invoke-static {v0}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v0
const-string v1, "readHeaderList size="
invoke-virtual {v1, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v0}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
goto :goto_42
:goto_41
throw p0
:goto_42
goto :goto_41
.end method
.method static readInt(Ljava/io/InputStream;)I
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 548
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v0
shl-int/lit8 v0, v0, 0x0
or-int/lit8 v0, v0, 0x0
.line 549
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v1
shl-int/lit8 v1, v1, 0x8
or-int/2addr v0, v1
.line 550
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v1
shl-int/lit8 v1, v1, 0x10
or-int/2addr v0, v1
.line 551
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result p0
shl-int/lit8 p0, p0, 0x18
or-int/2addr p0, v0
return p0
.end method
.method static readLong(Ljava/io/InputStream;)J
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 568
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v0
int-to-long v0, v0
const-wide/16 v2, 0xff
and-long/2addr v0, v2
const/4 v4, 0x0
shl-long/2addr v0, v4
const-wide/16 v4, 0x0
or-long/2addr v0, v4
.line 569
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v4
int-to-long v4, v4
and-long/2addr v4, v2
const/16 v6, 0x8
shl-long/2addr v4, v6
or-long/2addr v0, v4
.line 570
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v4
int-to-long v4, v4
and-long/2addr v4, v2
const/16 v6, 0x10
shl-long/2addr v4, v6
or-long/2addr v0, v4
.line 571
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v4
int-to-long v4, v4
and-long/2addr v4, v2
const/16 v6, 0x18
shl-long/2addr v4, v6
or-long/2addr v0, v4
.line 572
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v4
int-to-long v4, v4
and-long/2addr v4, v2
const/16 v6, 0x20
shl-long/2addr v4, v6
or-long/2addr v0, v4
.line 573
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v4
int-to-long v4, v4
and-long/2addr v4, v2
const/16 v6, 0x28
shl-long/2addr v4, v6
or-long/2addr v0, v4
.line 574
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result v4
int-to-long v4, v4
and-long/2addr v4, v2
const/16 v6, 0x30
shl-long/2addr v4, v6
or-long/2addr v0, v4
.line 575
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->read(Ljava/io/InputStream;)I
move-result p0
int-to-long v4, p0
and-long/2addr v2, v4
const/16 p0, 0x38
shl-long/2addr v2, p0
or-long/2addr v0, v2
return-wide v0
.end method
.method static readString(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;)Ljava/lang/String;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 586
invoke-static {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->readLong(Ljava/io/InputStream;)J
move-result-wide v0
.line 587
invoke-static {p0, v0, v1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->streamToBytes(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;J)[B
move-result-object p0
.line 588
new-instance v0, Ljava/lang/String;
const-string v1, "UTF-8"
invoke-direct {v0, p0, v1}, Ljava/lang/String;-><init>([BLjava/lang/String;)V
return-object v0
.end method
.method private removeEntry(Ljava/lang/String;)V
.registers 6
.line 324
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
if-eqz p1, :cond_11
.line 326
iget-wide v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
iget-wide v2, p1, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->size:J
sub-long/2addr v0, v2
iput-wide v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
:cond_11
return-void
.end method
.method static streamToBytes(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;J)[B
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 338
invoke-virtual {p0}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;->bytesRemaining()J
move-result-wide v0
const-wide/16 v2, 0x0
cmp-long v4, p1, v2
if-ltz v4, :cond_1f
cmp-long v2, p1, v0
if-gtz v2, :cond_1f
long-to-int v2, p1
int-to-long v3, v2
cmp-long v5, v3, p1
if-nez v5, :cond_1f
.line 343
new-array p1, v2, [B
.line 344
new-instance p2, Ljava/io/DataInputStream;
invoke-direct {p2, p0}, Ljava/io/DataInputStream;-><init>(Ljava/io/InputStream;)V
invoke-virtual {p2, p1}, Ljava/io/DataInputStream;->readFully([B)V
return-object p1
.line 341
:cond_1f
new-instance p0, Ljava/io/IOException;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "streamToBytes length="
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, p1, p2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string p1, ", maxLength="
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p0, p1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p0
.end method
.method static writeHeaderList(Ljava/util/List;Ljava/io/OutputStream;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Lcom/mopub/volley/Header;",
">;",
"Ljava/io/OutputStream;",
")V"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
if-eqz p0, :cond_29
.line 593
invoke-interface {p0}, Ljava/util/List;->size()I
move-result v0
invoke-static {p1, v0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->writeInt(Ljava/io/OutputStream;I)V
.line 594
invoke-interface {p0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p0
:goto_d
invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_28
invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/mopub/volley/Header;
.line 595
invoke-virtual {v0}, Lcom/mopub/volley/Header;->getName()Ljava/lang/String;
move-result-object v1
invoke-static {p1, v1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->writeString(Ljava/io/OutputStream;Ljava/lang/String;)V
.line 596
invoke-virtual {v0}, Lcom/mopub/volley/Header;->getValue()Ljava/lang/String;
move-result-object v0
invoke-static {p1, v0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->writeString(Ljava/io/OutputStream;Ljava/lang/String;)V
goto :goto_d
:cond_28
return-void
:cond_29
const/4 p0, 0x0
.line 599
invoke-static {p1, p0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->writeInt(Ljava/io/OutputStream;I)V
return-void
.end method
.method static writeInt(Ljava/io/OutputStream;I)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
shr-int/lit8 v0, p1, 0x0
and-int/lit16 v0, v0, 0xff
.line 540
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
shr-int/lit8 v0, p1, 0x8
and-int/lit16 v0, v0, 0xff
.line 541
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
shr-int/lit8 v0, p1, 0x10
and-int/lit16 v0, v0, 0xff
.line 542
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
shr-int/lit8 p1, p1, 0x18
and-int/lit16 p1, p1, 0xff
.line 543
invoke-virtual {p0, p1}, Ljava/io/OutputStream;->write(I)V
return-void
.end method
.method static writeLong(Ljava/io/OutputStream;J)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const/4 v0, 0x0
ushr-long v0, p1, v0
long-to-int v1, v0
int-to-byte v0, v1
.line 556
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
const/16 v0, 0x8
ushr-long v0, p1, v0
long-to-int v1, v0
int-to-byte v0, v1
.line 557
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
const/16 v0, 0x10
ushr-long v0, p1, v0
long-to-int v1, v0
int-to-byte v0, v1
.line 558
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
const/16 v0, 0x18
ushr-long v0, p1, v0
long-to-int v1, v0
int-to-byte v0, v1
.line 559
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
const/16 v0, 0x20
ushr-long v0, p1, v0
long-to-int v1, v0
int-to-byte v0, v1
.line 560
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
const/16 v0, 0x28
ushr-long v0, p1, v0
long-to-int v1, v0
int-to-byte v0, v1
.line 561
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
const/16 v0, 0x30
ushr-long v0, p1, v0
long-to-int v1, v0
int-to-byte v0, v1
.line 562
invoke-virtual {p0, v0}, Ljava/io/OutputStream;->write(I)V
const/16 v0, 0x38
ushr-long/2addr p1, v0
long-to-int p2, p1
int-to-byte p1, p2
.line 563
invoke-virtual {p0, p1}, Ljava/io/OutputStream;->write(I)V
return-void
.end method
.method static writeString(Ljava/io/OutputStream;Ljava/lang/String;)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const-string v0, "UTF-8"
.line 580
invoke-virtual {p1, v0}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object p1
.line 581
array-length v0, p1
int-to-long v0, v0
invoke-static {p0, v0, v1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->writeLong(Ljava/io/OutputStream;J)V
.line 582
array-length v0, p1
const/4 v1, 0x0
invoke-virtual {p0, p1, v1, v0}, Ljava/io/OutputStream;->write([BII)V
return-void
.end method
# virtual methods
.method public declared-synchronized clear()V
.registers 6
monitor-enter p0
.line 99
:try_start_1
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mRootDirectory:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v0
const/4 v1, 0x0
if-eqz v0, :cond_16
.line 101
array-length v2, v0
const/4 v3, 0x0
:goto_c
if-ge v3, v2, :cond_16
aget-object v4, v0, v3
.line 102
invoke-virtual {v4}, Ljava/io/File;->delete()Z
add-int/lit8 v3, v3, 0x1
goto :goto_c
.line 105
:cond_16
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->clear()V
const-wide/16 v2, 0x0
.line 106
iput-wide v2, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mTotalSize:J
const-string v0, "Cache cleared."
new-array v1, v1, [Ljava/lang/Object;
.line 107
invoke-static {v0, v1}, Lcom/mopub/volley/VolleyLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_26
.catchall {:try_start_1 .. :try_end_26} :catchall_28
.line 108
monitor-exit p0
return-void
:catchall_28
move-exception v0
monitor-exit p0
goto :goto_2c
:goto_2b
throw v0
:goto_2c
goto :goto_2b
.end method
.method createInputStream(Ljava/io/File;)Ljava/io/InputStream;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/FileNotFoundException;
}
.end annotation
.line 350
new-instance v0, Ljava/io/FileInputStream;
invoke-direct {v0, p1}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
return-object v0
.end method
.method createOutputStream(Ljava/io/File;)Ljava/io/OutputStream;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/FileNotFoundException;
}
.end annotation
.line 355
new-instance v0, Ljava/io/FileOutputStream;
invoke-direct {v0, p1}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
return-object v0
.end method
.method public declared-synchronized get(Ljava/lang/String;)Lcom/mopub/volley/Cache$Entry;
.registers 12
monitor-enter p0
.line 115
:try_start_1
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mEntries:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
:try_end_9
.catchall {:try_start_1 .. :try_end_9} :catchall_7e
const/4 v1, 0x0
if-nez v0, :cond_e
.line 118
monitor-exit p0
return-object v1
.line 120
:cond_e
:try_start_e
invoke-virtual {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->getFileForKey(Ljava/lang/String;)Ljava/io/File;
move-result-object v2
:try_end_12
.catchall {:try_start_e .. :try_end_12} :catchall_7e
const/4 v3, 0x1
const/4 v4, 0x0
const/4 v5, 0x2
.line 122
:try_start_15
new-instance v6, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;
new-instance v7, Ljava/io/BufferedInputStream;
.line 123
invoke-virtual {p0, v2}, Lcom/mopub/volley/toolbox/DiskBasedCache;->createInputStream(Ljava/io/File;)Ljava/io/InputStream;
move-result-object v8
invoke-direct {v7, v8}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;)V
invoke-virtual {v2}, Ljava/io/File;->length()J
move-result-wide v8
invoke-direct {v6, v7, v8, v9}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;-><init>(Ljava/io/InputStream;J)V
:try_end_27
.catch Ljava/io/IOException; {:try_start_15 .. :try_end_27} :catch_65
.catchall {:try_start_15 .. :try_end_27} :catchall_7e
.line 125
:try_start_27
invoke-static {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->readHeader(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;)Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
move-result-object v7
.line 126
iget-object v8, v7, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->key:Ljava/lang/String;
invoke-static {p1, v8}, Landroid/text/TextUtils;->equals(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Z
move-result v8
if-nez v8, :cond_4f
const-string v0, "%s: key=%s, found=%s"
const/4 v8, 0x3
new-array v8, v8, [Ljava/lang/Object;
.line 129
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v9
aput-object v9, v8, v4
aput-object p1, v8, v3
iget-object v7, v7, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->key:Ljava/lang/String;
aput-object v7, v8, v5
.line 128
invoke-static {v0, v8}, Lcom/mopub/volley/VolleyLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
.line 131
invoke-direct {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->removeEntry(Ljava/lang/String;)V
:try_end_4a
.catchall {:try_start_27 .. :try_end_4a} :catchall_60
.line 139
:try_start_4a
invoke-virtual {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;->close()V
:try_end_4d
.catch Ljava/io/IOException; {:try_start_4a .. :try_end_4d} :catch_65
.catchall {:try_start_4a .. :try_end_4d} :catchall_7e
.line 132
monitor-exit p0
return-object v1
.line 134
:cond_4f
:try_start_4f
invoke-virtual {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;->bytesRemaining()J
move-result-wide v7
invoke-static {v6, v7, v8}, Lcom/mopub/volley/toolbox/DiskBasedCache;->streamToBytes(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;J)[B
move-result-object v7
.line 135
invoke-virtual {v0, v7}, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->toCacheEntry([B)Lcom/mopub/volley/Cache$Entry;
move-result-object v0
:try_end_5b
.catchall {:try_start_4f .. :try_end_5b} :catchall_60
.line 139
:try_start_5b
invoke-virtual {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;->close()V
:try_end_5e
.catch Ljava/io/IOException; {:try_start_5b .. :try_end_5e} :catch_65
.catchall {:try_start_5b .. :try_end_5e} :catchall_7e
.line 135
monitor-exit p0
return-object v0
:catchall_60
move-exception v0
.line 139
:try_start_61
invoke-virtual {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;->close()V
throw v0
:try_end_65
.catch Ljava/io/IOException; {:try_start_61 .. :try_end_65} :catch_65
.catchall {:try_start_61 .. :try_end_65} :catchall_7e
:catch_65
move-exception v0
:try_start_66
const-string v6, "%s: %s"
new-array v5, v5, [Ljava/lang/Object;
.line 142
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v2
aput-object v2, v5, v4
invoke-virtual {v0}, Ljava/io/IOException;->toString()Ljava/lang/String;
move-result-object v0
aput-object v0, v5, v3
invoke-static {v6, v5}, Lcom/mopub/volley/VolleyLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
.line 143
invoke-virtual {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->remove(Ljava/lang/String;)V
:try_end_7c
.catchall {:try_start_66 .. :try_end_7c} :catchall_7e
.line 144
monitor-exit p0
return-object v1
:catchall_7e
move-exception p1
monitor-exit p0
throw p1
.end method
.method public getFileForKey(Ljava/lang/String;)Ljava/io/File;
.registers 4
.line 261
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mRootDirectory:Ljava/io/File;
invoke-direct {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->getFilenameForKey(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
.method public declared-synchronized initialize()V
.registers 10
monitor-enter p0
.line 154
:try_start_1
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mRootDirectory:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_24
.line 155
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mRootDirectory:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->mkdirs()Z
move-result v0
if-nez v0, :cond_22
const-string v0, "Unable to create cache dir %s"
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
.line 156
iget-object v3, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mRootDirectory:Ljava/io/File;
invoke-virtual {v3}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v3
aput-object v3, v2, v1
invoke-static {v0, v2}, Lcom/mopub/volley/VolleyLog;->e(Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_22
.catchall {:try_start_1 .. :try_end_22} :catchall_61
.line 158
:cond_22
monitor-exit p0
return-void
.line 160
:cond_24
:try_start_24
iget-object v0, p0, Lcom/mopub/volley/toolbox/DiskBasedCache;->mRootDirectory:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v0
:try_end_2a
.catchall {:try_start_24 .. :try_end_2a} :catchall_61
if-nez v0, :cond_2e
.line 162
monitor-exit p0
return-void
.line 164
:cond_2e
:try_start_2e
array-length v2, v0
:goto_2f
if-ge v1, v2, :cond_5f
aget-object v3, v0, v1
:try_end_33
.catchall {:try_start_2e .. :try_end_33} :catchall_61
.line 166
:try_start_33
invoke-virtual {v3}, Ljava/io/File;->length()J
move-result-wide v4
.line 167
new-instance v6, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;
new-instance v7, Ljava/io/BufferedInputStream;
.line 168
invoke-virtual {p0, v3}, Lcom/mopub/volley/toolbox/DiskBasedCache;->createInputStream(Ljava/io/File;)Ljava/io/InputStream;
move-result-object v8
invoke-direct {v7, v8}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;)V
invoke-direct {v6, v7, v4, v5}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;-><init>(Ljava/io/InputStream;J)V
:try_end_45
.catch Ljava/io/IOException; {:try_start_33 .. :try_end_45} :catch_59
.catchall {:try_start_33 .. :try_end_45} :catchall_61
.line 170
:try_start_45
invoke-static {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->readHeader(Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;)Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
move-result-object v7
.line 173
iput-wide v4, v7, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->size:J
.line 174
iget-object v4, v7, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->key:Ljava/lang/String;
invoke-direct {p0, v4, v7}, Lcom/mopub/volley/toolbox/DiskBasedCache;->putEntry(Ljava/lang/String;Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;)V
:try_end_50
.catchall {:try_start_45 .. :try_end_50} :catchall_54
.line 178
:try_start_50
invoke-virtual {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;->close()V
goto :goto_5c
:catchall_54
move-exception v4
invoke-virtual {v6}, Lcom/mopub/volley/toolbox/DiskBasedCache$CountingInputStream;->close()V
throw v4
:try_end_59
.catch Ljava/io/IOException; {:try_start_50 .. :try_end_59} :catch_59
.catchall {:try_start_50 .. :try_end_59} :catchall_61
.line 182
:catch_59
:try_start_59
invoke-virtual {v3}, Ljava/io/File;->delete()Z
:try_end_5c
.catchall {:try_start_59 .. :try_end_5c} :catchall_61
:goto_5c
add-int/lit8 v1, v1, 0x1
goto :goto_2f
.line 185
:cond_5f
monitor-exit p0
return-void
:catchall_61
move-exception v0
monitor-exit p0
goto :goto_65
:goto_64
throw v0
:goto_65
goto :goto_64
.end method
.method public declared-synchronized invalidate(Ljava/lang/String;Z)V
.registers 6
monitor-enter p0
.line 194
:try_start_1
invoke-virtual {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->get(Ljava/lang/String;)Lcom/mopub/volley/Cache$Entry;
move-result-object v0
if-eqz v0, :cond_12
const-wide/16 v1, 0x0
.line 196
iput-wide v1, v0, Lcom/mopub/volley/Cache$Entry;->softTtl:J
if-eqz p2, :cond_f
.line 198
iput-wide v1, v0, Lcom/mopub/volley/Cache$Entry;->ttl:J
.line 200
:cond_f
invoke-virtual {p0, p1, v0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->put(Ljava/lang/String;Lcom/mopub/volley/Cache$Entry;)V
:try_end_12
.catchall {:try_start_1 .. :try_end_12} :catchall_14
.line 202
:cond_12
monitor-exit p0
return-void
:catchall_14
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized put(Ljava/lang/String;Lcom/mopub/volley/Cache$Entry;)V
.registers 9
monitor-enter p0
.line 209
:try_start_1
iget-object v0, p2, Lcom/mopub/volley/Cache$Entry;->data:[B
array-length v0, v0
invoke-direct {p0, v0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->pruneIfNeeded(I)V
.line 210
invoke-virtual {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->getFileForKey(Ljava/lang/String;)Ljava/io/File;
move-result-object v0
:try_end_b
.catchall {:try_start_1 .. :try_end_b} :catchall_59
const/4 v1, 0x0
const/4 v2, 0x1
.line 212
:try_start_d
new-instance v3, Ljava/io/BufferedOutputStream;
invoke-virtual {p0, v0}, Lcom/mopub/volley/toolbox/DiskBasedCache;->createOutputStream(Ljava/io/File;)Ljava/io/OutputStream;
move-result-object v4
invoke-direct {v3, v4}, Ljava/io/BufferedOutputStream;-><init>(Ljava/io/OutputStream;)V
.line 213
new-instance v4, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;
invoke-direct {v4, p1, p2}, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;-><init>(Ljava/lang/String;Lcom/mopub/volley/Cache$Entry;)V
.line 214
invoke-virtual {v4, v3}, Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;->writeHeader(Ljava/io/OutputStream;)Z
move-result v5
if-eqz v5, :cond_2e
.line 220
iget-object p2, p2, Lcom/mopub/volley/Cache$Entry;->data:[B
invoke-virtual {v3, p2}, Ljava/io/BufferedOutputStream;->write([B)V
.line 221
invoke-virtual {v3}, Ljava/io/BufferedOutputStream;->close()V
.line 222
invoke-direct {p0, p1, v4}, Lcom/mopub/volley/toolbox/DiskBasedCache;->putEntry(Ljava/lang/String;Lcom/mopub/volley/toolbox/DiskBasedCache$CacheHeader;)V
:try_end_2c
.catch Ljava/io/IOException; {:try_start_d .. :try_end_2c} :catch_44
.catchall {:try_start_d .. :try_end_2c} :catchall_59
.line 223
monitor-exit p0
return-void
.line 216
:cond_2e
:try_start_2e
invoke-virtual {v3}, Ljava/io/BufferedOutputStream;->close()V
const-string p1, "Failed to write header for %s"
new-array p2, v2, [Ljava/lang/Object;
.line 217
invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v3
aput-object v3, p2, v1
invoke-static {p1, p2}, Lcom/mopub/volley/VolleyLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
.line 218
new-instance p1, Ljava/io/IOException;
invoke-direct {p1}, Ljava/io/IOException;-><init>()V
throw p1
:try_end_44
.catch Ljava/io/IOException; {:try_start_2e .. :try_end_44} :catch_44
.catchall {:try_start_2e .. :try_end_44} :catchall_59
.line 226
:catch_44
:try_start_44
invoke-virtual {v0}, Ljava/io/File;->delete()Z
move-result p1
if-nez p1, :cond_57
const-string p1, "Could not clean up file %s"
new-array p2, v2, [Ljava/lang/Object;
.line 228
invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
aput-object v0, p2, v1
invoke-static {p1, p2}, Lcom/mopub/volley/VolleyLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_57
.catchall {:try_start_44 .. :try_end_57} :catchall_59
.line 230
:cond_57
monitor-exit p0
return-void
:catchall_59
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized remove(Ljava/lang/String;)V
.registers 5
monitor-enter p0
.line 237
:try_start_1
invoke-virtual {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->getFileForKey(Ljava/lang/String;)Ljava/io/File;
move-result-object v0
invoke-virtual {v0}, Ljava/io/File;->delete()Z
move-result v0
.line 238
invoke-direct {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->removeEntry(Ljava/lang/String;)V
if-nez v0, :cond_20
const-string v0, "Could not delete cache entry for key=%s, filename=%s"
const/4 v1, 0x2
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
aput-object p1, v1, v2
const/4 v2, 0x1
.line 241
invoke-direct {p0, p1}, Lcom/mopub/volley/toolbox/DiskBasedCache;->getFilenameForKey(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
aput-object p1, v1, v2
.line 240
invoke-static {v0, v1}, Lcom/mopub/volley/VolleyLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_20
.catchall {:try_start_1 .. :try_end_20} :catchall_22
.line 243
:cond_20
monitor-exit p0
return-void
:catchall_22
move-exception p1
monitor-exit p0
throw p1
.end method