DefaultDiskStorage$InserterImpl.smali
.class Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;
.super Ljava/lang/Object;
.source "DefaultDiskStorage.java"
# interfaces
.implements Lcom/facebook/cache/disk/DiskStorage$Inserter;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/facebook/cache/disk/DefaultDiskStorage;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x0
name = "InserterImpl"
.end annotation
# instance fields
.field private final mResourceId:Ljava/lang/String;
.field final mTemporaryFile:Ljava/io/File;
.field final synthetic this$0:Lcom/facebook/cache/disk/DefaultDiskStorage;
# direct methods
.method public constructor <init>(Lcom/facebook/cache/disk/DefaultDiskStorage;Ljava/lang/String;Ljava/io/File;)V
.registers 4
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x8010,
0x0,
0x0
}
names = {
"this$0",
"resourceId",
"temporaryFile"
}
.end annotation
.line 632
iput-object p1, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->this$0:Lcom/facebook/cache/disk/DefaultDiskStorage;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 633
iput-object p2, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mResourceId:Ljava/lang/String;
.line 634
iput-object p3, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mTemporaryFile:Ljava/io/File;
return-void
.end method
# virtual methods
.method public cleanUp()Z
.registers 2
.line 708
iget-object v0, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mTemporaryFile:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_13
iget-object v0, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mTemporaryFile:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->delete()Z
move-result v0
if-eqz v0, :cond_11
goto :goto_13
:cond_11
const/4 v0, 0x0
goto :goto_14
:cond_13
:goto_13
const/4 v0, 0x1
:goto_14
return v0
.end method
.method public commit(Ljava/lang/Object;)Lcom/facebook/binaryresource/BinaryResource;
.registers 4
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"debugInfo"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 674
iget-object v0, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->this$0:Lcom/facebook/cache/disk/DefaultDiskStorage;
# getter for: Lcom/facebook/cache/disk/DefaultDiskStorage;->mClock:Lcom/facebook/common/time/Clock;
invoke-static {v0}, Lcom/facebook/cache/disk/DefaultDiskStorage;->access$400(Lcom/facebook/cache/disk/DefaultDiskStorage;)Lcom/facebook/common/time/Clock;
move-result-object v0
invoke-interface {v0}, Lcom/facebook/common/time/Clock;->now()J
move-result-wide v0
invoke-virtual {p0, p1, v0, v1}, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->commit(Ljava/lang/Object;J)Lcom/facebook/binaryresource/BinaryResource;
move-result-object p1
return-object p1
.end method
.method public commit(Ljava/lang/Object;J)Lcom/facebook/binaryresource/BinaryResource;
.registers 6
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0
}
names = {
"debugInfo",
"time"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 680
iget-object p1, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->this$0:Lcom/facebook/cache/disk/DefaultDiskStorage;
iget-object v0, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mResourceId:Ljava/lang/String;
invoke-virtual {p1, v0}, Lcom/facebook/cache/disk/DefaultDiskStorage;->getContentFileFor(Ljava/lang/String;)Ljava/io/File;
move-result-object p1
.line 683
:try_start_8
iget-object v0, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mTemporaryFile:Ljava/io/File;
invoke-static {v0, p1}, Lcom/facebook/common/file/FileUtils;->rename(Ljava/io/File;Ljava/io/File;)V
:try_end_d
.catch Lcom/facebook/common/file/FileUtils$RenameException; {:try_start_8 .. :try_end_d} :catch_1b
.line 700
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_16
.line 701
invoke-virtual {p1, p2, p3}, Ljava/io/File;->setLastModified(J)Z
.line 703
:cond_16
invoke-static {p1}, Lcom/facebook/binaryresource/FileBinaryResource;->create(Ljava/io/File;)Lcom/facebook/binaryresource/FileBinaryResource;
move-result-object p1
return-object p1
:catch_1b
move-exception p1
.line 686
invoke-virtual {p1}, Lcom/facebook/common/file/FileUtils$RenameException;->getCause()Ljava/lang/Throwable;
move-result-object p2
if-eqz p2, :cond_33
.line 689
instance-of p3, p2, Lcom/facebook/common/file/FileUtils$ParentDirNotFoundException;
if-nez p3, :cond_30
.line 692
instance-of p2, p2, Ljava/io/FileNotFoundException;
if-eqz p2, :cond_2d
.line 693
sget-object p2, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->WRITE_RENAME_FILE_TEMPFILE_NOT_FOUND:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
goto :goto_35
.line 695
:cond_2d
sget-object p2, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->WRITE_RENAME_FILE_OTHER:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
goto :goto_35
.line 690
:cond_30
sget-object p2, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->WRITE_RENAME_FILE_TEMPFILE_PARENT_NOT_FOUND:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
goto :goto_35
.line 688
:cond_33
sget-object p2, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->WRITE_RENAME_FILE_OTHER:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
.line 697
:goto_35
iget-object p3, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->this$0:Lcom/facebook/cache/disk/DefaultDiskStorage;
# getter for: Lcom/facebook/cache/disk/DefaultDiskStorage;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
invoke-static {p3}, Lcom/facebook/cache/disk/DefaultDiskStorage;->access$1000(Lcom/facebook/cache/disk/DefaultDiskStorage;)Lcom/facebook/cache/common/CacheErrorLogger;
move-result-object p3
# getter for: Lcom/facebook/cache/disk/DefaultDiskStorage;->TAG:Ljava/lang/Class;
invoke-static {}, Lcom/facebook/cache/disk/DefaultDiskStorage;->access$900()Ljava/lang/Class;
move-result-object v0
const-string v1, "commit"
invoke-interface {p3, p2, v0, v1, p1}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 698
throw p1
.end method
.method public writeData(Lcom/facebook/cache/common/WriterCallback;Ljava/lang/Object;)V
.registers 7
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0
}
names = {
"callback",
"debugInfo"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 641
:try_start_0
new-instance p2, Ljava/io/FileOutputStream;
iget-object v0, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mTemporaryFile:Ljava/io/File;
invoke-direct {p2, v0}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
:try_end_7
.catch Ljava/io/FileNotFoundException; {:try_start_0 .. :try_end_7} :catch_35
.line 653
:try_start_7
new-instance v0, Lcom/facebook/common/internal/CountingOutputStream;
invoke-direct {v0, p2}, Lcom/facebook/common/internal/CountingOutputStream;-><init>(Ljava/io/OutputStream;)V
.line 654
invoke-interface {p1, v0}, Lcom/facebook/cache/common/WriterCallback;->write(Ljava/io/OutputStream;)V
.line 657
invoke-virtual {v0}, Lcom/facebook/common/internal/CountingOutputStream;->flush()V
.line 658
invoke-virtual {v0}, Lcom/facebook/common/internal/CountingOutputStream;->getCount()J
move-result-wide v0
:try_end_16
.catchall {:try_start_7 .. :try_end_16} :catchall_30
.line 663
invoke-virtual {p2}, Ljava/io/FileOutputStream;->close()V
.line 667
iget-object p1, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mTemporaryFile:Ljava/io/File;
invoke-virtual {p1}, Ljava/io/File;->length()J
move-result-wide p1
cmp-long p1, p1, v0
if-nez p1, :cond_24
return-void
.line 668
:cond_24
new-instance p1, Lcom/facebook/cache/disk/DefaultDiskStorage$IncompleteFileException;
iget-object p2, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->mTemporaryFile:Ljava/io/File;
invoke-virtual {p2}, Ljava/io/File;->length()J
move-result-wide v2
invoke-direct {p1, v0, v1, v2, v3}, Lcom/facebook/cache/disk/DefaultDiskStorage$IncompleteFileException;-><init>(JJ)V
throw p1
:catchall_30
move-exception p1
.line 663
invoke-virtual {p2}, Ljava/io/FileOutputStream;->close()V
.line 664
throw p1
:catch_35
move-exception p1
.line 643
iget-object p2, p0, Lcom/facebook/cache/disk/DefaultDiskStorage$InserterImpl;->this$0:Lcom/facebook/cache/disk/DefaultDiskStorage;
# getter for: Lcom/facebook/cache/disk/DefaultDiskStorage;->mCacheErrorLogger:Lcom/facebook/cache/common/CacheErrorLogger;
invoke-static {p2}, Lcom/facebook/cache/disk/DefaultDiskStorage;->access$1000(Lcom/facebook/cache/disk/DefaultDiskStorage;)Lcom/facebook/cache/common/CacheErrorLogger;
move-result-object p2
sget-object v0, Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;->WRITE_UPDATE_FILE_NOT_FOUND:Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;
.line 645
# getter for: Lcom/facebook/cache/disk/DefaultDiskStorage;->TAG:Ljava/lang/Class;
invoke-static {}, Lcom/facebook/cache/disk/DefaultDiskStorage;->access$900()Ljava/lang/Class;
move-result-object v1
const-string v2, "updateResource"
.line 643
invoke-interface {p2, v0, v1, v2, p1}, Lcom/facebook/cache/common/CacheErrorLogger;->logError(Lcom/facebook/cache/common/CacheErrorLogger$CacheErrorCategory;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 648
throw p1
.end method