RLogFileProcessor.smali
.class public Lio/rong/common/rlog/RLogFileProcessor;
.super Ljava/lang/Object;
.source "RLogFileProcessor.java"
# static fields
.field private static final TAG:Ljava/lang/String; = "RLogFileProcessor"
# instance fields
.field fileSize:I
.field private volatile isUploading:Z
.field private mCompressor:Lio/rong/common/rlog/Compressor;
.field private mConfig:Lio/rong/common/rlog/RLogConfig;
.field private mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;
.field private mReporter:Lio/rong/common/rlog/RLogReporter;
# direct methods
.method private constructor <init>(Lio/rong/common/rlog/RLogConfig;)V
.registers 4
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
.line 2
iput-boolean v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z
.line 3
iput v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->fileSize:I
.line 4
iput-object p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
.line 5
new-instance v0, Lio/rong/common/rlog/RLogReporter;
invoke-direct {v0}, Lio/rong/common/rlog/RLogReporter;-><init>()V
iput-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mReporter:Lio/rong/common/rlog/RLogReporter;
.line 6
new-instance v0, Lio/rong/common/rlog/LogFileWriter;
invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig;->getFilePath()Ljava/lang/String;
move-result-object p1
new-instance v1, Lio/rong/common/rlog/RLogFileProcessor$1;
invoke-direct {v1, p0}, Lio/rong/common/rlog/RLogFileProcessor$1;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V
invoke-direct {v0, p1, v1}, Lio/rong/common/rlog/LogFileWriter;-><init>(Ljava/lang/String;Lio/rong/common/rlog/LogFileWriter$IWriterListener;)V
iput-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;
.line 7
new-instance p1, Lio/rong/common/rlog/Compressor;
new-instance v0, Lio/rong/common/rlog/RLogFileProcessor$2;
invoke-direct {v0, p0}, Lio/rong/common/rlog/RLogFileProcessor$2;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V
invoke-direct {p1, v0}, Lio/rong/common/rlog/Compressor;-><init>(Lio/rong/common/rlog/Compressor$ICompressListener;)V
iput-object p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mCompressor:Lio/rong/common/rlog/Compressor;
return-void
.end method
.method static synthetic access$000(Lio/rong/common/rlog/RLogFileProcessor;)Lio/rong/common/rlog/RLogConfig;
.registers 1
.line 1
iget-object p0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
return-object p0
.end method
.method static synthetic access$100(Lio/rong/common/rlog/RLogFileProcessor;)Lio/rong/common/rlog/LogFileWriter;
.registers 1
.line 1
iget-object p0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;
return-object p0
.end method
.method static synthetic access$200(Lio/rong/common/rlog/RLogFileProcessor;)Lio/rong/common/rlog/Compressor;
.registers 1
.line 1
iget-object p0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mCompressor:Lio/rong/common/rlog/Compressor;
return-object p0
.end method
.method static synthetic access$300(Lio/rong/common/rlog/RLogFileProcessor;ZLjava/lang/String;Ljava/lang/String;Z)V
.registers 5
.line 1
invoke-direct {p0, p1, p2, p3, p4}, Lio/rong/common/rlog/RLogFileProcessor;->processCompressFinish(ZLjava/lang/String;Ljava/lang/String;Z)V
return-void
.end method
.method static synthetic access$402(Lio/rong/common/rlog/RLogFileProcessor;Z)Z
.registers 2
.line 1
iput-boolean p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z
return p1
.end method
.method public static init(Lio/rong/common/rlog/RLogConfig;)Lio/rong/common/rlog/RLogFileProcessor;
.registers 2
.line 1
new-instance v0, Lio/rong/common/rlog/RLogFileProcessor;
invoke-direct {v0, p0}, Lio/rong/common/rlog/RLogFileProcessor;-><init>(Lio/rong/common/rlog/RLogConfig;)V
return-object v0
.end method
.method private processCompressFinish(ZLjava/lang/String;Ljava/lang/String;Z)V
.registers 11
const-string v0, "processCompressFinish file is:"
const-string v1, "RLogFileProcessor"
if-eqz p1, :cond_84
.line 1
new-instance p1, Ljava/io/File;
invoke-direct {p1, p2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Ljava/io/File;->delete()Z
move-result p1
if-nez p1, :cond_23
.line 2
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v1, p1}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I
.line 3
:cond_23
iget-boolean p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z
if-nez p1, :cond_be
.line 4
iget-object p1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig;->getZipConfig()Lio/rong/common/rlog/RLogConfig$ZipConfig;
move-result-object p1
if-eqz p1, :cond_be
.line 5
new-instance p2, Ljava/io/File;
invoke-direct {p2, p3}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 6
invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getCurrentSize()J
move-result-wide v2
invoke-virtual {p2}, Ljava/io/File;->length()J
move-result-wide v4
add-long/2addr v2, v4
invoke-virtual {p1, v2, v3}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->setCurrentSize(J)V
.line 7
invoke-virtual {p1, p2}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->addFile(Ljava/io/File;)V
.line 8
:cond_43
:goto_43
invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getCurrentSize()J
move-result-wide p2
iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getZipMaxSize()J
move-result-wide v2
cmp-long v4, p2, v2
if-lez v4, :cond_be
.line 9
invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getZipFiles()Ljava/util/TreeSet;
move-result-object p2
invoke-virtual {p2}, Ljava/util/TreeSet;->pollFirst()Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/io/File;
.line 10
invoke-virtual {p1}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getCurrentSize()J
move-result-wide v2
invoke-virtual {p2}, Ljava/io/File;->length()J
move-result-wide v4
sub-long/2addr v2, v4
invoke-virtual {p1, v2, v3}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->setCurrentSize(J)V
.line 11
invoke-virtual {p2}, Ljava/io/File;->delete()Z
move-result p3
if-nez p3, :cond_43
.line 12
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object p2
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {v1, p2}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_43
.line 13
:cond_84
new-instance p1, Ljava/io/File;
invoke-direct {p1, p2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Ljava/io/File;->delete()Z
move-result p1
if-nez p1, :cond_a1
.line 14
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v1, p1}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I
.line 15
:cond_a1
new-instance p1, Ljava/io/File;
invoke-direct {p1, p3}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Ljava/io/File;->delete()Z
move-result p1
if-nez p1, :cond_be
.line 16
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v1, p1}, Lio/rong/common/rlog/RLog;->i(Ljava/lang/String;Ljava/lang/String;)I
:cond_be
if-eqz p4, :cond_c3
.line 17
invoke-direct {p0}, Lio/rong/common/rlog/RLogFileProcessor;->uploadLog()V
:cond_c3
return-void
.end method
.method private uploadLog()V
.registers 15
.line 1
iget-boolean v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z
if-eqz v0, :cond_5
return-void
.line 2
:cond_5
iget-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
invoke-virtual {v0}, Lio/rong/common/rlog/RLogConfig;->getZipConfig()Lio/rong/common/rlog/RLogConfig$ZipConfig;
move-result-object v0
if-nez v0, :cond_e
return-void
.line 3
:cond_e
invoke-virtual {v0}, Lio/rong/common/rlog/RLogConfig$ZipConfig;->getZipFiles()Ljava/util/TreeSet;
move-result-object v0
.line 4
invoke-virtual {v0}, Ljava/util/TreeSet;->size()I
move-result v1
iput v1, p0, Lio/rong/common/rlog/RLogFileProcessor;->fileSize:I
const/4 v1, 0x1
.line 5
iput-boolean v1, p0, Lio/rong/common/rlog/RLogFileProcessor;->isUploading:Z
.line 6
invoke-virtual {v0}, Ljava/util/TreeSet;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_1f
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_71
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/io/File;
.line 7
invoke-virtual {v2}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v3
.line 8
invoke-virtual {v3}, Ljava/lang/String;->length()I
move-result v4
add-int/lit8 v4, v4, -0x3
const/4 v5, 0x0
invoke-virtual {v3, v5, v4}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v3
const-string v4, "_"
.line 9
invoke-virtual {v3, v4}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v3
.line 10
new-instance v4, Lio/rong/common/rlog/RLogReporter$UploadConfig;
iget-object v6, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
invoke-virtual {v6}, Lio/rong/common/rlog/RLogConfig;->getUploadUrl()Ljava/lang/String;
move-result-object v7
.line 11
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v8
aget-object v9, v3, v5
aget-object v10, v3, v1
iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
.line 12
invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getSdkVersion()Ljava/lang/String;
move-result-object v11
iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
.line 13
invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getAppKey()Ljava/lang/String;
move-result-object v12
iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mConfig:Lio/rong/common/rlog/RLogConfig;
.line 14
invoke-virtual {v2}, Lio/rong/common/rlog/RLogConfig;->getUserId()Ljava/lang/String;
move-result-object v13
move-object v6, v4
invoke-direct/range {v6 .. v13}, Lio/rong/common/rlog/RLogReporter$UploadConfig;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 15
iget-object v2, p0, Lio/rong/common/rlog/RLogFileProcessor;->mReporter:Lio/rong/common/rlog/RLogReporter;
new-instance v3, Lio/rong/common/rlog/RLogFileProcessor$3;
invoke-direct {v3, p0}, Lio/rong/common/rlog/RLogFileProcessor$3;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V
invoke-virtual {v2, v4, v3}, Lio/rong/common/rlog/RLogReporter;->report(Lio/rong/common/rlog/RLogReporter$UploadConfig;Lio/rong/common/rlog/RLogReporter$IUploadListener;)V
goto :goto_1f
:cond_71
return-void
.end method
# virtual methods
.method public upload()V
.registers 3
.line 1
new-instance v0, Lio/rong/common/rlog/RLogFileProcessor$4;
invoke-direct {v0, p0}, Lio/rong/common/rlog/RLogFileProcessor$4;-><init>(Lio/rong/common/rlog/RLogFileProcessor;)V
.line 2
iget-object v1, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;
invoke-virtual {v1, v0}, Lio/rong/common/rlog/LogFileWriter;->stopWrite(Lio/rong/common/rlog/LogFileWriter$IWriterOnStopListener;)V
return-void
.end method
.method public write(Ljava/lang/String;)V
.registers 3
.line 1
iget-object v0, p0, Lio/rong/common/rlog/RLogFileProcessor;->mLogFileWriter:Lio/rong/common/rlog/LogFileWriter;
invoke-virtual {v0, p1}, Lio/rong/common/rlog/LogFileWriter;->write(Ljava/lang/String;)V
return-void
.end method