DiskStorageCache.smali
.class public Lcom/facebook/cache/disk/DiskStorageCache;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/facebook/cache/disk/FileCache;
.implements Lcom/facebook/common/disk/DiskTrimmable;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/facebook/cache/disk/DiskStorageCache$Params;,
Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
}
.end annotation
# static fields
.field private static final FILECACHE_SIZE_UPDATE_PERIOD_MS:J
.field private static final FUTURE_TIMESTAMP_THRESHOLD_MS:J
.field private static final SHARED_PREFS_FILENAME_PREFIX:Ljava/lang/String; = "disk_entries_list"
.field public static final START_OF_VERSIONING:I = 0x1
.field private static final TAG:Ljava/lang/Class;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/Class<",
"*>;"
}
.end annotation
.end field
.field private static final TRIMMING_LOWER_BOUND:D = 0.02
.field private static final UNINITIALIZED:J = -0x1L
# instance fields
.field private final mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
.field private final mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
.field private mCacheSizeLastUpdateTime:J
.field private mCacheSizeLimit:J
.field private final mCacheSizeLimitMinimum:J
.field private final mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
.field private final mClock:Lcom/facebook/common/time/Clock;
.field private final mCountDownLatch:Ljava/util/concurrent/CountDownLatch;
.field private final mDefaultCacheSizeLimit:J
.field private final mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
.field private final mIndexPopulateAtStartupEnabled:Z
.field private mIndexReady:Z
.field private final mLock:Ljava/lang/Object;
.field private final mLowDiskSpaceCacheSizeLimit:J
.field final mResourceIndex:Ljava/util/Set;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private final mStatFsHelper:Lcom/facebook/common/statfs/StatFsHelper;
.field private final mStorage:Lcom/facebook/cache/disk/DiskStorage;
# direct methods
.method static constructor <clinit>()V
.registers 3
.line 44
const-class v0, Lcom/facebook/cache/disk/DiskStorageCache;
sput-object v0, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
.line 51
sget-object v0, Ljava/util/concurrent/TimeUnit;->HOURS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v1, 0x2
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v0
sput-wide v0, Lcom/facebook/cache/disk/DiskStorageCache;->FUTURE_TIMESTAMP_THRESHOLD_MS:J
.line 53
sget-object v0, Ljava/util/concurrent/TimeUnit;->MINUTES:Ljava/util/concurrent/TimeUnit;
const-wide/16 v1, 0x1e
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v0
sput-wide v0, Lcom/facebook/cache/disk/DiskStorageCache;->FILECACHE_SIZE_UPDATE_PERIOD_MS:J
return-void
.end method
.method public constructor <init>(Lcom/facebook/cache/disk/DiskStorage;Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;Lcom/facebook/cache/disk/DiskStorageCache$Params;Lcom/facebook/cache/common/CacheEventListener;Lcom/facebook/cache/common/CacheErrorLogger;Lcom/facebook/common/disk/DiskTrimmableRegistry;Landroid/content/Context;Ljava/util/concurrent/Executor;Z)V
.registers 12
.line 156
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 85
new-instance p7, Ljava/lang/Object;
invoke-direct {p7}, Ljava/lang/Object;-><init>()V
iput-object p7, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
.line 157
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mLowDiskSpaceCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLowDiskSpaceCacheSizeLimit:J
.line 158
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mDefaultCacheSizeLimit:J
.line 159
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
.line 160
invoke-static {}, Lcom/facebook/common/statfs/StatFsHelper;->getInstance()Lcom/facebook/common/statfs/StatFsHelper;
move-result-object p7
iput-object p7, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStatFsHelper:Lcom/facebook/common/statfs/StatFsHelper;
.line 162
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
.line 164
iput-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
const-wide/16 p1, -0x1
.line 166
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
.line 168
iput-object p4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
.line 170
iget-wide p1, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mCacheSizeLimitMinimum:J
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimitMinimum:J
.line 172
iput-object p5, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
.line 174
new-instance p1, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-direct {p1}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;-><init>()V
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
.line 176
invoke-static {}, Lcom/facebook/common/time/SystemClock;->get()Lcom/facebook/common/time/SystemClock;
move-result-object p1
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mClock:Lcom/facebook/common/time/Clock;
.line 178
iput-boolean p9, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
.line 180
new-instance p1, Ljava/util/HashSet;
invoke-direct {p1}, Ljava/util/HashSet;-><init>()V
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
if-eqz p6, :cond_47
.line 183
invoke-interface {p6, p0}, Lcom/facebook/common/disk/DiskTrimmableRegistry;->registerDiskTrimmable(Lcom/facebook/common/disk/DiskTrimmable;)V
.line 186
:cond_47
iget-boolean p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz p1, :cond_5c
.line 187
new-instance p1, Ljava/util/concurrent/CountDownLatch;
const/4 p2, 0x1
invoke-direct {p1, p2}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCountDownLatch:Ljava/util/concurrent/CountDownLatch;
.line 189
new-instance p1, Lcom/facebook/cache/disk/DiskStorageCache$1;
invoke-direct {p1, p0}, Lcom/facebook/cache/disk/DiskStorageCache$1;-><init>(Lcom/facebook/cache/disk/DiskStorageCache;)V
invoke-interface {p8, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
return-void
.line 201
:cond_5c
new-instance p1, Ljava/util/concurrent/CountDownLatch;
const/4 p2, 0x0
invoke-direct {p1, p2}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCountDownLatch:Ljava/util/concurrent/CountDownLatch;
return-void
.end method
.method static synthetic access$000(Lcom/facebook/cache/disk/DiskStorageCache;)Ljava/lang/Object;
.registers 1
.line 42
iget-object p0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
return-object p0
.end method
.method static synthetic access$100(Lcom/facebook/cache/disk/DiskStorageCache;)Z
.registers 1
.line 42
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
move-result p0
return p0
.end method
.method static synthetic access$202(Lcom/facebook/cache/disk/DiskStorageCache;Z)Z
.registers 2
.line 42
iput-boolean p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexReady:Z
return p1
.end method
.method static synthetic access$300(Lcom/facebook/cache/disk/DiskStorageCache;)Ljava/util/concurrent/CountDownLatch;
.registers 1
.line 42
iget-object p0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCountDownLatch:Ljava/util/concurrent/CountDownLatch;
return-object p0
.end method
.method private endInsert(Lcom/facebook/cache/disk/DiskStorage$Inserter;Lcom/facebook/cache/common/CacheKey;Ljava/lang/String;)Lcom/facebook/binaryresource/BinaryResource;
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 340
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 341
:try_start_3
invoke-interface {p1, p2}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->commit(Ljava/lang/Object;)Lcom/facebook/binaryresource/BinaryResource;
move-result-object p1
.line 342
iget-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {p2, p3}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 343
iget-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-interface {p1}, Lcom/facebook/binaryresource/BinaryResource;->size()J
move-result-wide v1
const-wide/16 v3, 0x1
invoke-virtual {p2, v1, v2, v3, v4}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->increment(JJ)V
.line 344
monitor-exit v0
return-object p1
:catchall_19
move-exception p1
.line 345
monitor-exit v0
:try_end_1b
.catchall {:try_start_3 .. :try_end_1b} :catchall_19
throw p1
.end method
.method private evictAboveSize(JLcom/facebook/cache/common/CacheEventListener$EvictionReason;)V
.registers 21
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
move-object/from16 v1, p0
move-wide/from16 v2, p1
.line 496
:try_start_4
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0}, Lcom/facebook/cache/disk/DiskStorage;->getEntries()Ljava/util/Collection;
move-result-object v0
invoke-direct {v1, v0}, Lcom/facebook/cache/disk/DiskStorageCache;->getSortedEntries(Ljava/util/Collection;)Ljava/util/Collection;
move-result-object v0
:try_end_e
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_e} :catch_7f
.line 506
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v4}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v4
sub-long v6, v4, v2
const/4 v8, 0x0
.line 510
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
const-wide/16 v11, 0x0
:goto_1d
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v13
if-eqz v13, :cond_71
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v13
check-cast v13, Lcom/facebook/cache/disk/DiskStorage$Entry;
cmp-long v14, v11, v6
if-gtz v14, :cond_71
.line 514
iget-object v14, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v14, v13}, Lcom/facebook/cache/disk/DiskStorage;->remove(Lcom/facebook/cache/disk/DiskStorage$Entry;)J
move-result-wide v14
.line 515
iget-object v9, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v13}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v10
invoke-interface {v9, v10}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
const-wide/16 v9, 0x0
cmp-long v16, v14, v9
if-lez v16, :cond_6e
add-int/lit8 v8, v8, 0x1
add-long/2addr v11, v14
.line 519
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
.line 520
invoke-interface {v13}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v10
invoke-virtual {v9, v10}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
move-object/from16 v10, p3
.line 521
invoke-virtual {v9, v10}, Lcom/facebook/cache/disk/SettableCacheEvent;->setEvictionReason(Lcom/facebook/cache/common/CacheEventListener$EvictionReason;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
.line 522
invoke-virtual {v9, v14, v15}, Lcom/facebook/cache/disk/SettableCacheEvent;->setItemSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
sub-long v13, v4, v11
.line 523
invoke-virtual {v9, v13, v14}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
.line 524
invoke-virtual {v9, v2, v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheLimit(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
.line 525
iget-object v13, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {v13, v9}, Lcom/facebook/cache/common/CacheEventListener;->onEviction(Lcom/facebook/cache/common/CacheEvent;)V
.line 526
invoke-virtual {v9}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_1d
:cond_6e
move-object/from16 v10, p3
goto :goto_1d
.line 529
:cond_71
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
neg-long v2, v11
neg-int v4, v8
int-to-long v4, v4
invoke-virtual {v0, v2, v3, v4, v5}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->increment(JJ)V
.line 530
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0}, Lcom/facebook/cache/disk/DiskStorage;->purgeUnexpectedResources()V
return-void
:catch_7f
move-exception v0
.line 498
iget-object v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v3, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->EVICTION:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v4, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
new-instance v5, Ljava/lang/StringBuilder;
const-string v6, "evictAboveSize: "
invoke-direct {v5, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 501
invoke-virtual {v0}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
.line 498
invoke-interface {v2, v3, v4, v5, v0}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 503
goto :goto_9d
:goto_9c
throw v0
:goto_9d
goto :goto_9c
.end method
.method private getSortedEntries(Ljava/util/Collection;)Ljava/util/Collection;
.registers 10
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Collection<",
"Lcom/facebook/cache/disk/DiskStorage$Entry;",
">;)",
"Ljava/util/Collection<",
"Lcom/facebook/cache/disk/DiskStorage$Entry;",
">;"
}
.end annotation
.line 542
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mClock:Lcom/facebook/common/time/Clock;
invoke-interface {v0}, Lcom/facebook/common/time/Clock;->now()J
move-result-wide v0
sget-wide v2, Lcom/facebook/cache/disk/DiskStorageCache;->FUTURE_TIMESTAMP_THRESHOLD_MS:J
add-long/2addr v0, v2
.line 543
new-instance v2, Ljava/util/ArrayList;
invoke-interface {p1}, Ljava/util/Collection;->size()I
move-result v3
invoke-direct {v2, v3}, Ljava/util/ArrayList;-><init>(I)V
.line 544
new-instance v3, Ljava/util/ArrayList;
invoke-interface {p1}, Ljava/util/Collection;->size()I
move-result v4
invoke-direct {v3, v4}, Ljava/util/ArrayList;-><init>(I)V
.line 545
invoke-interface {p1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_1f
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_3b
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/facebook/cache/disk/DiskStorage$Entry;
.line 546
invoke-interface {v4}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v5
cmp-long v7, v5, v0
if-lez v7, :cond_37
.line 547
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
.line 549
:cond_37
invoke-virtual {v3, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
.line 552
:cond_3b
iget-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
invoke-interface {p1}, Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;->get()Lcom/facebook/cache/disk/EntryEvictionComparator;
move-result-object p1
invoke-static {v3, p1}, Ljava/util/Collections;->sort(Ljava/util/List;Ljava/util/Comparator;)V
.line 553
invoke-virtual {v2, v3}, Ljava/util/ArrayList;->addAll(Ljava/util/Collection;)Z
return-object v2
.end method
.method private maybeEvictFilesInCacheDir()V
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 467
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 468
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
move-result v1
.line 471
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->updateFileCacheSizeLimit()V
.line 473
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v2}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v2
.line 476
iget-wide v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
cmp-long v6, v2, v4
if-lez v6, :cond_20
if-nez v1, :cond_20
.line 477
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v1}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->reset()V
.line 478
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 482
:cond_20
iget-wide v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
cmp-long v1, v2, v4
if-lez v1, :cond_34
.line 483
iget-wide v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
const-wide/16 v3, 0x9
mul-long v1, v1, v3
const-wide/16 v3, 0xa
div-long/2addr v1, v3
sget-object v3, Lcom/facebook/cache/common/CacheEventListener$EvictionReason;->CACHE_FULL:Lcom/facebook/cache/common/CacheEventListener$EvictionReason;
invoke-direct {p0, v1, v2, v3}, Lcom/facebook/cache/disk/DiskStorageCache;->evictAboveSize(JLcom/facebook/cache/common/CacheEventListener$EvictionReason;)V
.line 487
:cond_34
monitor-exit v0
return-void
:catchall_36
move-exception v1
monitor-exit v0
:try_end_38
.catchall {:try_start_3 .. :try_end_38} :catchall_36
throw v1
.end method
.method private maybeUpdateFileCacheSize()Z
.registers 8
.line 688
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mClock:Lcom/facebook/common/time/Clock;
invoke-interface {v0}, Lcom/facebook/common/time/Clock;->now()J
move-result-wide v0
.line 689
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v2}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->isInitialized()Z
move-result v2
if-eqz v2, :cond_20
iget-wide v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
const-wide/16 v4, -0x1
cmp-long v6, v2, v4
if-eqz v6, :cond_20
sub-long/2addr v0, v2
sget-wide v2, Lcom/facebook/cache/disk/DiskStorageCache;->FILECACHE_SIZE_UPDATE_PERIOD_MS:J
cmp-long v4, v0, v2
if-lez v4, :cond_1e
goto :goto_20
:cond_1e
const/4 v0, 0x0
return v0
.line 692
:cond_20
:goto_20
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSizeAndIndex()Z
move-result v0
return v0
.end method
.method private maybeUpdateFileCacheSizeAndIndex()Z
.registers 21
move-object/from16 v1, p0
.line 705
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mClock:Lcom/facebook/common/time/Clock;
invoke-interface {v0}, Lcom/facebook/common/time/Clock;->now()J
move-result-wide v2
.line 706
sget-wide v4, Lcom/facebook/cache/disk/DiskStorageCache;->FUTURE_TIMESTAMP_THRESHOLD_MS:J
add-long/2addr v4, v2
.line 708
iget-boolean v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v0, :cond_1a
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v0}, Ljava/util/Set;->isEmpty()Z
move-result v0
if-eqz v0, :cond_1a
.line 709
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
goto :goto_25
.line 710
:cond_1a
iget-boolean v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v0, :cond_24
.line 711
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
goto :goto_25
:cond_24
const/4 v0, 0x0
.line 716
:goto_25
:try_start_25
iget-object v8, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v8}, Lcom/facebook/cache/disk/DiskStorage;->getEntries()Ljava/util/Collection;
move-result-object v8
.line 717
invoke-interface {v8}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v8
const-wide/16 v10, 0x0
const-wide/16 v12, -0x1
const/4 v7, 0x0
const/4 v9, 0x0
const/4 v14, 0x0
const/4 v15, 0x0
:cond_37
:goto_37
invoke-interface {v8}, Ljava/util/Iterator;->hasNext()Z
move-result v16
if-eqz v16, :cond_76
invoke-interface {v8}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v16
check-cast v16, Lcom/facebook/cache/disk/DiskStorage$Entry;
add-int/lit8 v15, v15, 0x1
.line 719
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getSize()J
move-result-wide v17
add-long v10, v10, v17
.line 722
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v17
cmp-long v19, v17, v4
if-lez v19, :cond_6a
add-int/lit8 v7, v7, 0x1
move v14, v7
int-to-long v6, v9
.line 725
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getSize()J
move-result-wide v18
add-long v6, v6, v18
long-to-int v9, v6
.line 726
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v6
sub-long/2addr v6, v2
invoke-static {v6, v7, v12, v13}, Ljava/lang/Math;->max(JJ)J
move-result-wide v12
move v7, v14
const/4 v14, 0x1
goto :goto_37
.line 727
:cond_6a
iget-boolean v6, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v6, :cond_37
.line 728
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v6
invoke-interface {v0, v6}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
goto :goto_37
:cond_76
if-eqz v14, :cond_a5
.line 732
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v5, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->READ_INVALID_ENTRY:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v6, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
new-instance v8, Ljava/lang/StringBuilder;
const-string v14, "Future timestamp found in "
invoke-direct {v8, v14}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v7, " files , with a total size of "
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v7, " bytes, and a maximum time delta of "
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v12, v13}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v7, "ms"
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
const/4 v8, 0x0
invoke-interface {v4, v5, v6, v7, v8}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 740
:cond_a5
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v4}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getCount()J
move-result-wide v4
int-to-long v6, v15
cmp-long v8, v4, v6
if-nez v8, :cond_ba
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v4}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v4
cmp-long v8, v4, v10
if-eqz v8, :cond_d1
.line 741
:cond_ba
iget-boolean v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v4, :cond_cc
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
if-eq v4, v0, :cond_cc
.line 742
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v4}, Ljava/util/Set;->clear()V
.line 743
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v4, v0}, Ljava/util/Set;->addAll(Ljava/util/Collection;)Z
.line 745
:cond_cc
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v0, v10, v11, v6, v7}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->set(JJ)V
:try_end_d1
.catch Ljava/io/IOException; {:try_start_25 .. :try_end_d1} :catch_d5
.line 755
:cond_d1
iput-wide v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
const/4 v0, 0x1
return v0
:catch_d5
move-exception v0
.line 748
iget-object v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v3, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->GENERIC_IO:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v4, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
new-instance v5, Ljava/lang/StringBuilder;
const-string v6, "calcFileCacheSize: "
invoke-direct {v5, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 751
invoke-virtual {v0}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
.line 748
invoke-interface {v2, v3, v4, v5, v0}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
const/4 v2, 0x0
return v2
.end method
.method private startInsert(Ljava/lang/String;Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/DiskStorage$Inserter;
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 328
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeEvictFilesInCacheDir()V
.line 329
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0, p1, p2}, Lcom/facebook/cache/disk/DiskStorage;->insert(Ljava/lang/String;Ljava/lang/Object;)Lcom/facebook/cache/disk/DiskStorage$Inserter;
move-result-object p1
return-object p1
.end method
.method private trimBy(D)V
.registers 8
.line 661
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 664
:try_start_3
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v1}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->reset()V
.line 665
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 666
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v1}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v1
:try_end_11
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_11} :catch_21
.catchall {:try_start_3 .. :try_end_11} :catchall_1f
long-to-double v3, v1
.line 667
invoke-static {v3, v4}, Ljava/lang/Double;->isNaN(D)Z
mul-double p1, p1, v3
double-to-long p1, p1
sub-long/2addr v1, p1
.line 668
:try_start_19
sget-object p1, Lcom/facebook/cache/common/CacheEventListener$EvictionReason;->CACHE_MANAGER_TRIMMED:Lcom/facebook/cache/common/CacheEventListener$EvictionReason;
invoke-direct {p0, v1, v2, p1}, Lcom/facebook/cache/disk/DiskStorageCache;->evictAboveSize(JLcom/facebook/cache/common/CacheEventListener$EvictionReason;)V
:try_end_1e
.catch Ljava/io/IOException; {:try_start_19 .. :try_end_1e} :catch_21
.catchall {:try_start_19 .. :try_end_1e} :catchall_1f
goto :goto_3d
:catchall_1f
move-exception p1
goto :goto_3f
:catch_21
move-exception p1
.line 672
:try_start_22
iget-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v1, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->EVICTION:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v2, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "trimBy: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 675
invoke-virtual {p1}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
.line 672
invoke-interface {p2, v1, v2, v3, p1}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 678
:goto_3d
monitor-exit v0
return-void
:goto_3f
monitor-exit v0
:try_end_40
.catchall {:try_start_22 .. :try_end_40} :catchall_1f
throw p1
.end method
.method private updateFileCacheSizeLimit()V
.registers 7
.line 565
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
.line 566
invoke-interface {v0}, Lcom/facebook/cache/disk/DiskStorage;->isExternal()Z
move-result v0
if-eqz v0, :cond_b
sget-object v0, Lcom/facebook/common/statfs/StatFsHelper$StorageType;->EXTERNAL:Lcom/facebook/common/statfs/StatFsHelper$StorageType;
goto :goto_d
:cond_b
sget-object v0, Lcom/facebook/common/statfs/StatFsHelper$StorageType;->INTERNAL:Lcom/facebook/common/statfs/StatFsHelper$StorageType;
.line 569
:goto_d
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStatFsHelper:Lcom/facebook/common/statfs/StatFsHelper;
iget-wide v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mDefaultCacheSizeLimit:J
iget-object v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
.line 572
invoke-virtual {v4}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v4
sub-long/2addr v2, v4
.line 570
invoke-virtual {v1, v0, v2, v3}, Lcom/facebook/common/statfs/StatFsHelper;->testLowDiskSpace(Lcom/facebook/common/statfs/StatFsHelper$StorageType;J)Z
move-result v0
if-eqz v0, :cond_23
.line 574
iget-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLowDiskSpaceCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
return-void
.line 576
:cond_23
iget-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
return-void
.end method
# virtual methods
.method protected awaitIndex()V
.registers 3
.line 222
:try_start_0
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCountDownLatch:Ljava/util/concurrent/CountDownLatch;
invoke-virtual {v0}, Ljava/util/concurrent/CountDownLatch;->await()V
:try_end_5
.catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_5} :catch_6
return-void
.line 224
:catch_6
sget-object v0, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
const-string v1, "Memory Index is not ready yet. "
invoke-static {v0, v1}, Lcom/facebook/common/logging/FLog;->e(Ljava/lang/Class;Ljava/lang/String;)V
return-void
.end method
.method public clearAll()V
.registers 8
.line 589
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 591
:try_start_3
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage;->clearAll()V
.line 592
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v1}, Ljava/util/Set;->clear()V
.line 593
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {v1}, Lcom/facebook/cache/common/CacheEventListener;->onCleared()V
:try_end_12
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_12} :catch_17
.catch Ljava/lang/NullPointerException; {:try_start_3 .. :try_end_12} :catch_15
.catchall {:try_start_3 .. :try_end_12} :catchall_13
goto :goto_33
:catchall_13
move-exception v1
goto :goto_3a
:catch_15
move-exception v1
goto :goto_18
:catch_17
move-exception v1
.line 595
:goto_18
:try_start_18
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v3, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->EVICTION:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v4, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
new-instance v5, Ljava/lang/StringBuilder;
const-string v6, "clearAll: "
invoke-direct {v5, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 596
invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
.line 595
invoke-interface {v2, v3, v4, v5, v1}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 598
:goto_33
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v1}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->reset()V
.line 599
monitor-exit v0
return-void
:goto_3a
monitor-exit v0
:try_end_3b
.catchall {:try_start_18 .. :try_end_3b} :catchall_13
throw v1
.end method
.method public clearOldEntries(J)J
.registers 23
move-object/from16 v1, p0
.line 416
iget-object v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v2
.line 418
:try_start_5
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mClock:Lcom/facebook/common/time/Clock;
invoke-interface {v0}, Lcom/facebook/common/time/Clock;->now()J
move-result-wide v5
.line 419
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0}, Lcom/facebook/cache/disk/DiskStorage;->getEntries()Ljava/util/Collection;
move-result-object v0
.line 420
iget-object v7, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v7}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v7
const/4 v9, 0x0
.line 423
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
:try_end_1c
.catch Ljava/io/IOException; {:try_start_5 .. :try_end_1c} :catch_a0
.catchall {:try_start_5 .. :try_end_1c} :catchall_9e
const-wide/16 v10, 0x0
const-wide/16 v12, 0x0
:goto_20
:try_start_20
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v14
if-eqz v14, :cond_88
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v14
check-cast v14, Lcom/facebook/cache/disk/DiskStorage$Entry;
const-wide/16 v3, 0x1
.line 425
invoke-interface {v14}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v16
sub-long v16, v5, v16
move-wide/from16 v18, v5
invoke-static/range {v16 .. v17}, Ljava/lang/Math;->abs(J)J
move-result-wide v5
invoke-static {v3, v4, v5, v6}, Ljava/lang/Math;->max(JJ)J
move-result-wide v3
cmp-long v5, v3, p1
if-ltz v5, :cond_7f
.line 427
iget-object v3, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v3, v14}, Lcom/facebook/cache/disk/DiskStorage;->remove(Lcom/facebook/cache/disk/DiskStorage$Entry;)J
move-result-wide v3
.line 428
iget-object v5, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v14}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v6
invoke-interface {v5, v6}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
const-wide/16 v5, 0x0
cmp-long v15, v3, v5
if-lez v15, :cond_85
add-int/lit8 v9, v9, 0x1
add-long/2addr v10, v3
.line 432
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v15
.line 433
invoke-interface {v14}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v14
invoke-virtual {v15, v14}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v14
sget-object v15, Lcom/facebook/cache/common/CacheEventListener$EvictionReason;->CONTENT_STALE:Lcom/facebook/cache/common/CacheEventListener$EvictionReason;
.line 434
invoke-virtual {v14, v15}, Lcom/facebook/cache/disk/SettableCacheEvent;->setEvictionReason(Lcom/facebook/cache/common/CacheEventListener$EvictionReason;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v14
.line 435
invoke-virtual {v14, v3, v4}, Lcom/facebook/cache/disk/SettableCacheEvent;->setItemSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v3
sub-long v14, v7, v10
.line 436
invoke-virtual {v3, v14, v15}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v3
.line 437
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {v4, v3}, Lcom/facebook/cache/common/CacheEventListener;->onEviction(Lcom/facebook/cache/common/CacheEvent;)V
.line 438
invoke-virtual {v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_85
:cond_7f
const-wide/16 v5, 0x0
.line 441
invoke-static {v12, v13, v3, v4}, Ljava/lang/Math;->max(JJ)J
move-result-wide v12
:cond_85
:goto_85
move-wide/from16 v5, v18
goto :goto_20
.line 444
:cond_88
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0}, Lcom/facebook/cache/disk/DiskStorage;->purgeUnexpectedResources()V
if-lez v9, :cond_c0
.line 446
invoke-direct/range {p0 .. p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 447
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
neg-long v3, v10
neg-int v5, v9
int-to-long v5, v5
invoke-virtual {v0, v3, v4, v5, v6}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->increment(JJ)V
:try_end_9a
.catch Ljava/io/IOException; {:try_start_20 .. :try_end_9a} :catch_9b
.catchall {:try_start_20 .. :try_end_9a} :catchall_9e
goto :goto_c0
:catch_9b
move-exception v0
move-wide v3, v12
goto :goto_a4
:catchall_9e
move-exception v0
goto :goto_c2
:catch_a0
move-exception v0
const-wide/16 v5, 0x0
move-wide v3, v5
.line 450
:goto_a4
:try_start_a4
iget-object v5, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v6, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->EVICTION:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v7, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
new-instance v8, Ljava/lang/StringBuilder;
const-string v9, "clearOldEntries: "
invoke-direct {v8, v9}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 453
invoke-virtual {v0}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object v9
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
.line 450
invoke-interface {v5, v6, v7, v8, v0}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
move-wide v12, v3
.line 456
:cond_c0
:goto_c0
monitor-exit v2
return-wide v12
:goto_c2
monitor-exit v2
:try_end_c3
.catchall {:try_start_a4 .. :try_end_c3} :catchall_9e
goto :goto_c5
:goto_c4
throw v0
:goto_c5
goto :goto_c4
.end method
.method public getCount()J
.registers 3
.line 585
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v0}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getCount()J
move-result-wide v0
return-wide v0
.end method
.method public getDumpInfo()Lcom/facebook/cache/disk/DiskStorage$DiskDumpInfo;
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 207
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0}, Lcom/facebook/cache/disk/DiskStorage;->getDumpInfo()Lcom/facebook/cache/disk/DiskStorage$DiskDumpInfo;
move-result-object v0
return-object v0
.end method
.method public getResource(Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/binaryresource/BinaryResource;
.registers 10
.line 248
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
.line 249
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheKey(Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
const/4 v1, 0x0
.line 251
:try_start_9
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v2
:try_end_c
.catch Ljava/io/IOException; {:try_start_9 .. :try_end_c} :catch_4e
.catchall {:try_start_9 .. :try_end_c} :catchall_4c
.line 253
:try_start_c
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object v3
const/4 v4, 0x0
move-object v5, v1
move-object v6, v5
.line 254
:goto_13
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v7
if-ge v4, v7, :cond_2d
.line 255
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
.line 256
invoke-virtual {v0, v5}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 257
iget-object v6, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v6, v5, p1}, Lcom/facebook/cache/disk/DiskStorage;->getResource(Ljava/lang/String;Ljava/lang/Object;)Lcom/facebook/binaryresource/BinaryResource;
move-result-object v6
if-nez v6, :cond_2d
add-int/lit8 v4, v4, 0x1
goto :goto_13
:cond_2d
if-nez v6, :cond_3a
.line 263
iget-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {p1, v0}, Lcom/facebook/cache/common/CacheEventListener;->onMiss(Lcom/facebook/cache/common/CacheEvent;)V
.line 264
iget-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {p1, v5}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
goto :goto_44
.line 266
:cond_3a
iget-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {p1, v0}, Lcom/facebook/cache/common/CacheEventListener;->onHit(Lcom/facebook/cache/common/CacheEvent;)V
.line 267
iget-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {p1, v5}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 269
:goto_44
monitor-exit v2
:try_end_45
.catchall {:try_start_c .. :try_end_45} :catchall_49
.line 281
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object v6
:catchall_49
move-exception p1
.line 270
:try_start_4a
monitor-exit v2
:try_end_4b
.catchall {:try_start_4a .. :try_end_4b} :catchall_49
:try_start_4b
throw p1
:try_end_4c
.catch Ljava/io/IOException; {:try_start_4b .. :try_end_4c} :catch_4e
.catchall {:try_start_4b .. :try_end_4c} :catchall_4c
:catchall_4c
move-exception p1
goto :goto_66
:catch_4e
move-exception p1
.line 272
:try_start_4f
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v3, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->GENERIC_IO:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v4, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
const-string v5, "getResource"
invoke-interface {v2, v3, v4, v5, p1}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 277
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 278
iget-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {p1, v0}, Lcom/facebook/cache/common/CacheEventListener;->onReadException(Lcom/facebook/cache/common/CacheEvent;)V
:try_end_62
.catchall {:try_start_4f .. :try_end_62} :catchall_4c
.line 281
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object v1
:goto_66
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_6b
:goto_6a
throw p1
:goto_6b
goto :goto_6a
.end method
.method public getSize()J
.registers 3
.line 581
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v0}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v0
return-wide v0
.end method
.method public hasKey(Lcom/facebook/cache/common/CacheKey;)Z
.registers 9
.line 619
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 620
:try_start_3
invoke-virtual {p0, p1}, Lcom/facebook/cache/disk/DiskStorageCache;->hasKeySync(Lcom/facebook/cache/common/CacheKey;)Z
move-result v1
const/4 v2, 0x1
if-eqz v1, :cond_c
.line 621
monitor-exit v0
:try_end_b
.catchall {:try_start_3 .. :try_end_b} :catchall_34
return v2
:cond_c
const/4 v1, 0x0
.line 625
:try_start_d
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object v3
const/4 v4, 0x0
.line 626
:goto_12
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_30
.line 627
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
.line 628
iget-object v6, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v6, v5, p1}, Lcom/facebook/cache/disk/DiskStorage;->contains(Ljava/lang/String;Ljava/lang/Object;)Z
move-result v6
if-eqz v6, :cond_2d
.line 629
iget-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {p1, v5}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_2b
.catch Ljava/io/IOException; {:try_start_d .. :try_end_2b} :catch_32
.catchall {:try_start_d .. :try_end_2b} :catchall_34
.line 630
:try_start_2b
monitor-exit v0
return v2
:cond_2d
add-int/lit8 v4, v4, 0x1
goto :goto_12
.line 633
:cond_30
monitor-exit v0
return v1
.line 635
:catch_32
monitor-exit v0
return v1
:catchall_34
move-exception p1
.line 637
monitor-exit v0
:try_end_36
.catchall {:try_start_2b .. :try_end_36} :catchall_34
goto :goto_38
:goto_37
throw p1
:goto_38
goto :goto_37
.end method
.method public hasKeySync(Lcom/facebook/cache/common/CacheKey;)Z
.registers 7
.line 604
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 606
:try_start_3
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object p1
const/4 v1, 0x0
const/4 v2, 0x0
.line 607
:goto_9
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v3
if-ge v2, v3, :cond_23
.line 608
invoke-interface {p1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
.line 609
iget-object v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v4, v3}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v3
if-eqz v3, :cond_20
.line 610
monitor-exit v0
const/4 p1, 0x1
return p1
:cond_20
add-int/lit8 v2, v2, 0x1
goto :goto_9
.line 613
:cond_23
monitor-exit v0
return v1
:catchall_25
move-exception p1
.line 614
monitor-exit v0
:try_end_27
.catchall {:try_start_3 .. :try_end_27} :catchall_25
goto :goto_29
:goto_28
throw p1
:goto_29
goto :goto_28
.end method
.method public insert(Lcom/facebook/cache/common/CacheKey;Lcom/facebook/cache/common/WriterCallback;)Lcom/facebook/binaryresource/BinaryResource;
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 352
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
.line 353
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheKey(Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
.line 354
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {v1, v0}, Lcom/facebook/cache/common/CacheEventListener;->onWriteAttempt(Lcom/facebook/cache/common/CacheEvent;)V
.line 356
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v1
.line 358
:try_start_10
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getFirstResourceId(Lcom/facebook/cache/common/CacheKey;)Ljava/lang/String;
move-result-object v2
.line 359
monitor-exit v1
:try_end_15
.catchall {:try_start_10 .. :try_end_15} :catchall_70
.line 360
invoke-virtual {v0, v2}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 363
:try_start_18
invoke-direct {p0, v2, p1}, Lcom/facebook/cache/disk/DiskStorageCache;->startInsert(Ljava/lang/String;Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/DiskStorage$Inserter;
move-result-object v1
:try_end_1c
.catch Ljava/io/IOException; {:try_start_18 .. :try_end_1c} :catch_5b
.catchall {:try_start_18 .. :try_end_1c} :catchall_59
.line 365
:try_start_1c
invoke-interface {v1, p2, p1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->writeData(Lcom/facebook/cache/common/WriterCallback;Ljava/lang/Object;)V
.line 367
invoke-direct {p0, v1, p1, v2}, Lcom/facebook/cache/disk/DiskStorageCache;->endInsert(Lcom/facebook/cache/disk/DiskStorage$Inserter;Lcom/facebook/cache/common/CacheKey;Ljava/lang/String;)Lcom/facebook/binaryresource/BinaryResource;
move-result-object p1
.line 368
invoke-interface {p1}, Lcom/facebook/binaryresource/BinaryResource;->size()J
move-result-wide v2
invoke-virtual {v0, v2, v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->setItemSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p2
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
.line 369
invoke-virtual {v2}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v2
invoke-virtual {p2, v2, v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 370
iget-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {p2, v0}, Lcom/facebook/cache/common/CacheEventListener;->onWriteSuccess(Lcom/facebook/cache/common/CacheEvent;)V
:try_end_39
.catchall {:try_start_1c .. :try_end_39} :catchall_4a
.line 373
:try_start_39
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_46
.line 374
sget-object p2, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
const-string v1, "Failed to delete temp file"
invoke-static {p2, v1}, Lcom/facebook/common/logging/FLog;->e(Ljava/lang/Class;Ljava/lang/String;)V
:try_end_46
.catch Ljava/io/IOException; {:try_start_39 .. :try_end_46} :catch_5b
.catchall {:try_start_39 .. :try_end_46} :catchall_59
.line 383
:cond_46
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object p1
:catchall_4a
move-exception p1
.line 373
:try_start_4b
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_58
.line 374
sget-object p2, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
const-string v1, "Failed to delete temp file"
invoke-static {p2, v1}, Lcom/facebook/common/logging/FLog;->e(Ljava/lang/Class;Ljava/lang/String;)V
:cond_58
throw p1
:try_end_59
.catch Ljava/io/IOException; {:try_start_4b .. :try_end_59} :catch_5b
.catchall {:try_start_4b .. :try_end_59} :catchall_59
:catchall_59
move-exception p1
goto :goto_6c
:catch_5b
move-exception p1
.line 378
:try_start_5c
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 379
iget-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {p2, v0}, Lcom/facebook/cache/common/CacheEventListener;->onWriteException(Lcom/facebook/cache/common/CacheEvent;)V
.line 380
sget-object p2, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
const-string v1, "Failed inserting a file into the cache"
invoke-static {p2, v1, p1}, Lcom/facebook/common/logging/FLog;->e(Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 381
throw p1
:try_end_6c
.catchall {:try_start_5c .. :try_end_6c} :catchall_59
.line 383
:goto_6c
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
throw p1
:catchall_70
move-exception p1
.line 359
:try_start_71
monitor-exit v1
:try_end_72
.catchall {:try_start_71 .. :try_end_72} :catchall_70
throw p1
.end method
.method public isEnabled()Z
.registers 2
.line 212
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0}, Lcom/facebook/cache/disk/DiskStorage;->isEnabled()Z
move-result v0
return v0
.end method
.method public isIndexReady()Z
.registers 2
.line 233
iget-boolean v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexReady:Z
if-nez v0, :cond_b
iget-boolean v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-nez v0, :cond_9
goto :goto_b
:cond_9
const/4 v0, 0x0
return v0
:cond_b
:goto_b
const/4 v0, 0x1
return v0
.end method
.method public probe(Lcom/facebook/cache/common/CacheKey;)Z
.registers 8
const/4 v0, 0x0
const/4 v1, 0x0
.line 299
:try_start_2
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v2
:try_end_5
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_5} :catch_35
.line 300
:try_start_5
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object v3
const/4 v4, 0x0
.line 301
:goto_a
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_2a
.line 302
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
:try_end_16
.catchall {:try_start_5 .. :try_end_16} :catchall_2c
.line 303
:try_start_16
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v1, v5, p1}, Lcom/facebook/cache/disk/DiskStorage;->touch(Ljava/lang/String;Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_26
.line 304
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v1, v5}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 305
monitor-exit v2
:try_end_24
.catchall {:try_start_16 .. :try_end_24} :catchall_33
const/4 p1, 0x1
return p1
:cond_26
add-int/lit8 v4, v4, 0x1
move-object v1, v5
goto :goto_a
.line 308
:cond_2a
:try_start_2a
monitor-exit v2
:try_end_2b
.catchall {:try_start_2a .. :try_end_2b} :catchall_2c
return v0
:catchall_2c
move-exception v3
move-object v5, v1
move-object v1, v3
.line 309
:goto_2f
:try_start_2f
monitor-exit v2
:try_end_30
.catchall {:try_start_2f .. :try_end_30} :catchall_33
:try_start_30
throw v1
:try_end_31
.catch Ljava/io/IOException; {:try_start_30 .. :try_end_31} :catch_31
:catch_31
move-exception v1
goto :goto_38
:catchall_33
move-exception v1
goto :goto_2f
:catch_35
move-exception v2
move-object v5, v1
move-object v1, v2
.line 311
:goto_38
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v2
.line 312
invoke-virtual {v2, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheKey(Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
.line 313
invoke-virtual {p1, v5}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
.line 314
invoke-virtual {p1, v1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
.line 315
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {v1, p1}, Lcom/facebook/cache/common/CacheEventListener;->onReadException(Lcom/facebook/cache/common/CacheEvent;)V
.line 316
invoke-virtual {p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return v0
.end method
.method public remove(Lcom/facebook/cache/common/CacheKey;)V
.registers 8
.line 389
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 392
:try_start_3
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object p1
const/4 v1, 0x0
.line 393
:goto_8
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v2
if-ge v1, v2, :cond_3f
.line 394
invoke-interface {p1, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
.line 395
iget-object v3, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v3, v2}, Lcom/facebook/cache/disk/DiskStorage;->remove(Ljava/lang/String;)J
.line 396
iget-object v3, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v3, v2}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
:try_end_1e
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_1e} :catch_23
.catchall {:try_start_3 .. :try_end_1e} :catchall_21
add-int/lit8 v1, v1, 0x1
goto :goto_8
:catchall_21
move-exception p1
goto :goto_41
:catch_23
move-exception p1
.line 399
:try_start_24
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
sget-object v2, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->DELETE_FILE:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
sget-object v3, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "delete: "
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 402
invoke-virtual {p1}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 399
invoke-interface {v1, v2, v3, v4, p1}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 405
:cond_3f
monitor-exit v0
return-void
:goto_41
monitor-exit v0
:try_end_42
.catchall {:try_start_24 .. :try_end_42} :catchall_21
goto :goto_44
:goto_43
throw p1
:goto_44
goto :goto_43
.end method
.method public trimToMinimum()V
.registers 9
.line 642
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 643
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 644
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v1}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v1
.line 645
iget-wide v3, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimitMinimum:J
const-wide/16 v5, 0x0
cmp-long v7, v3, v5
if-lez v7, :cond_3b
cmp-long v3, v1, v5
if-lez v3, :cond_3b
iget-wide v3, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimitMinimum:J
cmp-long v5, v1, v3
if-gez v5, :cond_1f
goto :goto_3b
:cond_1f
const-wide/high16 v3, 0x3ff0000000000000L # 1.0
.line 648
iget-wide v5, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimitMinimum:J
:try_end_23
.catchall {:try_start_3 .. :try_end_23} :catchall_3d
long-to-double v5, v5
long-to-double v1, v1
invoke-static {v5, v6}, Ljava/lang/Double;->isNaN(D)Z
invoke-static {v1, v2}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v5, v1
sub-double/2addr v3, v5
const-wide v1, 0x3f947ae147ae147bL # 0.02
cmpl-double v5, v3, v1
if-lez v5, :cond_39
.line 650
:try_start_36
invoke-direct {p0, v3, v4}, Lcom/facebook/cache/disk/DiskStorageCache;->trimBy(D)V
.line 652
:cond_39
monitor-exit v0
return-void
.line 646
:cond_3b
:goto_3b
monitor-exit v0
return-void
:catchall_3d
move-exception v1
.line 652
monitor-exit v0
:try_end_3f
.catchall {:try_start_36 .. :try_end_3f} :catchall_3d
throw v1
.end method
.method public trimToNothing()V
.registers 1
.line 657
invoke-virtual {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->clearAll()V
return-void
.end method