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
# static fields
.field private static final FILECACHE_SIZE_UPDATE_PERIOD_MS:J
.field private static final FUTURE_TIMESTAMP_THRESHOLD_MS:J
.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;Ljava/util/concurrent/Executor;Z)V
.registers 11
.param p6 # Lcom/facebook/common/disk/DiskTrimmableRegistry;
.annotation runtime Ljavax/annotation/Nullable;
.end annotation
.end param
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0,
0x0,
0x0,
0x0,
0x0,
0x10,
0x0
}
names = {
"diskStorage",
"entryEvictionComparatorSupplier",
"params",
"cacheEventListener",
"cacheErrorLogger",
"diskTrimmableRegistry",
"executorForBackgrountInit",
"indexPopulateAtStartupEnabled"
}
.end annotation
.line 152
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 85
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;
.line 153
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mLowDiskSpaceCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLowDiskSpaceCacheSizeLimit:J
.line 154
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mDefaultCacheSizeLimit:J
.line 155
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
.line 156
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;
.line 158
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
.line 160
iput-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
const-wide/16 p1, -0x1
.line 162
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
.line 164
iput-object p4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
.line 166
iget-wide p1, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mCacheSizeLimitMinimum:J
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimitMinimum:J
.line 168
iput-object p5, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
.line 170
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 172
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 174
iput-boolean p8, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
.line 176
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 179
invoke-interface {p6, p0}, Lcom/facebook/common/disk/DiskTrimmableRegistry;->registerDiskTrimmable(Lcom/facebook/common/disk/DiskTrimmable;)V
:cond_47
if-eqz p8, :cond_5a
.line 183
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 185
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
.line 198
: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 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/MethodParameters;
accessFlags = {
0x10,
0x10,
0x0
}
names = {
"inserter",
"key",
"resourceId"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 326
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 327
: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 328
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 329
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 330
monitor-exit v0
return-object p1
:catchall_19
move-exception p1
.line 331
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/MethodParameters;
accessFlags = {
0x0,
0x0
}
names = {
"desiredSize",
"reason"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
move-object/from16 v1, p0
move-wide/from16 v2, p1
.line 477
: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
.line 487
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 491
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
.line 495
: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
.line 496
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
.line 501
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
.line 502
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 503
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 504
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 505
invoke-virtual {v9, v13, v14}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
.line 506
invoke-virtual {v9, v2, v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheLimit(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v9
.line 507
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 508
invoke-virtual {v9}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_1d
:cond_6f
move-object/from16 v10, p3
goto :goto_1d
.line 511
: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
.line 512
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
.line 479
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;
.line 482
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 479
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 484
throw v0
.end method
.method private getSortedEntries(Ljava/util/Collection;)Ljava/util/Collection;
.registers 9
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"allEntries"
}
.end annotation
.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 523
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 524
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 525
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 526
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 527
invoke-interface {v4}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v5
cmp-long v5, v5, v0
if-lez v5, :cond_37
.line 528
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
.line 530
:cond_37
invoke-virtual {v3, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
.line 533
: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 534
invoke-virtual {v2, v3}, Ljava/util/ArrayList;->addAll(Ljava/util/Collection;)Z
return-object v2
.end method
.method private maybeEvictFilesInCacheDir()V
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 450
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 451
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
move-result v1
.line 454
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->updateFileCacheSizeLimit()V
.line 456
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 459
iget-wide v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
cmp-long v4, v2, v4
if-lez v4, :cond_20
if-nez v1, :cond_20
.line 460
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 461
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 465
:cond_20
iget-wide v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
cmp-long v1, v2, v4
if-lez v1, :cond_31
const-wide/16 v1, 0x9
mul-long/2addr v4, v1
const-wide/16 v1, 0xa
.line 466
div-long/2addr v4, v1
sget-object v1, Lcom/facebook/cache/common/CacheEventListener$EvictionReason;->CACHE_FULL:Lcom/facebook/cache/common/CacheEventListener$EvictionReason;
invoke-direct {p0, v4, v5, v1}, Lcom/facebook/cache/disk/DiskStorageCache;->evictAboveSize(JLcom/facebook/cache/common/CacheEventListener$EvictionReason;)V
.line 469
:cond_31
monitor-exit v0
return-void
:catchall_33
move-exception v1
monitor-exit v0
:try_end_35
.catchall {:try_start_3 .. :try_end_35} :catchall_33
throw v1
.end method
.method private maybeUpdateFileCacheSize()Z
.registers 7
.line 663
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 664
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 v4, v2, v4
if-eqz v4, :cond_20
sub-long/2addr v0, v2
sget-wide v2, Lcom/facebook/cache/disk/DiskStorageCache;->FILECACHE_SIZE_UPDATE_PERIOD_MS:J
cmp-long v0, v0, v2
if-lez v0, :cond_1e
goto :goto_20
:cond_1e
const/4 v0, 0x0
return v0
.line 667
: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
move-object/from16 v1, p0
.line 680
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 681
sget-wide v4, Lcom/facebook/cache/disk/DiskStorageCache;->FUTURE_TIMESTAMP_THRESHOLD_MS:J
add-long/2addr v4, v2
.line 683
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 684
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
goto :goto_25
.line 685
:cond_1a
iget-boolean v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v0, :cond_24
.line 686
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
goto :goto_25
:cond_24
const/4 v0, 0x0
.line 691
: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 692
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_82
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
.line 694
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getSize()J
move-result-wide v18
add-long v9, v9, v18
.line 697
invoke-interface/range {v16 .. v16}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v18
cmp-long v18, v18, v4
if-lez v18, :cond_6f
add-int/lit8 v15, v15, 0x1
int-to-long v6, v7
.line 700
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
.line 701
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
move/from16 v13, v17
goto :goto_7f
:cond_6f
move-wide/from16 v21, v4
.line 702
iget-boolean v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v4, :cond_7f
.line 703
invoke-static {v0}, Lcom/facebook/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 704
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_7f
:goto_7f
move-wide/from16 v4, v21
goto :goto_37
:cond_82
if-eqz v13, :cond_b4
.line 708
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
.line 720
:cond_b4
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 v4, v4, v6
if-nez v4, :cond_c9
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 v4, v4, v9
if-eqz v4, :cond_e3
.line 721
:cond_c9
iget-boolean v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v4, :cond_de
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
if-eq v4, v0, :cond_de
.line 722
invoke-static {v0}, Lcom/facebook/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 723
iget-object v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v4}, Ljava/util/Set;->clear()V
.line 724
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 726
:cond_de
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_e3
.catch Ljava/io/IOException; {:try_start_25 .. :try_end_e3} :catch_e6
.line 736
:cond_e3
iput-wide v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
return v17
:catch_e6
move-exception v0
.line 729
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;
.line 732
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 729
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/MethodParameters;
accessFlags = {
0x10,
0x10
}
names = {
"resourceId",
"key"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 315
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeEvictFilesInCacheDir()V
.line 316
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
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x10
}
names = {
"trimRatio"
}
.end annotation
.line 640
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 643
: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 644
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 645
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
long-to-double v3, v1
mul-double/2addr p1, v3
double-to-long p1, p1
sub-long/2addr v1, p1
.line 647
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_1a
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_1a} :catch_1d
.catchall {:try_start_3 .. :try_end_1a} :catchall_1b
goto :goto_3c
:catchall_1b
move-exception p1
goto :goto_3e
:catch_1d
move-exception p1
.line 649
:try_start_1e
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 v4, "trimBy: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 650
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 649
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 652
:goto_3c
monitor-exit v0
return-void
:goto_3e
monitor-exit v0
:try_end_3f
.catchall {:try_start_1e .. :try_end_3f} :catchall_1b
throw p1
.end method
.method private updateFileCacheSizeLimit()V
.registers 7
.line 546
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
.line 547
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 550
: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 551
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
.line 553
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
.line 555
: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 protected awaitIndex()V
.registers 3
.line 219
: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
.line 221
: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
.line 568
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 570
: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 571
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v1}, Ljava/util/Set;->clear()V
.line 572
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
.line 574
: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;
.line 575
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 574
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 577
: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
.line 578
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
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"cacheExpirationMs"
}
.end annotation
move-object/from16 v1, p0
.line 398
iget-object v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v2
.line 400
: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 401
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 402
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 405
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 407
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 409
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 410
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 415
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v15
.line 416
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 417
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 418
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 419
invoke-virtual {v3, v14, v15}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v3
.line 420
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 421
invoke-virtual {v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_85
:cond_7f
const-wide/16 v5, 0x0
.line 424
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 427
: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
.line 429
invoke-direct/range {p0 .. p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 430
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
.line 433
: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;
.line 436
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 433
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 439
: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
throw v0
.end method
.method public getCount()J
.registers 3
.line 564
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 204
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 system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x10
}
names = {
"key"
}
.end annotation
.annotation runtime Ljavax/annotation/Nullable;
.end annotation
.line 245
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
.line 247
: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_52
.catchall {:try_start_9 .. :try_end_c} :catchall_50
.line 249
: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 250
:goto_13
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v7
if-ge v4, v7, :cond_2e
.line 251
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
.line 252
invoke-virtual {v0, v5}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 253
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
.line 259
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 260
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_48
.line 262
:cond_3b
invoke-static {v5}, Lcom/facebook/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.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;->onHit(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;->add(Ljava/lang/Object;)Z
.line 266
:goto_48
monitor-exit v2
:try_end_49
.catchall {:try_start_c .. :try_end_49} :catchall_4d
.line 275
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object v6
:catchall_4d
move-exception p1
.line 267
:try_start_4e
monitor-exit v2
:try_end_4f
.catchall {:try_start_4e .. :try_end_4f} :catchall_4d
:try_start_4f
throw p1
:try_end_50
.catch Ljava/io/IOException; {:try_start_4f .. :try_end_50} :catch_52
.catchall {:try_start_4f .. :try_end_50} :catchall_50
:catchall_50
move-exception p1
goto :goto_6a
:catch_52
move-exception p1
.line 269
:try_start_53
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 271
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 272
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_66
.catchall {:try_start_53 .. :try_end_66} :catchall_50
.line 275
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object v1
:goto_6a
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
.line 276
throw p1
.end method
.method public getSize()J
.registers 3
.line 560
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
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x10
}
names = {
"key"
}
.end annotation
.line 598
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 599
: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 600
monitor-exit v0
:try_end_b
.catchall {:try_start_3 .. :try_end_b} :catchall_34
return v2
:cond_c
const/4 v1, 0x0
.line 604
:try_start_d
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object v3
move v4, v1
.line 605
:goto_12
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_30
.line 606
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
.line 607
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 608
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 609
:try_start_2b
monitor-exit v0
return v2
:cond_2d
add-int/lit8 v4, v4, 0x1
goto :goto_12
.line 612
:cond_30
monitor-exit v0
return v1
.line 614
:catch_32
monitor-exit v0
return v1
:catchall_34
move-exception p1
.line 616
monitor-exit v0
:try_end_36
.catchall {:try_start_2b .. :try_end_36} :catchall_34
throw p1
.end method
.method public hasKeySync(Lcom/facebook/cache/common/CacheKey;)Z
.registers 7
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"key"
}
.end annotation
.line 583
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 585
: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
move v2, v1
.line 586
:goto_9
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v3
if-ge v2, v3, :cond_23
.line 587
invoke-interface {p1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
.line 588
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 589
monitor-exit v0
const/4 p1, 0x1
return p1
:cond_20
add-int/lit8 v2, v2, 0x1
goto :goto_9
.line 592
:cond_23
monitor-exit v0
return v1
:catchall_25
move-exception p1
.line 593
monitor-exit v0
:try_end_27
.catchall {:try_start_3 .. :try_end_27} :catchall_25
throw p1
.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/MethodParameters;
accessFlags = {
0x0,
0x0
}
names = {
"key",
"callback"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 338
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
.line 339
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 341
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v1
.line 343
: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 344
monitor-exit v1
:try_end_15
.catchall {:try_start_10 .. :try_end_15} :catchall_70
.line 345
invoke-virtual {v0, v2}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 348
: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 350
: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 352
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 353
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;
.line 354
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 357
:try_start_39
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_46
.line 358
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 367
:cond_46
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object p1
:catchall_4a
move-exception p1
.line 357
:try_start_4b
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_58
.line 358
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
.line 360
: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 362
:try_start_5c
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 363
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 364
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 365
throw p1
:try_end_6c
.catchall {:try_start_5c .. :try_end_6c} :catchall_59
.line 367
:goto_6c
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
.line 368
throw p1
:catchall_70
move-exception p1
.line 344
: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 209
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 230
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
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x10
}
names = {
"key"
}
.end annotation
const/4 v0, 0x0
const/4 v1, 0x0
.line 292
: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 293
:try_start_5
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object v3
move v4, v0
.line 294
:goto_a
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_2a
.line 295
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 296
: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 297
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 298
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 301
: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 302
: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 305
: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
.line 306
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 307
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
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"key"
}
.end annotation
.line 373
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 376
: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 377
:goto_8
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v2
if-ge v1, v2, :cond_42
.line 378
invoke-interface {p1, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
.line 379
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 380
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
.line 383
: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;
.line 384
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 383
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 386
:cond_42
monitor-exit v0
return-void
:goto_44
monitor-exit v0
:try_end_45
.catchall {:try_start_24 .. :try_end_45} :catchall_21
throw p1
.end method
.method public trimToMinimum()V
.registers 9
.line 621
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 622
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 623
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 624
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_31
cmp-long v5, v1, v5
if-lez v5, :cond_31
cmp-long v5, v1, v3
if-gez v5, :cond_1d
goto :goto_31
:cond_1d
const-wide/high16 v5, 0x3ff0000000000000L # 1.0
long-to-double v3, v3
long-to-double v1, v1
div-double/2addr v3, v1
sub-double/2addr v5, v3
const-wide v1, 0x3f947ae147ae147bL # 0.02
cmpl-double v1, v5, v1
if-lez v1, :cond_2f
.line 629
invoke-direct {p0, v5, v6}, Lcom/facebook/cache/disk/DiskStorageCache;->trimBy(D)V
.line 631
:cond_2f
monitor-exit v0
return-void
.line 625
:cond_31
:goto_31
monitor-exit v0
return-void
:catchall_33
move-exception v1
.line 631
monitor-exit v0
:try_end_35
.catchall {:try_start_3 .. :try_end_35} :catchall_33
throw v1
.end method
.method public trimToNothing()V
.registers 1
.line 636
invoke-virtual {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->clearAll()V
return-void
.end method