InfocLog.smali
.class public Lcom/cleanmaster/util/infocutil/InfocLog;
.super Ljava/lang/Object;
.source "InfocLog.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;
}
.end annotation
# static fields
.field private static final LOG_FILE_NAME_FIRST:Ljava/lang/String; = "log.0"
.field private static final LOG_FILE_NAME_SECOND:Ljava/lang/String; = "log.1"
.field private static final LOG_FMT:Ljava/lang/String; = "%s!@#$#@!%s!@#$#@!%s!@#$#@!%s\n"
.field private static final LogDirPath:Ljava/lang/String; = "/infoc/log"
.field private static final MAX_FILE_SIZE:J = 0x80000L
.field private static final THREAD_RETAIN_TIME:J = 0x7530L
.field private static mInstance:Lcom/cleanmaster/util/infocutil/InfocLog;
.field private static final mSem:[B
.field private static final nDateFormatLock:Ljava/lang/Object;
# instance fields
.field private mCurrentLogFile:Ljava/io/File;
.field private final mDateFormat:Ljava/text/SimpleDateFormat;
.field private final mLogItemList:Ljava/util/LinkedList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/LinkedList",
"<",
"Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;",
">;"
}
.end annotation
.end field
.field private mRunnable:Ljava/lang/Runnable;
.field private mWriteThread:Ljava/lang/Thread;
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 28
const/4 v0, 0x1
new-array v0, v0, [B
sput-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mSem:[B
.line 29
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
sput-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->nDateFormatLock:Ljava/lang/Object;
.line 31
new-instance v0, Lcom/cleanmaster/util/infocutil/InfocLog;
invoke-direct {v0}, Lcom/cleanmaster/util/infocutil/InfocLog;-><init>()V
sput-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mInstance:Lcom/cleanmaster/util/infocutil/InfocLog;
return-void
.end method
.method private constructor <init>()V
.registers 4
.prologue
const/4 v2, 0x0
.line 42
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 26
new-instance v0, Ljava/text/SimpleDateFormat;
const-string v1, "yyyy-MM-dd HH:mm:ss"
invoke-direct {v0, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V
iput-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mDateFormat:Ljava/text/SimpleDateFormat;
.line 40
iput-object v2, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mWriteThread:Ljava/lang/Thread;
.line 73
new-instance v0, Lcom/cleanmaster/util/infocutil/InfocLog$1;
invoke-direct {v0, p0}, Lcom/cleanmaster/util/infocutil/InfocLog$1;-><init>(Lcom/cleanmaster/util/infocutil/InfocLog;)V
iput-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mRunnable:Ljava/lang/Runnable;
.line 180
iput-object v2, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mCurrentLogFile:Ljava/io/File;
.line 43
new-instance v0, Ljava/util/LinkedList;
invoke-direct {v0}, Ljava/util/LinkedList;-><init>()V
iput-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mLogItemList:Ljava/util/LinkedList;
.line 44
return-void
.end method
.method static synthetic access$000(Lcom/cleanmaster/util/infocutil/InfocLog;)Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;
.registers 2
.prologue
.line 15
invoke-direct {p0}, Lcom/cleanmaster/util/infocutil/InfocLog;->getItemFromList()Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;
move-result-object v0
return-object v0
.end method
.method static synthetic access$100(Lcom/cleanmaster/util/infocutil/InfocLog;)V
.registers 1
.prologue
.line 15
invoke-direct {p0}, Lcom/cleanmaster/util/infocutil/InfocLog;->waitForNewWrite()V
return-void
.end method
.method static synthetic access$200(Lcom/cleanmaster/util/infocutil/InfocLog;Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;)V
.registers 2
.prologue
.line 15
invoke-direct {p0, p1}, Lcom/cleanmaster/util/infocutil/InfocLog;->writeDataToFile(Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;)V
return-void
.end method
.method private closeFileChannel(Ljava/nio/channels/FileChannel;)V
.registers 3
.prologue
.line 161
if-eqz p1, :cond_5
.line 163
:try_start_2
invoke-virtual {p1}, Ljava/nio/channels/FileChannel;->close()V
:try_end_5
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_5} :catch_6
.line 169
:cond_5
:goto_5
return-void
.line 165
:catch_6
move-exception v0
.line 166
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_5
.end method
.method private closeFileLock(Ljava/nio/channels/FileLock;)V
.registers 3
.prologue
.line 150
if-eqz p1, :cond_5
.line 152
:try_start_2
invoke-virtual {p1}, Ljava/nio/channels/FileLock;->release()V
:try_end_5
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_5} :catch_6
.line 158
:cond_5
:goto_5
return-void
.line 154
:catch_6
move-exception v0
.line 155
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_5
.end method
.method private closeOutputStream(Ljava/io/OutputStream;)V
.registers 3
.prologue
.line 172
if-nez p1, :cond_3
.line 178
:goto_2
return-void
.line 174
:cond_3
:try_start_3
invoke-virtual {p1}, Ljava/io/OutputStream;->close()V
:try_end_6
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_6} :catch_7
goto :goto_2
.line 175
:catch_7
move-exception v0
.line 176
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
goto :goto_2
.end method
.method private getItemFromList()Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;
.registers 4
.prologue
.line 95
const/4 v0, 0x0
.line 96
iget-object v1, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mLogItemList:Ljava/util/LinkedList;
monitor-enter v1
.line 97
:try_start_4
iget-object v2, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mLogItemList:Ljava/util/LinkedList;
invoke-virtual {v2}, Ljava/util/LinkedList;->isEmpty()Z
move-result v2
if-nez v2, :cond_14
.line 98
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mLogItemList:Ljava/util/LinkedList;
invoke-virtual {v0}, Ljava/util/LinkedList;->remove()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;
.line 99
:cond_14
monitor-exit v1
.line 100
return-object v0
.line 99
:catchall_16
move-exception v0
monitor-exit v1
:try_end_18
.catchall {:try_start_4 .. :try_end_18} :catchall_16
throw v0
.end method
.method private getLogFile()Ljava/io/File;
.registers 3
.prologue
.line 182
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mCurrentLogFile:Ljava/io/File;
if-eqz v0, :cond_f
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mCurrentLogFile:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->canWrite()Z
move-result v0
if-eqz v0, :cond_f
.line 183
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mCurrentLogFile:Ljava/io/File;
.line 191
:goto_e
return-object v0
.line 186
:cond_f
invoke-static {}, Lcom/keniu/security/m;->d()Landroid/content/Context;
move-result-object v0
.line 187
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0}, Landroid/content/Context;->getFilesDir()Ljava/io/File;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "/infoc/log"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 188
invoke-direct {p0, v0}, Lcom/cleanmaster/util/infocutil/InfocLog;->parentDirsExist(Ljava/lang/String;)Z
move-result v1
if-nez v1, :cond_32
const/4 v0, 0x0
goto :goto_e
.line 190
:cond_32
invoke-direct {p0, v0}, Lcom/cleanmaster/util/infocutil/InfocLog;->getRightLogFile(Ljava/lang/String;)Ljava/io/File;
move-result-object v0
iput-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mCurrentLogFile:Ljava/io/File;
.line 191
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mCurrentLogFile:Ljava/io/File;
goto :goto_e
.end method
.method private getRightLogFile(Ljava/lang/String;)Ljava/io/File;
.registers 5
.prologue
.line 203
new-instance v0, Ljava/io/File;
const-string v1, "log.0"
invoke-direct {v0, p1, v1}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 204
invoke-direct {p0, v0}, Lcom/cleanmaster/util/infocutil/InfocLog;->isLogFileValid(Ljava/io/File;)Z
move-result v1
.line 205
if-eqz v1, :cond_e
.line 225
:goto_d
return-object v0
.line 208
:cond_e
new-instance v1, Ljava/io/File;
const-string v2, "log.1"
invoke-direct {v1, p1, v2}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 209
invoke-direct {p0, v1}, Lcom/cleanmaster/util/infocutil/InfocLog;->isLogFileValid(Ljava/io/File;)Z
move-result v2
.line 210
if-eqz v2, :cond_1d
move-object v0, v1
.line 211
goto :goto_d
.line 214
:cond_1d
invoke-direct {p0, v0}, Lcom/cleanmaster/util/infocutil/InfocLog;->isFileOverSize(Ljava/io/File;)Z
move-result v2
if-eqz v2, :cond_32
invoke-direct {p0, v1}, Lcom/cleanmaster/util/infocutil/InfocLog;->isFileOverSize(Ljava/io/File;)Z
move-result v2
if-eqz v2, :cond_32
.line 215
invoke-virtual {v0}, Ljava/io/File;->delete()Z
.line 216
invoke-virtual {v1, v0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
.line 218
:try_start_2f
invoke-virtual {v1}, Ljava/io/File;->createNewFile()Z
:try_end_32
.catch Ljava/io/IOException; {:try_start_2f .. :try_end_32} :catch_34
:cond_32
move-object v0, v1
.line 225
goto :goto_d
.line 219
:catch_34
move-exception v0
.line 220
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
.line 221
const/4 v0, 0x0
goto :goto_d
.end method
.method private isFileOverSize(Ljava/io/File;)Z
.registers 6
.prologue
.line 230
if-eqz p1, :cond_15
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_15
invoke-virtual {p1}, Ljava/io/File;->length()J
move-result-wide v0
const-wide/32 v2, 0x80000
cmp-long v0, v0, v2
if-ltz v0, :cond_15
const/4 v0, 0x1
:goto_14
return v0
:cond_15
const/4 v0, 0x0
goto :goto_14
.end method
.method private isLogFileValid(Ljava/io/File;)Z
.registers 8
.prologue
const/4 v0, 0x0
.line 235
if-nez p1, :cond_4
.line 246
:cond_3
:goto_3
return v0
.line 237
:cond_4
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v1
if-nez v1, :cond_d
.line 239
:try_start_a
invoke-virtual {p1}, Ljava/io/File;->createNewFile()Z
:try_end_d
.catch Ljava/io/IOException; {:try_start_a .. :try_end_d} :catch_20
.line 246
:cond_d
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_3
invoke-virtual {p1}, Ljava/io/File;->length()J
move-result-wide v2
const-wide/32 v4, 0x80000
cmp-long v1, v2, v4
if-gez v1, :cond_3
const/4 v0, 0x1
goto :goto_3
.line 240
:catch_20
move-exception v1
.line 241
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
goto :goto_3
.end method
.method public static log(Ljava/lang/String;Ljava/lang/String;Z)V
.registers 8
.prologue
.line 47
invoke-static {p0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_c
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_d
.line 60
:cond_c
:goto_c
return-void
.line 50
:cond_d
sget-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mInstance:Lcom/cleanmaster/util/infocutil/InfocLog;
iget-object v1, v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mLogItemList:Ljava/util/LinkedList;
monitor-enter v1
.line 51
:try_start_12
new-instance v2, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;
invoke-direct {v2}, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;-><init>()V
.line 52
iput-object p0, v2, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;->tableName:Ljava/lang/String;
.line 53
iput-object p1, v2, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;->data:Ljava/lang/String;
.line 54
if-eqz p2, :cond_42
const-string v0, "force"
.line 55
:goto_1f
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "host "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
iput-object v0, v2, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;->src:Ljava/lang/String;
.line 56
sget-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mInstance:Lcom/cleanmaster/util/infocutil/InfocLog;
iget-object v0, v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mLogItemList:Ljava/util/LinkedList;
invoke-virtual {v0, v2}, Ljava/util/LinkedList;->addLast(Ljava/lang/Object;)V
.line 57
monitor-exit v1
:try_end_3c
.catchall {:try_start_12 .. :try_end_3c} :catchall_45
.line 59
sget-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mInstance:Lcom/cleanmaster/util/infocutil/InfocLog;
invoke-virtual {v0}, Lcom/cleanmaster/util/infocutil/InfocLog;->sendWriteLogMsg()V
goto :goto_c
.line 54
:cond_42
:try_start_42
const-string v0, "unForce"
goto :goto_1f
.line 57
:catchall_45
move-exception v0
monitor-exit v1
:try_end_47
.catchall {:try_start_42 .. :try_end_47} :catchall_45
throw v0
.end method
.method private parentDirsExist(Ljava/lang/String;)Z
.registers 5
.prologue
const/4 v0, 0x0
.line 195
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v1
if-eqz v1, :cond_8
.line 198
:cond_7
:goto_7
return v0
.line 197
:cond_8
new-instance v1, Ljava/io/File;
invoke-direct {v1, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 198
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_19
invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z
move-result v1
if-eqz v1, :cond_7
:cond_19
const/4 v0, 0x1
goto :goto_7
.end method
.method private waitForNewWrite()V
.registers 5
.prologue
.line 104
sget-object v1, Lcom/cleanmaster/util/infocutil/InfocLog;->mSem:[B
monitor-enter v1
.line 106
:try_start_3
sget-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mSem:[B
const-wide/16 v2, 0x7530
invoke-virtual {v0, v2, v3}, Ljava/lang/Object;->wait(J)V
:try_end_a
.catch Ljava/lang/InterruptedException; {:try_start_3 .. :try_end_a} :catch_c
.catchall {:try_start_3 .. :try_end_a} :catchall_11
.line 110
:goto_a
:try_start_a
monitor-exit v1
.line 111
return-void
.line 107
:catch_c
move-exception v0
.line 108
invoke-virtual {v0}, Ljava/lang/InterruptedException;->printStackTrace()V
goto :goto_a
.line 110
:catchall_11
move-exception v0
monitor-exit v1
:try_end_13
.catchall {:try_start_a .. :try_end_13} :catchall_11
throw v0
.end method
.method private writeDataToFile(Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;)V
.registers 10
.prologue
const/4 v1, 0x0
.line 116
invoke-direct {p0}, Lcom/cleanmaster/util/infocutil/InfocLog;->getLogFile()Ljava/io/File;
move-result-object v0
.line 117
if-nez v0, :cond_8
.line 147
:goto_7
return-void
.line 121
:cond_8
sget-object v2, Lcom/cleanmaster/util/infocutil/InfocLog;->nDateFormatLock:Ljava/lang/Object;
monitor-enter v2
.line 122
:try_start_b
iget-object v3, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mDateFormat:Ljava/text/SimpleDateFormat;
new-instance v4, Ljava/util/Date;
invoke-direct {v4}, Ljava/util/Date;-><init>()V
invoke-virtual {v3, v4}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v3
.line 123
monitor-exit v2
:try_end_17
.catchall {:try_start_b .. :try_end_17} :catchall_6a
.line 125
const-string v2, "%s!@#$#@!%s!@#$#@!%s!@#$#@!%s\n"
const/4 v4, 0x4
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
aput-object v3, v4, v5
const/4 v3, 0x1
iget-object v5, p1, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;->tableName:Ljava/lang/String;
aput-object v5, v4, v3
const/4 v3, 0x2
iget-object v5, p1, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;->data:Ljava/lang/String;
aput-object v5, v4, v3
const/4 v3, 0x3
iget-object v5, p1, Lcom/cleanmaster/util/infocutil/InfocLog$LogItem;->src:Ljava/lang/String;
aput-object v5, v4, v3
invoke-static {v2, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
.line 130
:try_start_32
new-instance v2, Ljava/io/RandomAccessFile;
const-string v4, "rw"
invoke-direct {v2, v0, v4}, Ljava/io/RandomAccessFile;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 131
invoke-virtual {v2}, Ljava/io/RandomAccessFile;->length()J
move-result-wide v4
invoke-virtual {v2, v4, v5}, Ljava/io/RandomAccessFile;->seek(J)V
.line 133
invoke-virtual {v2}, Ljava/io/RandomAccessFile;->getChannel()Ljava/nio/channels/FileChannel;
:try_end_43
.catch Ljava/lang/Exception; {:try_start_32 .. :try_end_43} :catch_6d
.catchall {:try_start_32 .. :try_end_43} :catchall_79
move-result-object v2
.line 134
:try_start_44
invoke-virtual {v2}, Ljava/nio/channels/FileChannel;->lock()Ljava/nio/channels/FileLock;
move-result-object v1
.line 135
const-string v4, "utf-8"
invoke-virtual {v3, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v3
invoke-static {v3}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/nio/channels/FileChannel;->write(Ljava/nio/ByteBuffer;)I
.line 137
invoke-virtual {v0}, Ljava/io/File;->length()J
move-result-wide v4
const-wide/32 v6, 0x80000
cmp-long v0, v4, v6
if-ltz v0, :cond_63
.line 139
const/4 v0, 0x0
iput-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mCurrentLogFile:Ljava/io/File;
:try_end_63
.catch Ljava/lang/Exception; {:try_start_44 .. :try_end_63} :catch_84
.catchall {:try_start_44 .. :try_end_63} :catchall_82
.line 144
:cond_63
invoke-direct {p0, v1}, Lcom/cleanmaster/util/infocutil/InfocLog;->closeFileLock(Ljava/nio/channels/FileLock;)V
.line 145
invoke-direct {p0, v2}, Lcom/cleanmaster/util/infocutil/InfocLog;->closeFileChannel(Ljava/nio/channels/FileChannel;)V
goto :goto_7
.line 123
:catchall_6a
move-exception v0
:try_start_6b
monitor-exit v2
:try_end_6c
.catchall {:try_start_6b .. :try_end_6c} :catchall_6a
throw v0
.line 141
:catch_6d
move-exception v0
move-object v2, v1
.line 142
:goto_6f
:try_start_6f
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
:try_end_72
.catchall {:try_start_6f .. :try_end_72} :catchall_82
.line 144
invoke-direct {p0, v1}, Lcom/cleanmaster/util/infocutil/InfocLog;->closeFileLock(Ljava/nio/channels/FileLock;)V
.line 145
invoke-direct {p0, v2}, Lcom/cleanmaster/util/infocutil/InfocLog;->closeFileChannel(Ljava/nio/channels/FileChannel;)V
goto :goto_7
.line 144
:catchall_79
move-exception v0
move-object v2, v1
:goto_7b
invoke-direct {p0, v1}, Lcom/cleanmaster/util/infocutil/InfocLog;->closeFileLock(Ljava/nio/channels/FileLock;)V
.line 145
invoke-direct {p0, v2}, Lcom/cleanmaster/util/infocutil/InfocLog;->closeFileChannel(Ljava/nio/channels/FileChannel;)V
throw v0
.line 144
:catchall_82
move-exception v0
goto :goto_7b
.line 141
:catch_84
move-exception v0
goto :goto_6f
.end method
# virtual methods
.method public declared-synchronized sendWriteLogMsg()V
.registers 4
.prologue
.line 63
monitor-enter p0
:try_start_1
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mWriteThread:Ljava/lang/Thread;
if-eqz v0, :cond_d
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mWriteThread:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->isAlive()Z
move-result v0
if-nez v0, :cond_1d
.line 64
:cond_d
new-instance v0, Ljava/lang/Thread;
iget-object v1, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mRunnable:Ljava/lang/Runnable;
const-string v2, "InfocLog:writeThread"
invoke-direct {v0, v1, v2}, Ljava/lang/Thread;-><init>(Ljava/lang/Runnable;Ljava/lang/String;)V
iput-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mWriteThread:Ljava/lang/Thread;
.line 65
iget-object v0, p0, Lcom/cleanmaster/util/infocutil/InfocLog;->mWriteThread:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->start()V
.line 68
:cond_1d
sget-object v1, Lcom/cleanmaster/util/infocutil/InfocLog;->mSem:[B
monitor-enter v1
:try_end_20
.catchall {:try_start_1 .. :try_end_20} :catchall_2b
.line 69
:try_start_20
sget-object v0, Lcom/cleanmaster/util/infocutil/InfocLog;->mSem:[B
invoke-virtual {v0}, Ljava/lang/Object;->notifyAll()V
.line 70
monitor-exit v1
:try_end_26
.catchall {:try_start_20 .. :try_end_26} :catchall_28
.line 71
monitor-exit p0
return-void
.line 70
:catchall_28
move-exception v0
:try_start_29
monitor-exit v1
:try_end_2a
.catchall {:try_start_29 .. :try_end_2a} :catchall_28
:try_start_2a
throw v0
:try_end_2b
.catchall {:try_start_2a .. :try_end_2b} :catchall_2b
.line 63
:catchall_2b
move-exception v0
monitor-exit p0
throw v0
.end method