FileLruCache.smali
.class public final Lcom/facebook/internal/FileLruCache;
.super Ljava/lang/Object;
.source "FileLruCache.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/facebook/internal/FileLruCache$StreamCloseCallback;,
Lcom/facebook/internal/FileLruCache$ModifiedFile;,
Lcom/facebook/internal/FileLruCache$Limits;,
Lcom/facebook/internal/FileLruCache$CopyingInputStream;,
Lcom/facebook/internal/FileLruCache$CloseCallbackOutputStream;,
Lcom/facebook/internal/FileLruCache$StreamHeader;,
Lcom/facebook/internal/FileLruCache$BufferFile;
}
.end annotation
# static fields
.field private static final HEADER_CACHEKEY_KEY:Ljava/lang/String; = "key"
.field private static final HEADER_CACHE_CONTENT_TAG_KEY:Ljava/lang/String; = "tag"
.field static final TAG:Ljava/lang/String;
.field private static final bufferIndex:Ljava/util/concurrent/atomic/AtomicLong;
# instance fields
.field private final directory:Ljava/io/File;
.field private isTrimInProgress:Z
.field private isTrimPending:Z
.field private lastClearCacheTime:Ljava/util/concurrent/atomic/AtomicLong;
.field private final limits:Lcom/facebook/internal/FileLruCache$Limits;
.field private final lock:Ljava/lang/Object;
.field private final tag:Ljava/lang/String;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 68
const-class v0, Lcom/facebook/internal/FileLruCache;
invoke-virtual {v0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/facebook/internal/FileLruCache;->TAG:Ljava/lang/String;
.line 72
new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicLong;-><init>()V
sput-object v0, Lcom/facebook/internal/FileLruCache;->bufferIndex:Ljava/util/concurrent/atomic/AtomicLong;
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Lcom/facebook/internal/FileLruCache$Limits;)V
.registers 6
.line 83
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 80
new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;
const-wide/16 v1, 0x0
invoke-direct {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;-><init>(J)V
iput-object v0, p0, Lcom/facebook/internal/FileLruCache;->lastClearCacheTime:Ljava/util/concurrent/atomic/AtomicLong;
.line 84
iput-object p1, p0, Lcom/facebook/internal/FileLruCache;->tag:Ljava/lang/String;
.line 85
iput-object p2, p0, Lcom/facebook/internal/FileLruCache;->limits:Lcom/facebook/internal/FileLruCache$Limits;
.line 86
new-instance p2, Ljava/io/File;
invoke-static {}, Lcom/facebook/FacebookSdk;->getCacheDir()Ljava/io/File;
move-result-object v0
invoke-direct {p2, v0, p1}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
iput-object p2, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
.line 87
new-instance p1, Ljava/lang/Object;
invoke-direct {p1}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
.line 90
iget-object p1, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-virtual {p1}, Ljava/io/File;->mkdirs()Z
move-result p1
if-nez p1, :cond_32
iget-object p1, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-virtual {p1}, Ljava/io/File;->isDirectory()Z
move-result p1
if-eqz p1, :cond_37
.line 92
:cond_32
iget-object p1, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-static {p1}, Lcom/facebook/internal/FileLruCache$BufferFile;->deleteAll(Ljava/io/File;)V
:cond_37
return-void
.end method
.method static synthetic access$000(Lcom/facebook/internal/FileLruCache;)Ljava/util/concurrent/atomic/AtomicLong;
.registers 1
.line 67
iget-object p0, p0, Lcom/facebook/internal/FileLruCache;->lastClearCacheTime:Ljava/util/concurrent/atomic/AtomicLong;
return-object p0
.end method
.method static synthetic access$100(Lcom/facebook/internal/FileLruCache;Ljava/lang/String;Ljava/io/File;)V
.registers 3
.line 67
invoke-direct {p0, p1, p2}, Lcom/facebook/internal/FileLruCache;->renameToTargetAndTrim(Ljava/lang/String;Ljava/io/File;)V
return-void
.end method
.method static synthetic access$200(Lcom/facebook/internal/FileLruCache;)V
.registers 1
.line 67
invoke-direct {p0}, Lcom/facebook/internal/FileLruCache;->trim()V
return-void
.end method
.method static synthetic access$300()Ljava/util/concurrent/atomic/AtomicLong;
.registers 1
.line 67
sget-object v0, Lcom/facebook/internal/FileLruCache;->bufferIndex:Ljava/util/concurrent/atomic/AtomicLong;
return-object v0
.end method
.method private postTrim()V
.registers 4
.line 299
iget-object v0, p0, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
monitor-enter v0
.line 300
:try_start_3
iget-boolean v1, p0, Lcom/facebook/internal/FileLruCache;->isTrimPending:Z
if-nez v1, :cond_16
const/4 v1, 0x1
.line 301
iput-boolean v1, p0, Lcom/facebook/internal/FileLruCache;->isTrimPending:Z
.line 302
invoke-static {}, Lcom/facebook/FacebookSdk;->getExecutor()Ljava/util/concurrent/Executor;
move-result-object v1
new-instance v2, Lcom/facebook/internal/FileLruCache$3;
invoke-direct {v2, p0}, Lcom/facebook/internal/FileLruCache$3;-><init>(Lcom/facebook/internal/FileLruCache;)V
invoke-interface {v1, v2}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
.line 309
:cond_16
monitor-exit v0
return-void
:catchall_18
move-exception v1
monitor-exit v0
:try_end_1a
.catchall {:try_start_3 .. :try_end_1a} :catchall_18
throw v1
.end method
.method private renameToTargetAndTrim(Ljava/lang/String;Ljava/io/File;)V
.registers 5
.line 271
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-static {p1}, Lcom/facebook/internal/Utility;->md5hash(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-direct {v0, v1, p1}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 279
invoke-virtual {p2, v0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
move-result p1
if-nez p1, :cond_14
.line 280
invoke-virtual {p2}, Ljava/io/File;->delete()Z
.line 283
:cond_14
invoke-direct {p0}, Lcom/facebook/internal/FileLruCache;->postTrim()V
return-void
.end method
.method private trim()V
.registers 17
move-object/from16 v1, p0
.line 313
iget-object v2, v1, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
monitor-enter v2
const/4 v3, 0x0
.line 314
:try_start_6
iput-boolean v3, v1, Lcom/facebook/internal/FileLruCache;->isTrimPending:Z
const/4 v0, 0x1
.line 315
iput-boolean v0, v1, Lcom/facebook/internal/FileLruCache;->isTrimInProgress:Z
.line 316
monitor-exit v2
:try_end_c
.catchall {:try_start_6 .. :try_end_c} :catchall_df
.line 318
:try_start_c
sget-object v0, Lcom/facebook/LoggingBehavior;->CACHE:Lcom/facebook/LoggingBehavior;
sget-object v2, Lcom/facebook/internal/FileLruCache;->TAG:Ljava/lang/String;
const-string/jumbo v4, "trim started"
invoke-static {v0, v2, v4}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
.line 319
new-instance v0, Ljava/util/PriorityQueue;
invoke-direct {v0}, Ljava/util/PriorityQueue;-><init>()V
.line 322
iget-object v2, v1, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-static {}, Lcom/facebook/internal/FileLruCache$BufferFile;->excludeBufferFiles()Ljava/io/FilenameFilter;
move-result-object v4
invoke-virtual {v2, v4}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;
move-result-object v2
const-wide/16 v6, 0x0
if-eqz v2, :cond_74
.line 324
array-length v8, v2
move-wide v9, v6
const/4 v11, 0x0
:goto_2c
if-ge v11, v8, :cond_75
aget-object v12, v2, v11
.line 325
new-instance v13, Lcom/facebook/internal/FileLruCache$ModifiedFile;
invoke-direct {v13, v12}, Lcom/facebook/internal/FileLruCache$ModifiedFile;-><init>(Ljava/io/File;)V
.line 326
invoke-virtual {v0, v13}, Ljava/util/PriorityQueue;->add(Ljava/lang/Object;)Z
.line 327
sget-object v14, Lcom/facebook/LoggingBehavior;->CACHE:Lcom/facebook/LoggingBehavior;
sget-object v15, Lcom/facebook/internal/FileLruCache;->TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, " trim considering time="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 330
invoke-virtual {v13}, Lcom/facebook/internal/FileLruCache$ModifiedFile;->getModified()J
move-result-wide v4
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v4, " name="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 331
invoke-virtual {v13}, Lcom/facebook/internal/FileLruCache$ModifiedFile;->getFile()Ljava/io/File;
move-result-object v4
invoke-virtual {v4}, Ljava/io/File;->getName()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 327
invoke-static {v14, v15, v3}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
.line 333
invoke-virtual {v12}, Ljava/io/File;->length()J
move-result-wide v3
add-long/2addr v6, v3
const-wide/16 v3, 0x1
add-long/2addr v9, v3
add-int/lit8 v11, v11, 0x1
const/4 v3, 0x0
goto :goto_2c
:cond_74
move-wide v9, v6
.line 338
:cond_75
:goto_75
iget-object v2, v1, Lcom/facebook/internal/FileLruCache;->limits:Lcom/facebook/internal/FileLruCache$Limits;
invoke-virtual {v2}, Lcom/facebook/internal/FileLruCache$Limits;->getByteCount()I
move-result v2
int-to-long v2, v2
cmp-long v4, v6, v2
if-gtz v4, :cond_9c
iget-object v2, v1, Lcom/facebook/internal/FileLruCache;->limits:Lcom/facebook/internal/FileLruCache$Limits;
invoke-virtual {v2}, Lcom/facebook/internal/FileLruCache$Limits;->getFileCount()I
move-result v2
:try_end_86
.catchall {:try_start_c .. :try_end_86} :catchall_ce
int-to-long v2, v2
cmp-long v4, v9, v2
if-lez v4, :cond_8c
goto :goto_9c
.line 346
:cond_8c
iget-object v2, v1, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
monitor-enter v2
const/4 v3, 0x0
.line 347
:try_start_90
iput-boolean v3, v1, Lcom/facebook/internal/FileLruCache;->isTrimInProgress:Z
.line 348
iget-object v0, v1, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->notifyAll()V
.line 349
monitor-exit v2
return-void
:catchall_99
move-exception v0
monitor-exit v2
:try_end_9b
.catchall {:try_start_90 .. :try_end_9b} :catchall_99
throw v0
.line 339
:cond_9c
:goto_9c
:try_start_9c
invoke-virtual {v0}, Ljava/util/PriorityQueue;->remove()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/facebook/internal/FileLruCache$ModifiedFile;
invoke-virtual {v2}, Lcom/facebook/internal/FileLruCache$ModifiedFile;->getFile()Ljava/io/File;
move-result-object v2
.line 340
sget-object v3, Lcom/facebook/LoggingBehavior;->CACHE:Lcom/facebook/LoggingBehavior;
sget-object v4, Lcom/facebook/internal/FileLruCache;->TAG:Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v8, " trim removing "
invoke-virtual {v5, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v8
invoke-virtual {v5, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v3, v4, v5}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
.line 341
invoke-virtual {v2}, Ljava/io/File;->length()J
move-result-wide v3
sub-long/2addr v6, v3
const-wide/16 v3, 0x1
sub-long/2addr v9, v3
.line 343
invoke-virtual {v2}, Ljava/io/File;->delete()Z
:try_end_cd
.catchall {:try_start_9c .. :try_end_cd} :catchall_ce
goto :goto_75
:catchall_ce
move-exception v0
.line 346
iget-object v3, v1, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
monitor-enter v3
const/4 v2, 0x0
.line 347
:try_start_d3
iput-boolean v2, v1, Lcom/facebook/internal/FileLruCache;->isTrimInProgress:Z
.line 348
iget-object v2, v1, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
invoke-virtual {v2}, Ljava/lang/Object;->notifyAll()V
.line 349
monitor-exit v3
:try_end_db
.catchall {:try_start_d3 .. :try_end_db} :catchall_dc
.line 350
throw v0
:catchall_dc
move-exception v0
.line 349
:try_start_dd
monitor-exit v3
:try_end_de
.catchall {:try_start_dd .. :try_end_de} :catchall_dc
throw v0
:catchall_df
move-exception v0
.line 316
:try_start_e0
monitor-exit v2
:try_end_e1
.catchall {:try_start_e0 .. :try_end_e1} :catchall_df
throw v0
.end method
# virtual methods
.method public clearCache()V
.registers 5
.line 248
iget-object v0, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-static {}, Lcom/facebook/internal/FileLruCache$BufferFile;->excludeBufferFiles()Ljava/io/FilenameFilter;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;
move-result-object v0
.line 249
iget-object v1, p0, Lcom/facebook/internal/FileLruCache;->lastClearCacheTime:Ljava/util/concurrent/atomic/AtomicLong;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
invoke-virtual {v1, v2, v3}, Ljava/util/concurrent/atomic/AtomicLong;->set(J)V
if-eqz v0, :cond_21
.line 251
invoke-static {}, Lcom/facebook/FacebookSdk;->getExecutor()Ljava/util/concurrent/Executor;
move-result-object v1
new-instance v2, Lcom/facebook/internal/FileLruCache$2;
invoke-direct {v2, p0, v0}, Lcom/facebook/internal/FileLruCache$2;-><init>(Lcom/facebook/internal/FileLruCache;[Ljava/io/File;)V
invoke-interface {v1, v2}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
:cond_21
return-void
.end method
.method public get(Ljava/lang/String;)Ljava/io/InputStream;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const/4 v0, 0x0
.line 124
invoke-virtual {p0, p1, v0}, Lcom/facebook/internal/FileLruCache;->get(Ljava/lang/String;Ljava/lang/String;)Ljava/io/InputStream;
move-result-object p1
return-object p1
.end method
.method public get(Ljava/lang/String;Ljava/lang/String;)Ljava/io/InputStream;
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 128
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-static {p1}, Lcom/facebook/internal/Utility;->md5hash(Ljava/lang/String;)Ljava/lang/String;
move-result-object v2
invoke-direct {v0, v1, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
const/4 v1, 0x0
.line 132
:try_start_c
new-instance v2, Ljava/io/FileInputStream;
invoke-direct {v2, v0}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
:try_end_11
.catch Ljava/io/IOException; {:try_start_c .. :try_end_11} :catch_85
.line 137
new-instance v3, Ljava/io/BufferedInputStream;
const/16 v4, 0x2000
invoke-direct {v3, v2, v4}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;I)V
.line 142
:try_start_18
invoke-static {v3}, Lcom/facebook/internal/FileLruCache$StreamHeader;->readHeader(Ljava/io/InputStream;)Lorg/json/JSONObject;
move-result-object v2
:try_end_1c
.catchall {:try_start_18 .. :try_end_1c} :catchall_80
if-nez v2, :cond_22
.line 171
invoke-virtual {v3}, Ljava/io/BufferedInputStream;->close()V
return-object v1
:cond_22
:try_start_22
const-string v4, "key"
.line 147
invoke-virtual {v2, v4}, Lorg/json/JSONObject;->optString(Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
if-eqz v4, :cond_7c
.line 148
invoke-virtual {v4, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-nez p1, :cond_31
goto :goto_7c
:cond_31
const-string p1, "tag"
.line 152
invoke-virtual {v2, p1, v1}, Lorg/json/JSONObject;->optString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
if-nez p2, :cond_3b
if-nez p1, :cond_43
:cond_3b
if-eqz p2, :cond_47
.line 155
invoke-virtual {p2, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
:try_end_41
.catchall {:try_start_22 .. :try_end_41} :catchall_80
if-nez p1, :cond_47
.line 171
:cond_43
invoke-virtual {v3}, Ljava/io/BufferedInputStream;->close()V
return-object v1
.line 159
:cond_47
:try_start_47
new-instance p1, Ljava/util/Date;
invoke-direct {p1}, Ljava/util/Date;-><init>()V
invoke-virtual {p1}, Ljava/util/Date;->getTime()J
move-result-wide p1
.line 160
sget-object v1, Lcom/facebook/LoggingBehavior;->CACHE:Lcom/facebook/LoggingBehavior;
sget-object v2, Lcom/facebook/internal/FileLruCache;->TAG:Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Setting lastModified to "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 163
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v5, " for "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 164
invoke-virtual {v0}, Ljava/io/File;->getName()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 160
invoke-static {v1, v2, v4}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
.line 165
invoke-virtual {v0, p1, p2}, Ljava/io/File;->setLastModified(J)Z
:try_end_7b
.catchall {:try_start_47 .. :try_end_7b} :catchall_80
return-object v3
.line 171
:cond_7c
:goto_7c
invoke-virtual {v3}, Ljava/io/BufferedInputStream;->close()V
return-object v1
:catchall_80
move-exception p1
invoke-virtual {v3}, Ljava/io/BufferedInputStream;->close()V
.line 173
throw p1
:catch_85
return-object v1
.end method
.method public getLocation()Ljava/lang/String;
.registers 2
.line 267
iget-object v0, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public interceptAndPut(Ljava/lang/String;Ljava/io/InputStream;)Ljava/io/InputStream;
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 290
invoke-virtual {p0, p1}, Lcom/facebook/internal/FileLruCache;->openPutStream(Ljava/lang/String;)Ljava/io/OutputStream;
move-result-object p1
.line 291
new-instance v0, Lcom/facebook/internal/FileLruCache$CopyingInputStream;
invoke-direct {v0, p2, p1}, Lcom/facebook/internal/FileLruCache$CopyingInputStream;-><init>(Ljava/io/InputStream;Ljava/io/OutputStream;)V
return-object v0
.end method
.method public openPutStream(Ljava/lang/String;)Ljava/io/OutputStream;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
const/4 v0, 0x0
.line 177
invoke-virtual {p0, p1, v0}, Lcom/facebook/internal/FileLruCache;->openPutStream(Ljava/lang/String;Ljava/lang/String;)Ljava/io/OutputStream;
move-result-object p1
return-object p1
.end method
.method public openPutStream(Ljava/lang/String;Ljava/lang/String;)Ljava/io/OutputStream;
.registers 12
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 181
iget-object v0, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-static {v0}, Lcom/facebook/internal/FileLruCache$BufferFile;->newFile(Ljava/io/File;)Ljava/io/File;
move-result-object v5
.line 182
invoke-virtual {v5}, Ljava/io/File;->delete()Z
.line 183
invoke-virtual {v5}, Ljava/io/File;->createNewFile()Z
move-result v0
if-eqz v0, :cond_92
const/4 v0, 0x5
.line 189
:try_start_10
new-instance v7, Ljava/io/FileOutputStream;
invoke-direct {v7, v5}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
:try_end_15
.catch Ljava/io/FileNotFoundException; {:try_start_10 .. :try_end_15} :catch_6f
.line 199
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v3
.line 200
new-instance v8, Lcom/facebook/internal/FileLruCache$1;
move-object v1, v8
move-object v2, p0
move-object v6, p1
invoke-direct/range {v1 .. v6}, Lcom/facebook/internal/FileLruCache$1;-><init>(Lcom/facebook/internal/FileLruCache;JLjava/io/File;Ljava/lang/String;)V
.line 213
new-instance v1, Lcom/facebook/internal/FileLruCache$CloseCallbackOutputStream;
invoke-direct {v1, v7, v8}, Lcom/facebook/internal/FileLruCache$CloseCallbackOutputStream;-><init>(Ljava/io/OutputStream;Lcom/facebook/internal/FileLruCache$StreamCloseCallback;)V
.line 215
new-instance v2, Ljava/io/BufferedOutputStream;
const/16 v3, 0x2000
invoke-direct {v2, v1, v3}, Ljava/io/BufferedOutputStream;-><init>(Ljava/io/OutputStream;I)V
.line 221
:try_start_2d
new-instance v1, Lorg/json/JSONObject;
invoke-direct {v1}, Lorg/json/JSONObject;-><init>()V
const-string v3, "key"
.line 222
invoke-virtual {v1, v3, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 223
invoke-static {p2}, Lcom/facebook/internal/Utility;->isNullOrEmpty(Ljava/lang/String;)Z
move-result p1
if-nez p1, :cond_42
const-string p1, "tag"
.line 224
invoke-virtual {v1, p1, p2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 227
:cond_42
invoke-static {v2, v1}, Lcom/facebook/internal/FileLruCache$StreamHeader;->writeHeader(Ljava/io/OutputStream;Lorg/json/JSONObject;)V
:try_end_45
.catch Lorg/json/JSONException; {:try_start_2d .. :try_end_45} :catch_48
.catchall {:try_start_2d .. :try_end_45} :catchall_46
return-object v2
:catchall_46
move-exception p1
goto :goto_6b
:catch_48
move-exception p1
.line 233
:try_start_49
sget-object p2, Lcom/facebook/LoggingBehavior;->CACHE:Lcom/facebook/LoggingBehavior;
sget-object v1, Lcom/facebook/internal/FileLruCache;->TAG:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Error creating JSON header for cache file: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {p2, v0, v1, v3}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;ILjava/lang/String;Ljava/lang/String;)V
.line 238
new-instance p2, Ljava/io/IOException;
invoke-virtual {p1}, Lorg/json/JSONException;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p2
:try_end_6b
.catchall {:try_start_49 .. :try_end_6b} :catchall_46
.line 241
:goto_6b
invoke-virtual {v2}, Ljava/io/BufferedOutputStream;->close()V
.line 243
throw p1
:catch_6f
move-exception p1
.line 191
sget-object p2, Lcom/facebook/LoggingBehavior;->CACHE:Lcom/facebook/LoggingBehavior;
sget-object v1, Lcom/facebook/internal/FileLruCache;->TAG:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Error creating buffer output stream: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {p2, v0, v1, v2}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;ILjava/lang/String;Ljava/lang/String;)V
.line 196
new-instance p2, Ljava/io/IOException;
invoke-virtual {p1}, Ljava/io/FileNotFoundException;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p2
.line 184
:cond_92
new-instance p1, Ljava/io/IOException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Could not create file at "
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method sizeInBytesForTest()J
.registers 8
.line 103
iget-object v0, p0, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
monitor-enter v0
.line 104
:catch_3
:goto_3
:try_start_3
iget-boolean v1, p0, Lcom/facebook/internal/FileLruCache;->isTrimPending:Z
if-nez v1, :cond_26
iget-boolean v1, p0, Lcom/facebook/internal/FileLruCache;->isTrimInProgress:Z
if-eqz v1, :cond_c
goto :goto_26
.line 111
:cond_c
monitor-exit v0
:try_end_d
.catchall {:try_start_3 .. :try_end_d} :catchall_2c
.line 113
iget-object v0, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v0
const-wide/16 v1, 0x0
if-eqz v0, :cond_25
.line 116
array-length v3, v0
const/4 v4, 0x0
:goto_19
if-ge v4, v3, :cond_25
aget-object v5, v0, v4
.line 117
invoke-virtual {v5}, Ljava/io/File;->length()J
move-result-wide v5
add-long/2addr v1, v5
add-int/lit8 v4, v4, 0x1
goto :goto_19
:cond_25
return-wide v1
.line 106
:cond_26
:goto_26
:try_start_26
iget-object v1, p0, Lcom/facebook/internal/FileLruCache;->lock:Ljava/lang/Object;
invoke-virtual {v1}, Ljava/lang/Object;->wait()V
:try_end_2b
.catch Ljava/lang/InterruptedException; {:try_start_26 .. :try_end_2b} :catch_3
.catchall {:try_start_26 .. :try_end_2b} :catchall_2c
goto :goto_3
:catchall_2c
move-exception v1
.line 111
:try_start_2d
monitor-exit v0
:try_end_2e
.catchall {:try_start_2d .. :try_end_2e} :catchall_2c
throw v1
.end method
.method public toString()Ljava/lang/String;
.registers 3
.line 295
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v1, "{FileLruCache: tag:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/facebook/internal/FileLruCache;->tag:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " file:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/facebook/internal/FileLruCache;->directory:Ljava/io/File;
invoke-virtual {v1}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string/jumbo v1, "}"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method