DiskStorageCache.smali
.class public Lcom/facebook/cache/disk/DiskStorageCache;
.super Ljava/lang/Object;
.source "DiskStorageCache.java"
# 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
.annotation build Ljavax/annotation/concurrent/ThreadSafe;
.end annotation
# static fields
.field public static final FILECACHE_SIZE_UPDATE_PERIOD_MS:J
.field public static final FUTURE_TIMESTAMP_THRESHOLD_MS:J
.field public static final START_OF_VERSIONING:I = 0x1
.field public static final TAG:Ljava/lang/Class;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/Class<",
"*>;"
}
.end annotation
.end field
.field public static final TRIMMING_LOWER_BOUND:D = 0.02
.field public static final UNINITIALIZED:J = -0x1L
# instance fields
.field public final mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
.field public final mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
.field public mCacheSizeLastUpdateTime:J
.field public mCacheSizeLimit:J
.field public final mCacheSizeLimitMinimum:J
.field public final mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
.field public final mClock:Lcom/facebook/common/time/Clock;
.field public final mCountDownLatch:Ljava/util/concurrent/CountDownLatch;
.field public final mDefaultCacheSizeLimit:J
.field public final mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
.field public final mIndexPopulateAtStartupEnabled:Z
.field public mIndexReady:Z
.field public final mLock:Ljava/lang/Object;
.field public final mLowDiskSpaceCacheSizeLimit:J
.field public final mResourceIndex:Ljava/util/Set;
.annotation build Lcom/facebook/common/internal/VisibleForTesting;
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "mLock"
.end annotation
.end field
.field public final mStatFsHelper:Lcom/facebook/common/statfs/StatFsHelper;
.field public final mStorage:Lcom/facebook/cache/disk/DiskStorage;
# direct methods
.method public static constructor <clinit>()V
.registers 3
const-class v0, Lcom/facebook/cache/disk/DiskStorageCache;
sput-object v0, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
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
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;Ljava/util/concurrent/Executor;Z)V
.registers 11
.param p1 # Lcom/facebook/cache/disk/DiskStorage;
.annotation runtime Ljavax/annotation/Nullable;
.end annotation
.end param
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mLowDiskSpaceCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLowDiskSpaceCacheSizeLimit:J
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
invoke-static {}, Lcom/facebook/common/statfs/StatFsHelper;->getInstance()Lcom/facebook/common/statfs/StatFsHelper;
move-result-object v0
iput-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStatFsHelper:Lcom/facebook/common/statfs/StatFsHelper;
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
iput-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
const-wide/16 p1, -0x1
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
iput-object p4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
iget-wide p1, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mCacheSizeLimitMinimum:J
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimitMinimum:J
iput-object p5, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
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;
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;
iput-boolean p8, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
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_45
invoke-interface {p6, p0}, Lcom/facebook/common/disk/DiskTrimmableRegistry;->registerDiskTrimmable(Lcom/facebook/common/disk/DiskTrimmable;)V
:cond_45
iget-boolean p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz p1, :cond_5a
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;
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 {p7, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
goto :goto_62
:cond_5a
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;
:goto_62
return-void
.end method
.method public static synthetic access$000(Lcom/facebook/cache/disk/DiskStorageCache;)Ljava/lang/Object;
.registers 1
iget-object p0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
return-object p0
.end method
.method public static synthetic access$100(Lcom/facebook/cache/disk/DiskStorageCache;)Z
.registers 1
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
move-result p0
return p0
.end method
.method public static synthetic access$202(Lcom/facebook/cache/disk/DiskStorageCache;Z)Z
.registers 2
iput-boolean p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexReady:Z
return p1
.end method
.method public static synthetic access$300(Lcom/facebook/cache/disk/DiskStorageCache;)Ljava/util/concurrent/CountDownLatch;
.registers 1
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
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
: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
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
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
monitor-exit v0
return-object p1
:catchall_19
move-exception p1
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
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "mLock"
.end annotation
move-object/from16 v1, p0
move-wide/from16 v2, p1
: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_80
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
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_72
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-lez v14, :cond_2e
goto :goto_72
:cond_2e
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
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_6f
add-int/lit8 v8, v8, 0x1
add-long/2addr v11, v14
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
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
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
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
invoke-virtual {v9, v13, v14}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
invoke-virtual {v9, v2, v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheLimit(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
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
invoke-virtual {v9}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_1d
:cond_6f
move-object/from16 v10, p3
goto :goto_1d
:cond_72
:goto_72
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
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_80
move-exception v0
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;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "evictAboveSize: "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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
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
goto :goto_a1
:goto_a0
throw v0
:goto_a1
goto :goto_a0
.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
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
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
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
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;
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
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
:cond_37
invoke-virtual {v3, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
: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
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
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
move-result v1
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->updateFileCacheSizeLimit()V
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
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
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
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
:cond_20
iget-wide v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
cmp-long v1, v2, v4
if-lez v1, :cond_34
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
: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
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "mLock"
.end annotation
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
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
: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 24
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "mLock"
.end annotation
move-object/from16 v1, p0
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
sget-wide v4, Lcom/facebook/cache/disk/DiskStorageCache;->FUTURE_TIMESTAMP_THRESHOLD_MS:J
add-long/2addr v4, v2
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
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
goto :goto_25
:cond_1a
iget-boolean v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v0, :cond_24
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
goto :goto_25
:cond_24
const/4 v0, 0x0
: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
invoke-interface {v8}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v8
const-wide/16 v9, 0x0
const-wide/16 v11, -0x1
const/4 v7, 0x0
const/4 v13, 0x0
const/4 v14, 0x0
const/4 v15, 0x0
:goto_37
invoke-interface {v8}, Ljava/util/Iterator;->hasNext()Z
move-result v16
const/16 v17, 0x1
if-eqz v16, :cond_7e
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 v14, v14, 0x1
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getSize()J
move-result-wide v18
add-long v9, v9, v18
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v18
cmp-long v20, v18, v4
if-lez v20, :cond_6e
add-int/lit8 v15, v15, 0x1
int-to-long v6, v7
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getSize()J
move-result-wide v19
add-long v6, v6, v19
long-to-int v7, v6
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v19
move-wide/from16 v21, v4
sub-long v4, v19, v2
invoke-static {v4, v5, v11, v12}, Ljava/lang/Math;->max(JJ)J
move-result-wide v4
move-wide v11, v4
const/4 v13, 0x1
goto :goto_7b
:cond_6e
move-wide/from16 v21, v4
iget-boolean v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v4, :cond_7b
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v4
invoke-interface {v0, v4}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:cond_7b
:goto_7b
move-wide/from16 v4, v21
goto :goto_37
:cond_7e
if-eqz v13, :cond_b0
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;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v13, "Future timestamp found in "
invoke-virtual {v8, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v15}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v13, " files , with a total size of "
invoke-virtual {v8, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v7}, 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, v11, v12}, 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
:cond_b0
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, v14
cmp-long v8, v4, v6
if-nez v8, :cond_c5
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, v9
if-eqz v8, :cond_dc
:cond_c5
iget-boolean v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v4, :cond_d7
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
if-eq v4, v0, :cond_d7
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v4}, Ljava/util/Set;->clear()V
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
:cond_d7
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v0, v9, v10, v6, v7}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->set(JJ)V
:try_end_dc
.catch Ljava/io/IOException; {:try_start_25 .. :try_end_dc} :catch_df
:cond_dc
iput-wide v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
return v17
:catch_df
move-exception v0
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;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "calcFileCacheSize: "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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
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
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeEvictFilesInCacheDir()V
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
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
: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
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
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
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
: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_41
:catchall_1f
move-exception p1
goto :goto_43
:catch_21
move-exception p1
: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;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v4, "trimBy: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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
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
:goto_41
monitor-exit v0
return-void
:goto_43
monitor-exit v0
:try_end_44
.catchall {:try_start_22 .. :try_end_44} :catchall_1f
throw p1
.end method
.method private updateFileCacheSizeLimit()V
.registers 7
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "mLock"
.end annotation
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
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;
: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;
invoke-virtual {v4}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v4
sub-long/2addr v2, v4
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
iget-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLowDiskSpaceCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
goto :goto_27
:cond_23
iget-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
:goto_27
return-void
.end method
# virtual methods
.method public awaitIndex()V
.registers 3
.annotation build Lcom/facebook/common/internal/VisibleForTesting;
.end annotation
: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
goto :goto_d
: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
:goto_d
return-void
.end method
.method public clearAll()V
.registers 8
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
: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
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v1}, Ljava/util/Set;->clear()V
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_36
:catchall_13
move-exception v1
goto :goto_3d
:catch_15
move-exception v1
goto :goto_18
:catch_17
move-exception v1
: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;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "clearAll: "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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
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
:goto_36
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
monitor-exit v0
return-void
:goto_3d
monitor-exit v0
:try_end_3e
.catchall {:try_start_18 .. :try_end_3e} :catchall_13
throw v1
.end method
.method public clearOldEntries(J)J
.registers 23
move-object/from16 v1, p0
iget-object v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v2
: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
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
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
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
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
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
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
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v15
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;
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
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
invoke-virtual {v3, v14, v15}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v3
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
invoke-virtual {v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_85
:cond_7f
const-wide/16 v5, 0x0
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
: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_c3
invoke-direct/range {p0 .. p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
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_c3
:catch_9b
move-exception v0
move-wide v3, v12
goto :goto_a4
:catchall_9e
move-exception v0
goto :goto_c5
:catch_a0
move-exception v0
const-wide/16 v5, 0x0
move-wide v3, v5
: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;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "clearOldEntries: "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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
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
:cond_c3
:goto_c3
monitor-exit v2
return-wide v12
:goto_c5
monitor-exit v2
:try_end_c6
.catchall {:try_start_a4 .. :try_end_c6} :catchall_9e
goto :goto_c8
:goto_c7
throw v0
:goto_c8
goto :goto_c7
.end method
.method public getCount()J
.registers 3
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
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
.annotation runtime Ljavax/annotation/Nullable;
.end annotation
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
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
: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_4f
.catchall {:try_start_9 .. :try_end_c} :catchall_4d
: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
:goto_13
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v7
if-ge v4, v7, :cond_2e
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
invoke-virtual {v0, v5}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
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-eqz v6, :cond_2b
goto :goto_2e
:cond_2b
add-int/lit8 v4, v4, 0x1
goto :goto_13
:cond_2e
:goto_2e
if-nez v6, :cond_3b
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
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_45
:cond_3b
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
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
:goto_45
monitor-exit v2
:try_end_46
.catchall {:try_start_c .. :try_end_46} :catchall_4a
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object v6
:catchall_4a
move-exception p1
:try_start_4b
monitor-exit v2
:try_end_4c
.catchall {:try_start_4b .. :try_end_4c} :catchall_4a
:try_start_4c
throw p1
:try_end_4d
.catch Ljava/io/IOException; {:try_start_4c .. :try_end_4d} :catch_4f
.catchall {:try_start_4c .. :try_end_4d} :catchall_4d
:catchall_4d
move-exception p1
goto :goto_67
:catch_4f
move-exception p1
:try_start_50
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
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
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_63
.catchall {:try_start_50 .. :try_end_63} :catchall_4d
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object v1
:goto_67
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_6c
:goto_6b
throw p1
:goto_6c
goto :goto_6b
.end method
.method public getSize()J
.registers 3
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
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
: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
monitor-exit v0
:try_end_b
.catchall {:try_start_3 .. :try_end_b} :catchall_34
return v2
:cond_c
const/4 v1, 0x0
: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
:goto_12
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_30
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
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
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
:try_start_2b
monitor-exit v0
return v2
:cond_2d
add-int/lit8 v4, v4, 0x1
goto :goto_12
:cond_30
monitor-exit v0
return v1
:catch_32
monitor-exit v0
return v1
:catchall_34
move-exception p1
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
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
: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
:goto_9
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v3
if-ge v2, v3, :cond_23
invoke-interface {p1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
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
monitor-exit v0
const/4 p1, 0x1
return p1
:cond_20
add-int/lit8 v2, v2, 0x1
goto :goto_9
:cond_23
monitor-exit v0
return v1
:catchall_25
move-exception p1
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
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheKey(Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
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
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v1
:try_start_10
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getFirstResourceId(Lcom/facebook/cache/common/CacheKey;)Ljava/lang/String;
move-result-object v2
monitor-exit v1
:try_end_15
.catchall {:try_start_10 .. :try_end_15} :catchall_70
invoke-virtual {v0, v2}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
: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
:try_start_1c
invoke-interface {v1, p2, p1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->writeData(Lcom/facebook/cache/common/WriterCallback;Ljava/lang/Object;)V
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
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;
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;
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
:try_start_39
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_46
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
:cond_46
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object p1
:catchall_4a
move-exception p1
:try_start_4b
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_58
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
:try_start_5c
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
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
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
throw p1
:try_end_6c
.catchall {:try_start_5c .. :try_end_6c} :catchall_59
:goto_6c
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
throw p1
:catchall_70
move-exception p1
: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
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
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
goto :goto_c
:cond_b
:goto_b
const/4 v0, 0x1
:goto_c
return v0
.end method
.method public probe(Lcom/facebook/cache/common/CacheKey;)Z
.registers 8
const/4 v0, 0x0
const/4 v1, 0x0
: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
: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
:goto_a
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_2a
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
: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
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
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
: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
: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
:goto_38
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v2
invoke-virtual {v2, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheKey(Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
invoke-virtual {p1, v5}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
invoke-virtual {p1, v1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
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
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
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
: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
:goto_8
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v2
if-ge v1, v2, :cond_42
invoke-interface {p1, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
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
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_44
:catch_23
move-exception p1
: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;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "delete: "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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
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
:cond_42
monitor-exit v0
return-void
:goto_44
monitor-exit v0
:try_end_45
.catchall {:try_start_24 .. :try_end_45} :catchall_21
goto :goto_47
:goto_46
throw p1
:goto_47
goto :goto_46
.end method
.method public trimToMinimum()V
.registers 9
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
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
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
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
:try_start_36
invoke-direct {p0, v3, v4}, Lcom/facebook/cache/disk/DiskStorageCache;->trimBy(D)V
:cond_39
monitor-exit v0
return-void
:cond_3b
:goto_3b
monitor-exit v0
return-void
:catchall_3d
move-exception v1
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
invoke-virtual {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->clearAll()V
return-void
.end method