DiskStorageCache.smali
.class public Lcom/facebook/cache/disk/DiskStorageCache;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/facebook/cache/disk/FileCache;
.implements Lcom/facebook/common/disk/DiskTrimmable;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/facebook/cache/disk/DiskStorageCache$Params;,
Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
}
.end annotation
# static fields
.field private static final FILECACHE_SIZE_UPDATE_PERIOD_MS:J
.field private static final FUTURE_TIMESTAMP_THRESHOLD_MS:J
.field private static final SHARED_PREFS_FILENAME_PREFIX:Ljava/lang/String; = "disk_entries_list"
.field public static final START_OF_VERSIONING:I = 0x1
.field private static final TAG:Ljava/lang/Class;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/Class<",
"*>;"
}
.end annotation
.end field
.field private static final TRIMMING_LOWER_BOUND:D = 0.02
.field private static final UNINITIALIZED:J = -0x1L
# instance fields
.field private final mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
.field private final mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
.field private mCacheSizeLastUpdateTime:J
.field private mCacheSizeLimit:J
.field private final mCacheSizeLimitMinimum:J
.field private final mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
.field private final mClock:Lcom/facebook/common/time/Clock;
.field private final mCountDownLatch:Ljava/util/concurrent/CountDownLatch;
.field private final mDefaultCacheSizeLimit:J
.field private final mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
.field private final mIndexPopulateAtStartupEnabled:Z
.field private mIndexReady:Z
.field private final mLock:Ljava/lang/Object;
.field private final mLowDiskSpaceCacheSizeLimit:J
.field 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
.end field
.field private final mStatFsHelper:Lcom/facebook/common/statfs/StatFsHelper;
.field private final mStorage:Lcom/facebook/cache/disk/DiskStorage;
# direct methods
.method public static constructor <clinit>()V
.registers 3
.line 1
const-class v0, Lcom/facebook/cache/disk/DiskStorageCache;
sput-object v0, Lcom/facebook/cache/disk/DiskStorageCache;->TAG:Ljava/lang/Class;
.line 2
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 3
sget-object v0, Ljava/util/concurrent/TimeUnit;->MINUTES:Ljava/util/concurrent/TimeUnit;
const-wide/16 v1, 0x1e
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v0
sput-wide v0, Lcom/facebook/cache/disk/DiskStorageCache;->FILECACHE_SIZE_UPDATE_PERIOD_MS:J
return-void
.end method
.method public constructor <init>(Lcom/facebook/cache/disk/DiskStorage;Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;Lcom/facebook/cache/disk/DiskStorageCache$Params;Lcom/facebook/cache/common/CacheEventListener;Lcom/facebook/cache/common/CacheErrorLogger;Lcom/facebook/common/disk/DiskTrimmableRegistry;Landroid/content/Context;Ljava/util/concurrent/Executor;Z)V
.registers 12
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance p7, Ljava/lang/Object;
invoke-direct {p7}, Ljava/lang/Object;-><init>()V
iput-object p7, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
.line 3
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mLowDiskSpaceCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLowDiskSpaceCacheSizeLimit:J
.line 4
iget-wide v0, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mDefaultCacheSizeLimit:J
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mDefaultCacheSizeLimit:J
.line 5
iput-wide v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
.line 6
invoke-static {}, Lcom/facebook/common/statfs/StatFsHelper;->getInstance()Lcom/facebook/common/statfs/StatFsHelper;
move-result-object p7
iput-object p7, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStatFsHelper:Lcom/facebook/common/statfs/StatFsHelper;
.line 7
iput-object p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
.line 8
iput-object p2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mEntryEvictionComparatorSupplier:Lcom/facebook/cache/disk/EntryEvictionComparatorSupplier;
const-wide/16 p1, -0x1
.line 9
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
.line 10
iput-object p4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
.line 11
iget-wide p1, p3, Lcom/facebook/cache/disk/DiskStorageCache$Params;->mCacheSizeLimitMinimum:J
iput-wide p1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimitMinimum:J
.line 12
iput-object p5, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
.line 13
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 14
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 15
iput-boolean p9, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
.line 16
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
.line 17
invoke-interface {p6, p0}, Lcom/facebook/common/disk/DiskTrimmableRegistry;->registerDiskTrimmable(Lcom/facebook/common/disk/DiskTrimmable;)V
:cond_45
if-eqz p9, :cond_58
.line 18
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 19
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-static {p8, p1}, Lcom/facebook/cache/disk/DiskStorageCache;->INVOKEINTERFACE_com_facebook_cache_disk_DiskStorageCache_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
goto :goto_60
.line 20
:cond_58
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_60
return-void
.end method
.method public static INVOKEINTERFACE_com_facebook_cache_disk_DiskStorageCache_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
.registers 4
.line 1
invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->b()Z
move-result v0
if-eqz v0, :cond_3a
invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->a()Z
move-result v0
if-eqz v0, :cond_3a
.line 2
:try_start_c
sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 3
sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->b:Landroid/os/Handler;
new-instance v1, Lcom/shopee/app/asm/anr/threadpool/a$b;
invoke-direct {v1, p0, p1}, Lcom/shopee/app/asm/anr/threadpool/a$b;-><init>(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
:try_end_18
.catchall {:try_start_c .. :try_end_18} :catchall_19
goto :goto_54
:catchall_19
move-exception v0
.line 4
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 5
:try_start_1f
invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_2b
.line 6
sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;
.line 7
invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V
return-void
.line 8
:cond_2b
invoke-interface {p0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
:try_end_2e
.catchall {:try_start_1f .. :try_end_2e} :catchall_2f
goto :goto_54
:catchall_2f
move-exception p0
.line 9
sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 10
invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;
move-result-object p1
invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V
goto :goto_54
.line 11
:cond_3a
:try_start_3a
invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_46
.line 12
sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;
.line 13
invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V
return-void
.line 14
:cond_46
invoke-interface {p0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
:try_end_49
.catchall {:try_start_3a .. :try_end_49} :catchall_4a
goto :goto_54
:catchall_4a
move-exception p0
.line 15
sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 16
invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;
move-result-object p1
invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V
:goto_54
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
.line 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
: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 3
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 4
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 5
monitor-exit v0
return-object p1
:catchall_19
move-exception p1
.line 6
monitor-exit v0
:try_end_1b
.catchall {:try_start_3 .. :try_end_1b} :catchall_19
throw p1
.end method
.method private evictAboveSize(JLcom/facebook/cache/common/CacheEventListener$EvictionReason;)V
.registers 21
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
move-object/from16 v1, p0
move-wide/from16 v2, p1
.line 1
: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 2
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 3
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
const-wide/16 v9, 0x0
:goto_1d
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v11
if-eqz v11, :cond_72
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v11
check-cast v11, Lcom/facebook/cache/disk/DiskStorage$Entry;
cmp-long v12, v9, v6
if-lez v12, :cond_2e
goto :goto_72
.line 4
:cond_2e
iget-object v12, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v12, v11}, Lcom/facebook/cache/disk/DiskStorage;->remove(Lcom/facebook/cache/disk/DiskStorage$Entry;)J
move-result-wide v12
.line 5
iget-object v14, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v11}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v15
invoke-interface {v14, v15}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
const-wide/16 v14, 0x0
cmp-long v16, v12, v14
if-lez v16, :cond_6f
add-int/lit8 v8, v8, 0x1
add-long/2addr v9, v12
.line 6
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v14
.line 7
invoke-interface {v11}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getId()Ljava/lang/String;
move-result-object v11
invoke-virtual {v14, v11}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v11
move-object/from16 v14, p3
.line 8
invoke-virtual {v11, v14}, Lcom/facebook/cache/disk/SettableCacheEvent;->setEvictionReason(Lcom/facebook/cache/common/CacheEventListener$EvictionReason;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v11
.line 9
invoke-virtual {v11, v12, v13}, Lcom/facebook/cache/disk/SettableCacheEvent;->setItemSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v11
sub-long v12, v4, v9
.line 10
invoke-virtual {v11, v12, v13}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v11
.line 11
invoke-virtual {v11, v2, v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheLimit(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v11
.line 12
iget-object v12, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheEventListener:Lcom/facebook/cache/common/CacheEventListener;
invoke-interface {v12, v11}, Lcom/facebook/cache/common/CacheEventListener;->onEviction(Lcom/facebook/cache/common/CacheEvent;)V
.line 13
invoke-virtual {v11}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_1d
:cond_6f
move-object/from16 v14, p3
goto :goto_1d
.line 14
:cond_72
:goto_72
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
neg-long v2, v9
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 15
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 16
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;
const-string v5, "evictAboveSize: "
.line 17
invoke-static {v5}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
.line 18
invoke-virtual {v0}, Ljava/lang/Throwable;->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 19
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 20
throw v0
.end method
.method private getSortedEntries(Ljava/util/Collection;)Ljava/util/Collection;
.registers 10
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Collection<",
"Lcom/facebook/cache/disk/DiskStorage$Entry;",
">;)",
"Ljava/util/Collection<",
"Lcom/facebook/cache/disk/DiskStorage$Entry;",
">;"
}
.end annotation
.line 1
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 2
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 3
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 4
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 5
invoke-interface {v4}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v5
cmp-long v7, v5, v0
if-lez v7, :cond_37
.line 6
invoke-virtual {v2, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
.line 7
:cond_37
invoke-virtual {v3, v4}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_1f
.line 8
: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 9
invoke-virtual {v2, v3}, Ljava/util/ArrayList;->addAll(Ljava/util/Collection;)Z
return-object v2
.end method
.method private maybeEvictFilesInCacheDir()V
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
move-result v1
.line 3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->updateFileCacheSizeLimit()V
.line 4
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 5
iget-wide v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
cmp-long v6, v2, v4
if-lez v6, :cond_20
if-nez v1, :cond_20
.line 6
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 7
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 8
:cond_20
iget-wide v4, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLimit:J
cmp-long v1, v2, v4
if-lez v1, :cond_32
const-wide/16 v1, 0x9
mul-long v4, v4, v1
const-wide/16 v1, 0xa
.line 9
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 10
:cond_32
monitor-exit v0
return-void
:catchall_34
move-exception v1
monitor-exit v0
:try_end_36
.catchall {:try_start_3 .. :try_end_36} :catchall_34
throw v1
.end method
.method private maybeUpdateFileCacheSize()Z
.registers 8
.line 1
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 2
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v2}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->isInitialized()Z
move-result v2
if-eqz v2, :cond_20
iget-wide v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
const-wide/16 v4, -0x1
cmp-long v6, v2, v4
if-eqz v6, :cond_20
sub-long/2addr v0, v2
sget-wide v2, Lcom/facebook/cache/disk/DiskStorageCache;->FILECACHE_SIZE_UPDATE_PERIOD_MS:J
cmp-long v4, v0, v2
if-lez v4, :cond_1e
goto :goto_20
:cond_1e
const/4 v0, 0x0
return v0
.line 3
: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 20
move-object/from16 v1, p0
.line 1
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 2
sget-wide v4, Lcom/facebook/cache/disk/DiskStorageCache;->FUTURE_TIMESTAMP_THRESHOLD_MS:J
add-long/2addr v4, v2
.line 3
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 4
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
goto :goto_25
.line 5
:cond_1a
iget-boolean v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v0, :cond_24
.line 6
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
goto :goto_25
:cond_24
const/4 v0, 0x0
.line 7
:goto_25
:try_start_25
iget-object v6, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v6}, Lcom/facebook/cache/disk/DiskStorage;->getEntries()Ljava/util/Collection;
move-result-object v6
.line 8
invoke-interface {v6}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v6
const-wide/16 v7, 0x0
const-wide/16 v9, -0x1
const/4 v11, 0x0
const/4 v12, 0x0
const/4 v13, 0x0
const/4 v14, 0x0
:goto_37
invoke-interface {v6}, Ljava/util/Iterator;->hasNext()Z
move-result v15
const/16 v16, 0x1
if-eqz v15, :cond_80
invoke-interface {v6}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v15
check-cast v15, Lcom/facebook/cache/disk/DiskStorage$Entry;
add-int/lit8 v13, v13, 0x1
.line 9
invoke-interface {v15}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getSize()J
move-result-wide v16
add-long v7, v7, v16
.line 10
invoke-interface {v15}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v16
cmp-long v18, v16, v4
if-lez v18, :cond_70
add-int/lit8 v14, v14, 0x1
int-to-long v11, v11
.line 11
invoke-interface {v15}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getSize()J
move-result-wide v16
add-long v11, v11, v16
long-to-int v12, v11
.line 12
invoke-interface {v15}, Lcom/facebook/cache/disk/DiskStorage$Entry;->getTimestamp()J
move-result-wide v15
move-wide/from16 v17, v4
sub-long v4, v15, v2
invoke-static {v4, v5, v9, v10}, Ljava/lang/Math;->max(JJ)J
move-result-wide v4
const/4 v9, 0x1
move-wide v9, v4
move v11, v12
const/4 v12, 0x1
goto :goto_7d
:cond_70
move-wide/from16 v17, v4
.line 13
iget-boolean v4, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mIndexPopulateAtStartupEnabled:Z
if-eqz v4, :cond_7d
.line 14
invoke-interface {v15}, 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_7d
:goto_7d
move-wide/from16 v4, v17
goto :goto_37
:cond_80
if-eqz v12, :cond_b2
.line 15
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 v12, Ljava/lang/StringBuilder;
invoke-direct {v12}, Ljava/lang/StringBuilder;-><init>()V
const-string v15, "Future timestamp found in "
invoke-virtual {v12, v15}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v14}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v14, " files , with a total size of "
invoke-virtual {v12, v14}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v11}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v11, " bytes, and a maximum time delta of "
invoke-virtual {v12, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v9, v10}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v9, "ms"
invoke-virtual {v12, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v9
const/4 v10, 0x0
invoke-interface {v4, v5, v6, v9, v10}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 16
:cond_b2
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 v9, v13
cmp-long v6, v4, v9
if-nez v6, :cond_c7
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 v6, v4, v7
if-eqz v6, :cond_dc
.line 17
:cond_c7
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
.line 18
invoke-interface {v4}, Ljava/util/Set;->clear()V
.line 19
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 20
:cond_d7
iget-object v0, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
invoke-virtual {v0, v7, v8, v9, v10}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->set(JJ)V
:try_end_dc
.catch Ljava/io/IOException; {:try_start_25 .. :try_end_dc} :catch_df
.line 21
:cond_dc
iput-wide v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheSizeLastUpdateTime:J
return v16
:catch_df
move-exception v0
.line 22
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;
const-string v5, "calcFileCacheSize: "
.line 23
invoke-static {v5}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
.line 24
invoke-virtual {v0}, Ljava/lang/Throwable;->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 25
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 v0, 0x0
return v0
.end method
.method private startInsert(Ljava/lang/String;Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/DiskStorage$Inserter;
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeEvictFilesInCacheDir()V
.line 2
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mStorage:Lcom/facebook/cache/disk/DiskStorage;
invoke-interface {v0, p1, p2}, Lcom/facebook/cache/disk/DiskStorage;->insert(Ljava/lang/String;Ljava/lang/Object;)Lcom/facebook/cache/disk/DiskStorage$Inserter;
move-result-object p1
return-object p1
.end method
.method private trimBy(D)V
.registers 8
.line 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
: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 3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 4
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 p1, p1, v3
double-to-long p1, p1
sub-long/2addr v1, p1
.line 5
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_1b
.catch Ljava/io/IOException; {:try_start_3 .. :try_end_1b} :catch_1e
.catchall {:try_start_3 .. :try_end_1b} :catchall_1c
goto :goto_3d
:catchall_1c
move-exception p1
goto :goto_3f
:catch_1e
move-exception p1
.line 6
:try_start_1f
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 7
invoke-virtual {p1}, Ljava/lang/Throwable;->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 8
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 9
:goto_3d
monitor-exit v0
return-void
:goto_3f
monitor-exit v0
:try_end_40
.catchall {:try_start_1f .. :try_end_40} :catchall_1c
throw p1
.end method
.method private updateFileCacheSizeLimit()V
.registers 7
.line 1
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
.line 2
sget-object v0, Lcom/facebook/common/statfs/StatFsHelper$StorageType;->EXTERNAL:Lcom/facebook/common/statfs/StatFsHelper$StorageType;
goto :goto_d
.line 3
:cond_b
sget-object v0, Lcom/facebook/common/statfs/StatFsHelper$StorageType;->INTERNAL:Lcom/facebook/common/statfs/StatFsHelper$StorageType;
.line 4
: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 5
invoke-virtual {v4}, Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;->getSize()J
move-result-wide v4
sub-long/2addr v2, v4
.line 6
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 7
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 8
: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
.line 1
: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 2
: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 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
: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 3
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mResourceIndex:Ljava/util/Set;
invoke-interface {v1}, Ljava/util/Set;->clear()V
.line 4
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 5
: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 6
invoke-virtual {v1}, Ljava/lang/Throwable;->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 7
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 8
: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 9
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
.line 1
iget-object v2, v1, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v2
.line 2
: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 3
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 4
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 5
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 6
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 7
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 8
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 9
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v15
.line 10
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 11
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 12
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 13
invoke-virtual {v3, v14, v15}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v3
.line 14
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 15
invoke-virtual {v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
goto :goto_85
:cond_7f
const-wide/16 v5, 0x0
.line 16
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 17
: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 18
invoke-direct/range {p0 .. p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 19
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 20
: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 21
invoke-virtual {v0}, Ljava/lang/Throwable;->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 22
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 23
: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
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
.line 1
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
.line 2
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 3
: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
.line 4
: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 5
:goto_13
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v7
if-ge v4, v7, :cond_2e
.line 6
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
.line 7
invoke-virtual {v0, v5}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 8
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 9
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 10
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
.line 11
: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
.line 12
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 13
:goto_45
monitor-exit v2
:try_end_46
.catchall {:try_start_c .. :try_end_46} :catchall_4a
.line 14
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object v6
:catchall_4a
move-exception p1
.line 15
: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
.line 16
: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
.line 17
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 18
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
.line 19
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
.line 20
throw p1
.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
.line 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
: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 3
monitor-exit v0
:try_end_b
.catchall {:try_start_3 .. :try_end_b} :catchall_34
return v2
:cond_c
const/4 v1, 0x0
.line 4
:try_start_d
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object v3
const/4 v4, 0x0
.line 5
:goto_12
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_30
.line 6
invoke-interface {v3, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/lang/String;
.line 7
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 8
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 9
:try_start_2b
monitor-exit v0
return v2
:cond_2d
add-int/lit8 v4, v4, 0x1
goto :goto_12
.line 10
:cond_30
monitor-exit v0
return v1
.line 11
:catch_32
monitor-exit v0
return v1
:catchall_34
move-exception p1
.line 12
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
.line 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object p1
const/4 v1, 0x0
const/4 v2, 0x0
.line 3
:goto_9
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v3
if-ge v2, v3, :cond_23
.line 4
invoke-interface {p1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
.line 5
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 6
monitor-exit v0
const/4 p1, 0x1
return p1
:cond_20
add-int/lit8 v2, v2, 0x1
goto :goto_9
.line 7
:cond_23
monitor-exit v0
return v1
:catchall_25
move-exception p1
.line 8
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/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v0
.line 2
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 3
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 4
iget-object v1, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v1
.line 5
: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 6
monitor-exit v1
:try_end_15
.catchall {:try_start_10 .. :try_end_15} :catchall_70
.line 7
invoke-virtual {v0, v2}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 8
: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 9
: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 10
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 11
invoke-interface {p1}, Lcom/facebook/binaryresource/BinaryResource;->size()J
move-result-wide v2
invoke-virtual {v0, v2, v3}, Lcom/facebook/cache/disk/SettableCacheEvent;->setItemSize(J)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p2
iget-object v2, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mCacheStats:Lcom/facebook/cache/disk/DiskStorageCache$CacheStats;
.line 12
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 13
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 14
:try_start_39
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_46
.line 15
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 16
:cond_46
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return-object p1
:catchall_4a
move-exception p1
.line 17
:try_start_4b
invoke-interface {v1}, Lcom/facebook/cache/disk/DiskStorage$Inserter;->cleanUp()Z
move-result p2
if-nez p2, :cond_58
.line 18
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 19
: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 20
:try_start_5c
invoke-virtual {v0, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
.line 21
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 22
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 23
throw p1
:try_end_6c
.catchall {:try_start_5c .. :try_end_6c} :catchall_59
.line 24
:goto_6c
invoke-virtual {v0}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
.line 25
throw p1
:catchall_70
move-exception p1
.line 26
: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
.line 1
: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 2
:try_start_5
invoke-static {p1}, Lcom/facebook/cache/common/CacheKeyUtil;->getResourceIds(Lcom/facebook/cache/common/CacheKey;)Ljava/util/List;
move-result-object v3
const/4 v4, 0x0
.line 3
:goto_a
invoke-interface {v3}, Ljava/util/List;->size()I
move-result v5
if-ge v4, v5, :cond_2a
.line 4
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 5
: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 6
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 7
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 8
: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 9
: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 10
:goto_38
invoke-static {}, Lcom/facebook/cache/disk/SettableCacheEvent;->obtain()Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object v2
.line 11
invoke-virtual {v2, p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setCacheKey(Lcom/facebook/cache/common/CacheKey;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
.line 12
invoke-virtual {p1, v5}, Lcom/facebook/cache/disk/SettableCacheEvent;->setResourceId(Ljava/lang/String;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
.line 13
invoke-virtual {p1, v1}, Lcom/facebook/cache/disk/SettableCacheEvent;->setException(Ljava/io/IOException;)Lcom/facebook/cache/disk/SettableCacheEvent;
move-result-object p1
.line 14
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 15
invoke-virtual {p1}, Lcom/facebook/cache/disk/SettableCacheEvent;->recycle()V
return v0
.end method
.method public remove(Lcom/facebook/cache/common/CacheKey;)V
.registers 8
.line 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
: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 3
:goto_8
invoke-interface {p1}, Ljava/util/List;->size()I
move-result v2
if-ge v1, v2, :cond_42
.line 4
invoke-interface {p1, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
.line 5
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 6
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 7
: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 8
invoke-virtual {p1}, Ljava/lang/Throwable;->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 9
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 10
: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 1
iget-object v0, p0, Lcom/facebook/cache/disk/DiskStorageCache;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
invoke-direct {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->maybeUpdateFileCacheSize()Z
.line 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;->getSize()J
move-result-wide v1
.line 4
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 v7, v1, v5
if-lez v7, :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 v3, v5, v1
if-lez v3, :cond_2f
.line 5
invoke-direct {p0, v5, v6}, Lcom/facebook/cache/disk/DiskStorageCache;->trimBy(D)V
.line 6
:cond_2f
monitor-exit v0
return-void
.line 7
:cond_31
:goto_31
monitor-exit v0
return-void
:catchall_33
move-exception v1
.line 8
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
invoke-virtual {p0}, Lcom/facebook/cache/disk/DiskStorageCache;->clearAll()V
return-void
.end method