- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3 - APKTool decompilation (Smali bytecode) for modding and rebuilding APK - Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures - Includes full Smali source, resources, and native libraries - Ready to rebuild APK after modifications with apktool b command - Added comprehensive README-apktool.md with modding guide This branch complements the JADX branches: - Use JADX (main/discord-community) to UNDERSTAND code (readable Java) - Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali) Total: 44,417 files, 538.51 MB Smali source code
1735 lines
40 KiB
Smali
1735 lines
40 KiB
Smali
.class public Lcom/ea/nimble/LogImpl;
|
|
.super Lcom/ea/nimble/Component;
|
|
.source "SourceFile"
|
|
|
|
# interfaces
|
|
.implements Lcom/ea/nimble/ILog;
|
|
|
|
|
|
# annotations
|
|
.annotation system Ldalvik/annotation/MemberClasses;
|
|
value = {
|
|
Lcom/ea/nimble/LogImpl$GuardTask;,
|
|
Lcom/ea/nimble/LogImpl$LogRecord;
|
|
}
|
|
.end annotation
|
|
|
|
|
|
# static fields
|
|
.field private static final DEFAULT_CHECK_INTERVAL:I = 0xe10
|
|
|
|
.field private static final DEFAULT_CONSOLE_OUTPUT_LIMIT:I = 0xfa0
|
|
|
|
.field private static final DEFAULT_MESSAGE_LENGTH_LIMIT:I = 0x3e8
|
|
|
|
.field private static final DEFAULT_SIZE_LIMIT:I = 0x400
|
|
|
|
|
|
# instance fields
|
|
.field private m_cache:Ljava/util/ArrayList;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"Ljava/util/ArrayList<",
|
|
"Lcom/ea/nimble/LogImpl$LogRecord;",
|
|
">;"
|
|
}
|
|
.end annotation
|
|
.end field
|
|
|
|
.field private m_callback:Lcom/ea/nimble/ILog$LogCallback;
|
|
|
|
.field private m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
.field private m_filePath:Ljava/io/File;
|
|
|
|
.field private m_format:Ljava/text/DateFormat;
|
|
|
|
.field private m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
.field private m_interval:I
|
|
|
|
.field private m_level:I
|
|
|
|
.field private m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
.field private m_messageLengthLimit:I
|
|
|
|
.field private m_sizeLimit:I
|
|
|
|
|
|
# direct methods
|
|
.method public constructor <init>()V
|
|
.locals 2
|
|
|
|
.line 57
|
|
invoke-direct {p0}, Lcom/ea/nimble/Component;-><init>()V
|
|
|
|
const/4 v0, 0x0
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
const/4 v1, 0x0
|
|
|
|
iput v1, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_format:Ljava/text/DateFormat;
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
iput v1, p0, Lcom/ea/nimble/LogImpl;->m_interval:I
|
|
|
|
.line 65
|
|
new-instance v1, Ljava/util/ArrayList;
|
|
|
|
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
|
|
|
|
iput-object v1, p0, Lcom/ea/nimble/LogImpl;->m_cache:Ljava/util/ArrayList;
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_callback:Lcom/ea/nimble/ILog$LogCallback;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static synthetic access$000(Lcom/ea/nimble/LogImpl;)Ljava/io/File;
|
|
.locals 0
|
|
|
|
.line 19
|
|
iget-object p0, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
return-object p0
|
|
.end method
|
|
|
|
.method public static synthetic access$100(Lcom/ea/nimble/LogImpl;)I
|
|
.locals 0
|
|
|
|
.line 19
|
|
iget p0, p0, Lcom/ea/nimble/LogImpl;->m_sizeLimit:I
|
|
|
|
return p0
|
|
.end method
|
|
|
|
.method public static synthetic access$200(Lcom/ea/nimble/LogImpl;)V
|
|
.locals 0
|
|
|
|
.line 19
|
|
invoke-direct {p0}, Lcom/ea/nimble/LogImpl;->clearLog()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private clearLog()V
|
|
.locals 3
|
|
|
|
:try_start_0
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
.line 468
|
|
invoke-virtual {v0}, Ljava/io/FileOutputStream;->close()V
|
|
|
|
.line 469
|
|
new-instance v0, Ljava/io/FileOutputStream;
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
const/4 v2, 0x0
|
|
|
|
invoke-direct {v0, v1, v2}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
:try_end_0
|
|
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_0
|
|
const-string v0, "Nimble"
|
|
|
|
const-string v1, "LOG: Can\'t clear log file"
|
|
|
|
.line 473
|
|
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
.method private configure()V
|
|
.locals 9
|
|
|
|
iget v0, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
const/4 v1, 0x1
|
|
|
|
const/4 v2, 0x0
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
move v0, v1
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
move v0, v2
|
|
|
|
:goto_0
|
|
iget-object v3, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
const-string v4, "setting::log"
|
|
|
|
.line 211
|
|
invoke-virtual {v3, v4}, Lcom/ea/nimble/BaseCore;->getSettings(Ljava/lang/String;)Ljava/util/Map;
|
|
|
|
move-result-object v3
|
|
|
|
const/4 v4, 0x0
|
|
|
|
if-nez v3, :cond_2
|
|
|
|
.line 215
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->parseLevel(Ljava/lang/String;)I
|
|
|
|
move-result v0
|
|
|
|
iget v1, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
if-eq v0, v1, :cond_1
|
|
|
|
iput v0, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
.line 220
|
|
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
|
|
|
|
move-result-object v0
|
|
|
|
filled-new-array {v0}, [Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
const-string v1, "LOG: Default Log level(%d) without log configuration file"
|
|
|
|
invoke-static {v1, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
|
|
|
|
:cond_1
|
|
return-void
|
|
|
|
:cond_2
|
|
const-string v5, "Level"
|
|
|
|
.line 225
|
|
invoke-interface {v3, v5}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
check-cast v5, Ljava/lang/String;
|
|
|
|
invoke-direct {p0, v5}, Lcom/ea/nimble/LogImpl;->parseLevel(Ljava/lang/String;)I
|
|
|
|
move-result v5
|
|
|
|
iget v6, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
if-eq v5, v6, :cond_3
|
|
|
|
iput v5, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
.line 229
|
|
invoke-static {v5}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
|
|
|
|
move-result-object v5
|
|
|
|
filled-new-array {v5}, [Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
const-string v6, "LOG: Log level(%d)"
|
|
|
|
invoke-static {v6, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
|
|
|
|
:cond_3
|
|
iget v5, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
const/16 v6, 0x64
|
|
|
|
if-gt v5, v6, :cond_4
|
|
|
|
iput v2, p0, Lcom/ea/nimble/LogImpl;->m_messageLengthLimit:I
|
|
|
|
goto :goto_1
|
|
|
|
:cond_4
|
|
const-string v5, "MessageLengthLimit"
|
|
|
|
.line 239
|
|
invoke-interface {v3, v5}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
check-cast v5, Ljava/lang/String;
|
|
|
|
const/16 v6, 0x3e8
|
|
|
|
if-nez v5, :cond_5
|
|
|
|
iput v6, p0, Lcom/ea/nimble/LogImpl;->m_messageLengthLimit:I
|
|
|
|
goto :goto_1
|
|
|
|
.line 248
|
|
:cond_5
|
|
:try_start_0
|
|
invoke-static {v5}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
|
|
|
|
move-result v5
|
|
|
|
iput v5, p0, Lcom/ea/nimble/LogImpl;->m_messageLengthLimit:I
|
|
|
|
if-gez v5, :cond_6
|
|
|
|
iput v6, p0, Lcom/ea/nimble/LogImpl;->m_messageLengthLimit:I
|
|
:try_end_0
|
|
.catch Ljava/lang/NumberFormatException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_1
|
|
|
|
:catch_0
|
|
iput v6, p0, Lcom/ea/nimble/LogImpl;->m_messageLengthLimit:I
|
|
|
|
:cond_6
|
|
:goto_1
|
|
const-string v5, "File"
|
|
|
|
.line 261
|
|
invoke-interface {v3, v5}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
check-cast v5, Ljava/lang/String;
|
|
|
|
.line 262
|
|
invoke-static {v5}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v6
|
|
|
|
if-nez v6, :cond_9
|
|
|
|
if-nez v0, :cond_7
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
if-eqz v0, :cond_8
|
|
|
|
:cond_7
|
|
iput-object v4, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
iput-object v4, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
iput v2, p0, Lcom/ea/nimble/LogImpl;->m_interval:I
|
|
|
|
:cond_8
|
|
return-void
|
|
|
|
:cond_9
|
|
const-string v0, "Location"
|
|
|
|
.line 279
|
|
invoke-interface {v3, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
check-cast v0, Ljava/lang/String;
|
|
|
|
.line 282
|
|
new-instance v6, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment;
|
|
|
|
move-result-object v7
|
|
|
|
invoke-interface {v7}, Lcom/ea/nimble/IApplicationEnvironment;->getCachePath()Ljava/lang/String;
|
|
|
|
move-result-object v7
|
|
|
|
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
sget-object v7, Ljava/io/File;->separator:Ljava/lang/String;
|
|
|
|
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v6, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v6
|
|
|
|
.line 285
|
|
invoke-static {v0}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v8
|
|
|
|
if-eqz v8, :cond_c
|
|
|
|
const-string v8, "external"
|
|
|
|
.line 286
|
|
invoke-virtual {v0, v8}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_c
|
|
|
|
.line 292
|
|
invoke-static {}, Landroid/os/Environment;->getExternalStorageState()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
const-string v8, "mounted"
|
|
|
|
invoke-virtual {v0, v8}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_c
|
|
|
|
.line 297
|
|
invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getCurrentActivity()Landroid/app/Activity;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-virtual {v0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-virtual {v0}, Ljava/lang/Class;->getPackage()Ljava/lang/Package;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-virtual {v0}, Ljava/lang/Package;->getName()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
.line 298
|
|
invoke-static {v2}, Lcom/ea/nimble/Utility;->getPackageInfo(I)Landroid/content/pm/PackageInfo;
|
|
|
|
move-result-object v2
|
|
|
|
if-eqz v2, :cond_a
|
|
|
|
.line 301
|
|
iget-object v0, v2, Landroid/content/pm/PackageInfo;->packageName:Ljava/lang/String;
|
|
|
|
.line 305
|
|
:cond_a
|
|
new-instance v2, Ljava/io/File;
|
|
|
|
invoke-static {}, Landroid/os/Environment;->getExternalStorageDirectory()Ljava/io/File;
|
|
|
|
move-result-object v8
|
|
|
|
invoke-direct {v2, v8, v0}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
|
|
|
|
.line 308
|
|
invoke-virtual {v2}, Ljava/io/File;->exists()Z
|
|
|
|
move-result v0
|
|
|
|
if-nez v0, :cond_b
|
|
|
|
.line 313
|
|
invoke-virtual {v2}, Ljava/io/File;->mkdir()Z
|
|
|
|
move-result v0
|
|
|
|
:cond_b
|
|
if-eqz v0, :cond_c
|
|
|
|
.line 320
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v6
|
|
|
|
.line 328
|
|
:cond_c
|
|
new-instance v0, Ljava/io/File;
|
|
|
|
invoke-direct {v0, v6}, Ljava/io/File;-><init>(Ljava/lang/String;)V
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
if-eq v0, v2, :cond_d
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
.line 334
|
|
:try_start_1
|
|
new-instance v0, Ljava/io/FileOutputStream;
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
invoke-direct {v0, v2, v1}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
:try_end_1
|
|
.catch Ljava/io/FileNotFoundException; {:try_start_1 .. :try_end_1} :catch_1
|
|
|
|
.line 342
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v2, "LOG: File path: "
|
|
|
|
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
invoke-virtual {v2}, Ljava/io/File;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
goto :goto_2
|
|
|
|
.line 338
|
|
:catch_1
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v1, "LOG: Can\'t create log file at "
|
|
|
|
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
const-string v1, "Nimble"
|
|
|
|
invoke-static {v1, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
iput-object v4, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
return-void
|
|
|
|
:cond_d
|
|
:goto_2
|
|
const-string v0, "DateFormat"
|
|
|
|
.line 346
|
|
invoke-interface {v3, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
check-cast v0, Ljava/lang/String;
|
|
|
|
if-eqz v0, :cond_e
|
|
|
|
.line 347
|
|
invoke-virtual {v0}, Ljava/lang/String;->length()I
|
|
|
|
move-result v2
|
|
|
|
if-lez v2, :cond_e
|
|
|
|
.line 349
|
|
new-instance v2, Ljava/text/SimpleDateFormat;
|
|
|
|
invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;
|
|
|
|
move-result-object v5
|
|
|
|
invoke-direct {v2, v0, v5}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
|
|
|
|
iput-object v2, p0, Lcom/ea/nimble/LogImpl;->m_format:Ljava/text/DateFormat;
|
|
|
|
goto :goto_3
|
|
|
|
.line 353
|
|
:cond_e
|
|
new-instance v0, Ljava/text/SimpleDateFormat;
|
|
|
|
const-string v2, "yyyy-MM-dd HH:mm:ss.SSS"
|
|
|
|
invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;
|
|
|
|
move-result-object v5
|
|
|
|
invoke-direct {v0, v2, v5}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_format:Ljava/text/DateFormat;
|
|
|
|
:goto_3
|
|
const/16 v0, 0xe10
|
|
|
|
:try_start_2
|
|
const-string v2, "FileCheckInterval"
|
|
|
|
.line 358
|
|
invoke-interface {v3, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v2
|
|
|
|
check-cast v2, Ljava/lang/String;
|
|
|
|
invoke-static {v2}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
|
|
|
|
move-result v2
|
|
|
|
iput v2, p0, Lcom/ea/nimble/LogImpl;->m_interval:I
|
|
|
|
if-gtz v2, :cond_f
|
|
|
|
iput v0, p0, Lcom/ea/nimble/LogImpl;->m_interval:I
|
|
:try_end_2
|
|
.catch Ljava/lang/NumberFormatException; {:try_start_2 .. :try_end_2} :catch_2
|
|
|
|
goto :goto_4
|
|
|
|
:catch_2
|
|
iput v0, p0, Lcom/ea/nimble/LogImpl;->m_interval:I
|
|
|
|
:cond_f
|
|
:goto_4
|
|
const/16 v0, 0x400
|
|
|
|
:try_start_3
|
|
const-string v2, "MaxFileSize"
|
|
|
|
.line 371
|
|
invoke-interface {v3, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v2
|
|
|
|
check-cast v2, Ljava/lang/String;
|
|
|
|
invoke-static {v2}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
|
|
|
|
move-result v2
|
|
|
|
iput v2, p0, Lcom/ea/nimble/LogImpl;->m_sizeLimit:I
|
|
|
|
if-gtz v2, :cond_10
|
|
|
|
iput v0, p0, Lcom/ea/nimble/LogImpl;->m_sizeLimit:I
|
|
:try_end_3
|
|
.catch Ljava/lang/NumberFormatException; {:try_start_3 .. :try_end_3} :catch_3
|
|
|
|
goto :goto_5
|
|
|
|
:catch_3
|
|
iput v0, p0, Lcom/ea/nimble/LogImpl;->m_sizeLimit:I
|
|
|
|
.line 383
|
|
:cond_10
|
|
:goto_5
|
|
new-instance v0, Lcom/ea/nimble/LogImpl$GuardTask;
|
|
|
|
invoke-direct {v0, p0, v4}, Lcom/ea/nimble/LogImpl$GuardTask;-><init>(Lcom/ea/nimble/LogImpl;Lcom/ea/nimble/LogImpl$1;)V
|
|
|
|
.line 384
|
|
invoke-virtual {v0}, Lcom/ea/nimble/LogImpl$GuardTask;->run()V
|
|
|
|
.line 385
|
|
new-instance v2, Lcom/ea/nimble/Timer;
|
|
|
|
invoke-direct {v2, v0}, Lcom/ea/nimble/Timer;-><init>(Ljava/lang/Runnable;)V
|
|
|
|
iput-object v2, p0, Lcom/ea/nimble/LogImpl;->m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
iget v0, p0, Lcom/ea/nimble/LogImpl;->m_interval:I
|
|
|
|
int-to-double v3, v0
|
|
|
|
.line 386
|
|
invoke-virtual {v2, v3, v4, v1}, Lcom/ea/nimble/Timer;->schedule(DZ)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private flushCache()V
|
|
.locals 4
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_cache:Ljava/util/ArrayList;
|
|
|
|
.line 391
|
|
invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object v0
|
|
|
|
:cond_0
|
|
:goto_0
|
|
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v1
|
|
|
|
check-cast v1, Lcom/ea/nimble/LogImpl$LogRecord;
|
|
|
|
.line 393
|
|
iget v2, v1, Lcom/ea/nimble/LogImpl$LogRecord;->level:I
|
|
|
|
iget v3, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
if-lt v2, v3, :cond_0
|
|
|
|
.line 395
|
|
iget-object v1, v1, Lcom/ea/nimble/LogImpl$LogRecord;->message:Ljava/lang/String;
|
|
|
|
invoke-direct {p0, v2, v1}, Lcom/ea/nimble/LogImpl;->writeLine(ILjava/lang/String;)V
|
|
|
|
goto :goto_0
|
|
|
|
:cond_1
|
|
const/4 v0, 0x0
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_cache:Ljava/util/ArrayList;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
.locals 6
|
|
|
|
.line 619
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string p1, ">"
|
|
|
|
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0, p2}, 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 620
|
|
invoke-virtual {p1}, Ljava/lang/String;->length()I
|
|
|
|
move-result p2
|
|
|
|
iget v0, p0, Lcom/ea/nimble/LogImpl;->m_messageLengthLimit:I
|
|
|
|
const/4 v1, 0x0
|
|
|
|
if-le p2, v0, :cond_0
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
sub-int/2addr p2, v0
|
|
|
|
.line 624
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
iget v2, p0, Lcom/ea/nimble/LogImpl;->m_messageLengthLimit:I
|
|
|
|
invoke-virtual {p1, v1, v2}, Ljava/lang/String;->substring(II)Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
|
|
|
|
move-result-object p1
|
|
|
|
filled-new-array {p1}, [Ljava/lang/Object;
|
|
|
|
move-result-object p1
|
|
|
|
const-string p2, "... and %d chars more"
|
|
|
|
invoke-static {p2, p1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
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 625
|
|
invoke-virtual {p1}, Ljava/lang/String;->length()I
|
|
|
|
move-result p2
|
|
|
|
:cond_0
|
|
int-to-double v2, p2
|
|
|
|
const-wide v4, 0x40af400000000000L # 4000.0
|
|
|
|
div-double/2addr v2, v4
|
|
|
|
.line 629
|
|
invoke-static {v2, v3}, Ljava/lang/Math;->ceil(D)D
|
|
|
|
move-result-wide v2
|
|
|
|
double-to-int v0, v2
|
|
|
|
.line 630
|
|
new-array v0, v0, [Ljava/lang/String;
|
|
|
|
:goto_0
|
|
if-ge v1, p2, :cond_2
|
|
|
|
add-int/lit16 v2, v1, 0xfa0
|
|
|
|
if-ge v2, p2, :cond_1
|
|
|
|
.line 635
|
|
div-int/lit16 v3, v1, 0xfa0
|
|
|
|
invoke-virtual {p1, v1, v2}, Ljava/lang/String;->substring(II)Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
aput-object v1, v0, v3
|
|
|
|
goto :goto_1
|
|
|
|
.line 639
|
|
:cond_1
|
|
div-int/lit16 v3, v1, 0xfa0
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/String;->substring(I)Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
aput-object v1, v0, v3
|
|
|
|
:goto_1
|
|
move v1, v2
|
|
|
|
goto :goto_0
|
|
|
|
:cond_2
|
|
return-object v0
|
|
.end method
|
|
|
|
.method private outputMessageToFile(Ljava/lang/String;)V
|
|
.locals 4
|
|
|
|
const-string v0, "line.separator"
|
|
|
|
.line 648
|
|
invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
iget-object v1, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
.line 654
|
|
:try_start_0
|
|
new-instance v1, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
iget-object v2, p0, Lcom/ea/nimble/LogImpl;->m_format:Ljava/text/DateFormat;
|
|
|
|
new-instance v3, Ljava/util/Date;
|
|
|
|
invoke-direct {v3}, Ljava/util/Date;-><init>()V
|
|
|
|
invoke-virtual {v2, v3}, Ljava/text/DateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string v2, " "
|
|
|
|
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
const-string v1, "UTF-8"
|
|
|
|
.line 655
|
|
invoke-static {v1}, Ljava/nio/charset/Charset;->forName(Ljava/lang/String;)Ljava/nio/charset/Charset;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {p1, v1}, Ljava/lang/String;->getBytes(Ljava/nio/charset/Charset;)[B
|
|
|
|
move-result-object p1
|
|
|
|
invoke-virtual {v0, p1}, Ljava/io/FileOutputStream;->write([B)V
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
.line 656
|
|
invoke-virtual {p1}, Ljava/io/OutputStream;->flush()V
|
|
:try_end_0
|
|
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_0
|
|
move-exception p1
|
|
|
|
.line 660
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v1, "Error writing to log file: "
|
|
|
|
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p1
|
|
|
|
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
|
|
|
|
const-string v0, "Nimble"
|
|
|
|
invoke-static {v0, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
:cond_0
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
.method private parseLevel(Ljava/lang/String;)I
|
|
.locals 3
|
|
|
|
const/16 v0, 0x1f4
|
|
|
|
const/16 v1, 0x64
|
|
|
|
.line 406
|
|
:try_start_0
|
|
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_7
|
|
|
|
.line 408
|
|
invoke-static {p1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
|
|
|
|
move-result p1
|
|
:try_end_0
|
|
.catch Ljava/lang/NumberFormatException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
if-eqz p1, :cond_7
|
|
|
|
return p1
|
|
|
|
:catch_0
|
|
const-string v2, "all"
|
|
|
|
.line 418
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_0
|
|
|
|
const/4 p1, 0x0
|
|
|
|
return p1
|
|
|
|
:cond_0
|
|
const-string v2, "verbose"
|
|
|
|
.line 422
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_1
|
|
|
|
return v1
|
|
|
|
:cond_1
|
|
const-string v2, "debug"
|
|
|
|
.line 426
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_2
|
|
|
|
const/16 p1, 0xc8
|
|
|
|
return p1
|
|
|
|
:cond_2
|
|
const-string v2, "info"
|
|
|
|
.line 430
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_3
|
|
|
|
const/16 p1, 0x12c
|
|
|
|
return p1
|
|
|
|
:cond_3
|
|
const-string v2, "warn"
|
|
|
|
.line 434
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_4
|
|
|
|
const/16 p1, 0x190
|
|
|
|
return p1
|
|
|
|
:cond_4
|
|
const-string v2, "error"
|
|
|
|
.line 438
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_5
|
|
|
|
return v0
|
|
|
|
:cond_5
|
|
const-string v2, "fatal"
|
|
|
|
.line 442
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result v2
|
|
|
|
if-eqz v2, :cond_6
|
|
|
|
const/16 p1, 0x258
|
|
|
|
return p1
|
|
|
|
:cond_6
|
|
const-string v2, "silent"
|
|
|
|
.line 446
|
|
invoke-virtual {p1, v2}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
|
|
|
|
move-result p1
|
|
|
|
if-eqz p1, :cond_7
|
|
|
|
const/16 p1, 0x2bc
|
|
|
|
return p1
|
|
|
|
:cond_7
|
|
iget-object p1, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
.line 452
|
|
invoke-virtual {p1}, Lcom/ea/nimble/BaseCore;->getConfiguration()Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
move-result-object p1
|
|
|
|
sget-object v2, Lcom/ea/nimble/NimbleConfiguration;->INTEGRATION:Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
if-eq p1, v2, :cond_9
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
.line 453
|
|
invoke-virtual {p1}, Lcom/ea/nimble/BaseCore;->getConfiguration()Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
move-result-object p1
|
|
|
|
sget-object v2, Lcom/ea/nimble/NimbleConfiguration;->STAGE:Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
if-ne p1, v2, :cond_8
|
|
|
|
goto :goto_0
|
|
|
|
:cond_8
|
|
return v0
|
|
|
|
:cond_9
|
|
:goto_0
|
|
return v1
|
|
.end method
|
|
|
|
.method private write(ILjava/lang/String;Ljava/lang/String;)V
|
|
.locals 1
|
|
|
|
.line 595
|
|
invoke-static {p2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 597
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string p2, "> "
|
|
|
|
invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p2
|
|
|
|
goto :goto_0
|
|
|
|
.line 601
|
|
:cond_0
|
|
new-instance p2, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v0, " "
|
|
|
|
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p2
|
|
|
|
:goto_0
|
|
iget-object p3, p0, Lcom/ea/nimble/LogImpl;->m_cache:Ljava/util/ArrayList;
|
|
|
|
if-eqz p3, :cond_1
|
|
|
|
.line 607
|
|
new-instance p3, Lcom/ea/nimble/LogImpl$LogRecord;
|
|
|
|
const/4 v0, 0x0
|
|
|
|
invoke-direct {p3, v0}, Lcom/ea/nimble/LogImpl$LogRecord;-><init>(Lcom/ea/nimble/LogImpl$1;)V
|
|
|
|
iput p1, p3, Lcom/ea/nimble/LogImpl$LogRecord;->level:I
|
|
|
|
iput-object p2, p3, Lcom/ea/nimble/LogImpl$LogRecord;->message:Ljava/lang/String;
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/LogImpl;->m_cache:Ljava/util/ArrayList;
|
|
|
|
.line 610
|
|
invoke-virtual {p1, p3}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
|
|
|
|
return-void
|
|
|
|
.line 614
|
|
:cond_1
|
|
invoke-direct {p0, p1, p2}, Lcom/ea/nimble/LogImpl;->writeLine(ILjava/lang/String;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private writeLine(ILjava/lang/String;)V
|
|
.locals 6
|
|
|
|
const/16 v0, 0x258
|
|
|
|
const/4 v1, 0x0
|
|
|
|
if-eqz p1, :cond_8
|
|
|
|
const/16 v2, 0x64
|
|
|
|
if-eq p1, v2, :cond_7
|
|
|
|
const/16 v2, 0xc8
|
|
|
|
if-eq p1, v2, :cond_6
|
|
|
|
const/16 v2, 0x12c
|
|
|
|
if-eq p1, v2, :cond_5
|
|
|
|
const/16 v2, 0x190
|
|
|
|
const-string v3, "Nimble"
|
|
|
|
if-eq p1, v2, :cond_4
|
|
|
|
const/16 v2, 0x1f4
|
|
|
|
if-eq p1, v2, :cond_3
|
|
|
|
if-eq p1, v0, :cond_1
|
|
|
|
.line 568
|
|
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
|
|
|
|
move-result-object v2
|
|
|
|
filled-new-array {v2}, [Ljava/lang/Object;
|
|
|
|
move-result-object v2
|
|
|
|
const-string v4, "NIM(%d)"
|
|
|
|
invoke-static {v4, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 569
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 571
|
|
aget-object v4, v2, v1
|
|
|
|
.line 572
|
|
:goto_0
|
|
array-length v5, v2
|
|
|
|
add-int/lit8 v5, v5, -0x1
|
|
|
|
if-ge v1, v5, :cond_0
|
|
|
|
.line 574
|
|
invoke-static {v3, v4}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
.line 575
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
.line 576
|
|
aget-object v4, v2, v1
|
|
|
|
goto :goto_0
|
|
|
|
.line 578
|
|
:cond_0
|
|
invoke-static {v3, v4}, Landroid/util/Log;->wtf(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
.line 579
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
goto/16 :goto_8
|
|
|
|
:cond_1
|
|
const-string v2, "NIM_FATAL"
|
|
|
|
.line 553
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 555
|
|
aget-object v4, v2, v1
|
|
|
|
.line 556
|
|
:goto_1
|
|
array-length v5, v2
|
|
|
|
add-int/lit8 v5, v5, -0x1
|
|
|
|
if-ge v1, v5, :cond_2
|
|
|
|
.line 558
|
|
invoke-static {v3, v4}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
.line 559
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
.line 560
|
|
aget-object v4, v2, v1
|
|
|
|
goto :goto_1
|
|
|
|
.line 562
|
|
:cond_2
|
|
invoke-static {v3, v4}, Landroid/util/Log;->wtf(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
.line 563
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
goto/16 :goto_8
|
|
|
|
:cond_3
|
|
const-string v2, "NIM_ERROR"
|
|
|
|
.line 542
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 543
|
|
array-length v4, v2
|
|
|
|
:goto_2
|
|
if-ge v1, v4, :cond_9
|
|
|
|
aget-object v5, v2, v1
|
|
|
|
.line 545
|
|
invoke-static {v3, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
.line 546
|
|
invoke-direct {p0, v5}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
goto :goto_2
|
|
|
|
:cond_4
|
|
const-string v2, "NIM_WARN"
|
|
|
|
.line 531
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 532
|
|
array-length v4, v2
|
|
|
|
:goto_3
|
|
if-ge v1, v4, :cond_9
|
|
|
|
aget-object v5, v2, v1
|
|
|
|
.line 534
|
|
invoke-static {v3, v5}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
.line 535
|
|
invoke-direct {p0, v5}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
goto :goto_3
|
|
|
|
:cond_5
|
|
const-string v2, "NIM_INFO"
|
|
|
|
.line 520
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 521
|
|
array-length v3, v2
|
|
|
|
:goto_4
|
|
if-ge v1, v3, :cond_9
|
|
|
|
aget-object v4, v2, v1
|
|
|
|
.line 524
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
goto :goto_4
|
|
|
|
:cond_6
|
|
const-string v2, "NIM_DEBUG"
|
|
|
|
.line 509
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 510
|
|
array-length v3, v2
|
|
|
|
:goto_5
|
|
if-ge v1, v3, :cond_9
|
|
|
|
aget-object v4, v2, v1
|
|
|
|
.line 513
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
goto :goto_5
|
|
|
|
:cond_7
|
|
const-string v2, "NIM_VERBOSE"
|
|
|
|
.line 498
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 499
|
|
array-length v3, v2
|
|
|
|
:goto_6
|
|
if-ge v1, v3, :cond_9
|
|
|
|
aget-object v4, v2, v1
|
|
|
|
.line 502
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
goto :goto_6
|
|
|
|
:cond_8
|
|
const-string v2, "NIM_ALL"
|
|
|
|
.line 487
|
|
invoke-direct {p0, v2, p2}, Lcom/ea/nimble/LogImpl;->formatLine(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
.line 488
|
|
array-length v3, v2
|
|
|
|
:goto_7
|
|
if-ge v1, v3, :cond_9
|
|
|
|
aget-object v4, v2, v1
|
|
|
|
.line 491
|
|
invoke-direct {p0, v4}, Lcom/ea/nimble/LogImpl;->outputMessageToFile(Ljava/lang/String;)V
|
|
|
|
add-int/lit8 v1, v1, 0x1
|
|
|
|
goto :goto_7
|
|
|
|
:cond_9
|
|
:goto_8
|
|
if-lt p1, v0, :cond_b
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
.line 585
|
|
invoke-virtual {p1}, Lcom/ea/nimble/BaseCore;->getConfiguration()Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
move-result-object p1
|
|
|
|
sget-object v0, Lcom/ea/nimble/NimbleConfiguration;->INTEGRATION:Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
if-eq p1, v0, :cond_a
|
|
|
|
iget-object p1, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
.line 586
|
|
invoke-virtual {p1}, Lcom/ea/nimble/BaseCore;->getConfiguration()Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
move-result-object p1
|
|
|
|
sget-object v0, Lcom/ea/nimble/NimbleConfiguration;->STAGE:Lcom/ea/nimble/NimbleConfiguration;
|
|
|
|
if-eq p1, v0, :cond_a
|
|
|
|
goto :goto_9
|
|
|
|
.line 588
|
|
:cond_a
|
|
new-instance p1, Ljava/lang/AssertionError;
|
|
|
|
invoke-direct {p1, p2}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
|
|
|
|
throw p1
|
|
|
|
:cond_b
|
|
:goto_9
|
|
return-void
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public connectToCore(Lcom/ea/nimble/BaseCore;)V
|
|
.locals 0
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
.line 195
|
|
invoke-direct {p0}, Lcom/ea/nimble/LogImpl;->configure()V
|
|
|
|
.line 196
|
|
invoke-direct {p0}, Lcom/ea/nimble/LogImpl;->flushCache()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public disconnectFromCore()V
|
|
.locals 1
|
|
|
|
const/4 v0, 0x0
|
|
|
|
iput-object v0, p0, Lcom/ea/nimble/LogImpl;->m_core:Lcom/ea/nimble/BaseCore;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public getComponentId()Ljava/lang/String;
|
|
.locals 1
|
|
|
|
const-string v0, "com.ea.nimble.NimbleLog"
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getLogFilePath()Ljava/lang/String;
|
|
.locals 1
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_filePath:Ljava/io/File;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 143
|
|
invoke-virtual {v0}, Ljava/io/File;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
return-object v0
|
|
|
|
:cond_0
|
|
const/4 v0, 0x0
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public getThresholdLevel()I
|
|
.locals 1
|
|
|
|
iget v0, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
return v0
|
|
.end method
|
|
|
|
.method public resume()V
|
|
.locals 1
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 97
|
|
invoke-virtual {v0}, Lcom/ea/nimble/Timer;->fire()V
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
.line 98
|
|
invoke-virtual {v0}, Lcom/ea/nimble/Timer;->resume()V
|
|
|
|
:cond_0
|
|
return-void
|
|
.end method
|
|
|
|
.method public setLogCallback(Lcom/ea/nimble/ILog$LogCallback;)V
|
|
.locals 0
|
|
|
|
iput-object p1, p0, Lcom/ea/nimble/LogImpl;->m_callback:Lcom/ea/nimble/ILog$LogCallback;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public setThresholdLevel(I)V
|
|
.locals 0
|
|
|
|
iput p1, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public setup()V
|
|
.locals 0
|
|
|
|
.line 80
|
|
invoke-direct {p0}, Lcom/ea/nimble/LogImpl;->configure()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public suspend()V
|
|
.locals 1
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 88
|
|
invoke-virtual {v0}, Lcom/ea/nimble/Timer;->pause()V
|
|
|
|
:cond_0
|
|
return-void
|
|
.end method
|
|
|
|
.method public teardown()V
|
|
.locals 3
|
|
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
const/4 v1, 0x0
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 107
|
|
invoke-virtual {v0}, Lcom/ea/nimble/Timer;->cancel()V
|
|
|
|
iput-object v1, p0, Lcom/ea/nimble/LogImpl;->m_guardTimer:Lcom/ea/nimble/Timer;
|
|
|
|
:cond_0
|
|
iget-object v0, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
if-eqz v0, :cond_1
|
|
|
|
.line 114
|
|
:try_start_0
|
|
invoke-virtual {v0}, Ljava/io/FileOutputStream;->close()V
|
|
:try_end_0
|
|
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_0
|
|
const-string v0, "Nimble"
|
|
|
|
const-string v2, "LOG: Can\'t close log file"
|
|
|
|
.line 118
|
|
invoke-static {v0, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
:goto_0
|
|
iput-object v1, p0, Lcom/ea/nimble/LogImpl;->m_logFileStream:Ljava/io/FileOutputStream;
|
|
|
|
:cond_1
|
|
return-void
|
|
.end method
|
|
|
|
.method public varargs writeWithSource(ILjava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
.locals 1
|
|
|
|
.line 158
|
|
instance-of v0, p2, Lcom/ea/nimble/LogSource;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 160
|
|
check-cast p2, Lcom/ea/nimble/LogSource;
|
|
|
|
invoke-interface {p2}, Lcom/ea/nimble/LogSource;->getLogSourceTitle()Ljava/lang/String;
|
|
|
|
move-result-object p2
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
if-eqz p2, :cond_1
|
|
|
|
.line 164
|
|
invoke-virtual {p2}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
|
|
|
|
move-result-object p2
|
|
|
|
invoke-virtual {p2}, Ljava/lang/Class;->getName()Ljava/lang/String;
|
|
|
|
move-result-object p2
|
|
|
|
goto :goto_0
|
|
|
|
:cond_1
|
|
const-string p2, ""
|
|
|
|
.line 167
|
|
:goto_0
|
|
invoke-virtual {p0, p1, p2, p3, p4}, Lcom/ea/nimble/LogImpl;->writeWithTitle(ILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public varargs writeWithTitle(ILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
.locals 1
|
|
|
|
iget v0, p0, Lcom/ea/nimble/LogImpl;->m_level:I
|
|
|
|
if-lt p1, v0, :cond_1
|
|
|
|
.line 173
|
|
invoke-static {p3}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
|
|
|
|
move-result v0
|
|
|
|
if-eqz v0, :cond_1
|
|
|
|
.line 176
|
|
array-length v0, p4
|
|
|
|
if-lez v0, :cond_0
|
|
|
|
.line 178
|
|
invoke-static {p3, p4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
|
|
|
|
move-result-object p3
|
|
|
|
.line 181
|
|
:cond_0
|
|
invoke-direct {p0, p1, p2, p3}, Lcom/ea/nimble/LogImpl;->write(ILjava/lang/String;Ljava/lang/String;)V
|
|
|
|
iget-object p4, p0, Lcom/ea/nimble/LogImpl;->m_callback:Lcom/ea/nimble/ILog$LogCallback;
|
|
|
|
if-eqz p4, :cond_1
|
|
|
|
.line 185
|
|
invoke-interface {p4, p1, p2, p3}, Lcom/ea/nimble/ILog$LogCallback;->callback(ILjava/lang/String;Ljava/lang/String;)V
|
|
|
|
:cond_1
|
|
return-void
|
|
.end method
|