LogFileManager.smali
.class public Lcom/google/firebase/crashlytics/internal/log/LogFileManager;
.super Ljava/lang/Object;
.source "LogFileManager.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/google/firebase/crashlytics/internal/log/LogFileManager$NoopLogStore;,
Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;
}
.end annotation
# static fields
.field private static final COLLECT_CUSTOM_LOGS:Ljava/lang/String; = "com.crashlytics.CollectCustomLogs"
.field private static final LOGFILE_EXT:Ljava/lang/String; = ".temp"
.field private static final LOGFILE_PREFIX:Ljava/lang/String; = "crashlytics-userlog-"
.field static final MAX_LOG_SIZE:I = 0x10000
.field private static final NOOP_LOG_STORE:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$NoopLogStore;
# instance fields
.field private final context:Landroid/content/Context;
.field private currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
.field private final directoryProvider:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;
# direct methods
.method static constructor <clinit>()V
.registers 2
.line 34
new-instance v0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager$NoopLogStore;
const/4 v1, 0x0
invoke-direct {v0, v1}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager$NoopLogStore;-><init>(Lcom/google/firebase/crashlytics/internal/log/LogFileManager$1;)V
sput-object v0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->NOOP_LOG_STORE:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$NoopLogStore;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;)V
.registers 4
const/4 v0, 0x0
.line 48
invoke-direct {p0, p1, p2, v0}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;-><init>(Landroid/content/Context;Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;Ljava/lang/String;)V
return-void
.end method
.method public constructor <init>(Landroid/content/Context;Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;Ljava/lang/String;)V
.registers 4
.line 52
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 53
iput-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->context:Landroid/content/Context;
.line 54
iput-object p2, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->directoryProvider:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;
.line 55
sget-object p1, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->NOOP_LOG_STORE:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$NoopLogStore;
iput-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
.line 56
invoke-virtual {p0, p3}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->setCurrentSession(Ljava/lang/String;)V
return-void
.end method
.method private getSessionIdForFile(Ljava/io/File;)Ljava/lang/String;
.registers 4
.line 129
invoke-virtual {p1}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object p1
const-string v0, ".temp"
.line 130
invoke-virtual {p1, v0}, Ljava/lang/String;->lastIndexOf(Ljava/lang/String;)I
move-result v0
const/4 v1, -0x1
if-ne v0, v1, :cond_e
return-object p1
:cond_e
const/16 v1, 0x14
.line 134
invoke-virtual {p1, v1, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private getWorkingFileForSession(Ljava/lang/String;)Ljava/io/File;
.registers 4
.line 124
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "crashlytics-userlog-"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, ".temp"
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 125
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->directoryProvider:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;
invoke-interface {v1}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;->getLogFileDir()Ljava/io/File;
move-result-object v1
invoke-direct {v0, v1, p1}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
return-object v0
.end method
# virtual methods
.method public clearLog()V
.registers 2
.line 99
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
invoke-interface {v0}, Lcom/google/firebase/crashlytics/internal/log/FileLogStore;->deleteLogFile()V
return-void
.end method
.method public discardOldLogFiles(Ljava/util/Set;)V
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Set<",
"Ljava/lang/String;",
">;)V"
}
.end annotation
.line 108
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->directoryProvider:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;
invoke-interface {v0}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager$DirectoryProvider;->getLogFileDir()Ljava/io/File;
move-result-object v0
invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v0
if-eqz v0, :cond_22
.line 110
array-length v1, v0
const/4 v2, 0x0
:goto_e
if-ge v2, v1, :cond_22
aget-object v3, v0, v2
.line 111
invoke-direct {p0, v3}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->getSessionIdForFile(Ljava/io/File;)Ljava/lang/String;
move-result-object v4
invoke-interface {p1, v4}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v4
if-nez v4, :cond_1f
.line 112
invoke-virtual {v3}, Ljava/io/File;->delete()Z
:cond_1f
add-int/lit8 v2, v2, 0x1
goto :goto_e
:cond_22
return-void
.end method
.method public getBytesForLog()[B
.registers 2
.line 89
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
invoke-interface {v0}, Lcom/google/firebase/crashlytics/internal/log/FileLogStore;->getLogAsBytes()[B
move-result-object v0
return-object v0
.end method
.method public getLogString()Ljava/lang/String;
.registers 2
.line 94
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
invoke-interface {v0}, Lcom/google/firebase/crashlytics/internal/log/FileLogStore;->getLogAsString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public final setCurrentSession(Ljava/lang/String;)V
.registers 5
.line 65
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
invoke-interface {v0}, Lcom/google/firebase/crashlytics/internal/log/FileLogStore;->closeLogFile()V
.line 66
sget-object v0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->NOOP_LOG_STORE:Lcom/google/firebase/crashlytics/internal/log/LogFileManager$NoopLogStore;
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
if-nez p1, :cond_c
return-void
.line 72
:cond_c
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->context:Landroid/content/Context;
const/4 v1, 0x1
const-string v2, "com.crashlytics.CollectCustomLogs"
.line 73
invoke-static {v0, v2, v1}, Lcom/google/firebase/crashlytics/internal/common/CommonUtils;->getBooleanResourceValue(Landroid/content/Context;Ljava/lang/String;Z)Z
move-result v0
if-nez v0, :cond_21
.line 76
invoke-static {}, Lcom/google/firebase/crashlytics/internal/Logger;->getLogger()Lcom/google/firebase/crashlytics/internal/Logger;
move-result-object p1
const-string v0, "Preferences requested no custom logs. Aborting log file creation."
invoke-virtual {p1, v0}, Lcom/google/firebase/crashlytics/internal/Logger;->d(Ljava/lang/String;)V
return-void
.line 80
:cond_21
invoke-direct {p0, p1}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->getWorkingFileForSession(Ljava/lang/String;)Ljava/io/File;
move-result-object p1
const/high16 v0, 0x10000
invoke-virtual {p0, p1, v0}, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->setLogFile(Ljava/io/File;I)V
return-void
.end method
.method setLogFile(Ljava/io/File;I)V
.registers 4
.line 120
new-instance v0, Lcom/google/firebase/crashlytics/internal/log/QueueFileLogStore;
invoke-direct {v0, p1, p2}, Lcom/google/firebase/crashlytics/internal/log/QueueFileLogStore;-><init>(Ljava/io/File;I)V
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
return-void
.end method
.method public writeToLog(JLjava/lang/String;)V
.registers 5
.line 85
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/LogFileManager;->currentLog:Lcom/google/firebase/crashlytics/internal/log/FileLogStore;
invoke-interface {v0, p1, p2, p3}, Lcom/google/firebase/crashlytics/internal/log/FileLogStore;->writeToLog(JLjava/lang/String;)V
return-void
.end method