Add Discord APKTool decompilation (Smali source for modding)

- 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
This commit is contained in:
2026-02-18 16:13:44 -08:00
parent c080f0d97f
commit f3960ee359
44288 changed files with 10998761 additions and 0 deletions

View File

@@ -0,0 +1,98 @@
.class public abstract Lcom/helpshift/log/HSLogger;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field public static logger:Lcom/helpshift/log/ILogger;
# direct methods
.method public static d(Ljava/lang/String;Ljava/lang/String;)V
.locals 1
const/4 v0, 0x0
.line 12
invoke-static {p0, p1, v0}, Lcom/helpshift/log/HSLogger;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public static d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 1
sget-object v0, Lcom/helpshift/log/HSLogger;->logger:Lcom/helpshift/log/ILogger;
if-nez v0, :cond_0
return-void
.line 27
:cond_0
invoke-interface {v0, p0, p1, p2}, Lcom/helpshift/log/ILogger;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public static e(Ljava/lang/String;Ljava/lang/String;)V
.locals 1
const/4 v0, 0x0
.line 20
invoke-static {p0, p1, v0}, Lcom/helpshift/log/HSLogger;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public static e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 1
sget-object v0, Lcom/helpshift/log/HSLogger;->logger:Lcom/helpshift/log/ILogger;
if-nez v0, :cond_0
return-void
.line 41
:cond_0
invoke-interface {v0, p0, p1, p2}, Lcom/helpshift/log/ILogger;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public static initLogger(Lcom/helpshift/log/ILogger;)V
.locals 0
sput-object p0, Lcom/helpshift/log/HSLogger;->logger:Lcom/helpshift/log/ILogger;
return-void
.end method
.method public static w(Ljava/lang/String;Ljava/lang/String;)V
.locals 1
const/4 v0, 0x0
.line 16
invoke-static {p0, p1, v0}, Lcom/helpshift/log/HSLogger;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public static w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 1
sget-object v0, Lcom/helpshift/log/HSLogger;->logger:Lcom/helpshift/log/ILogger;
if-nez v0, :cond_0
return-void
.line 34
:cond_0
invoke-interface {v0, p0, p1, p2}, Lcom/helpshift/log/ILogger;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method

View File

@@ -0,0 +1,115 @@
.class public final enum Lcom/helpshift/log/ILogger$LEVEL;
.super Ljava/lang/Enum;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/helpshift/log/ILogger;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x4019
name = "LEVEL"
.end annotation
# static fields
.field private static final synthetic $VALUES:[Lcom/helpshift/log/ILogger$LEVEL;
.field public static final enum DEBUG:Lcom/helpshift/log/ILogger$LEVEL;
.field public static final enum ERROR:Lcom/helpshift/log/ILogger$LEVEL;
.field public static final enum WARN:Lcom/helpshift/log/ILogger$LEVEL;
# direct methods
.method static constructor <clinit>()V
.locals 5
.line 21
new-instance v0, Lcom/helpshift/log/ILogger$LEVEL;
const-string v1, "DEBUG"
const/4 v2, 0x0
invoke-direct {v0, v1, v2}, Lcom/helpshift/log/ILogger$LEVEL;-><init>(Ljava/lang/String;I)V
sput-object v0, Lcom/helpshift/log/ILogger$LEVEL;->DEBUG:Lcom/helpshift/log/ILogger$LEVEL;
.line 22
new-instance v1, Lcom/helpshift/log/ILogger$LEVEL;
const-string v2, "WARN"
const/4 v3, 0x1
invoke-direct {v1, v2, v3}, Lcom/helpshift/log/ILogger$LEVEL;-><init>(Ljava/lang/String;I)V
sput-object v1, Lcom/helpshift/log/ILogger$LEVEL;->WARN:Lcom/helpshift/log/ILogger$LEVEL;
.line 23
new-instance v2, Lcom/helpshift/log/ILogger$LEVEL;
const-string v3, "ERROR"
const/4 v4, 0x2
invoke-direct {v2, v3, v4}, Lcom/helpshift/log/ILogger$LEVEL;-><init>(Ljava/lang/String;I)V
sput-object v2, Lcom/helpshift/log/ILogger$LEVEL;->ERROR:Lcom/helpshift/log/ILogger$LEVEL;
filled-new-array {v0, v1, v2}, [Lcom/helpshift/log/ILogger$LEVEL;
move-result-object v0
sput-object v0, Lcom/helpshift/log/ILogger$LEVEL;->$VALUES:[Lcom/helpshift/log/ILogger$LEVEL;
return-void
.end method
.method private constructor <init>(Ljava/lang/String;I)V
.locals 0
.annotation system Ldalvik/annotation/Signature;
value = {
"()V"
}
.end annotation
.line 20
invoke-direct {p0, p1, p2}, Ljava/lang/Enum;-><init>(Ljava/lang/String;I)V
return-void
.end method
.method public static valueOf(Ljava/lang/String;)Lcom/helpshift/log/ILogger$LEVEL;
.locals 1
const-class v0, Lcom/helpshift/log/ILogger$LEVEL;
.line 20
invoke-static {v0, p0}, Ljava/lang/Enum;->valueOf(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Enum;
move-result-object p0
check-cast p0, Lcom/helpshift/log/ILogger$LEVEL;
return-object p0
.end method
.method public static values()[Lcom/helpshift/log/ILogger$LEVEL;
.locals 1
sget-object v0, Lcom/helpshift/log/ILogger$LEVEL;->$VALUES:[Lcom/helpshift/log/ILogger$LEVEL;
.line 20
invoke-virtual {v0}, [Lcom/helpshift/log/ILogger$LEVEL;->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lcom/helpshift/log/ILogger$LEVEL;
return-object v0
.end method

View File

@@ -0,0 +1,22 @@
.class public interface abstract Lcom/helpshift/log/ILogger;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/helpshift/log/ILogger$LEVEL;
}
.end annotation
# virtual methods
.method public abstract d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.end method
.method public abstract e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.end method
.method public abstract w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.end method

View File

@@ -0,0 +1,83 @@
.class public abstract synthetic Lcom/helpshift/log/InternalHelpshiftLogger$1;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/helpshift/log/InternalHelpshiftLogger;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x1009
name = null
.end annotation
# static fields
.field public static final synthetic $SwitchMap$com$helpshift$log$ILogger$LEVEL:[I
# direct methods
.method static constructor <clinit>()V
.locals 3
.line 65
invoke-static {}, Lcom/helpshift/log/ILogger$LEVEL;->values()[Lcom/helpshift/log/ILogger$LEVEL;
move-result-object v0
array-length v0, v0
new-array v0, v0, [I
sput-object v0, Lcom/helpshift/log/InternalHelpshiftLogger$1;->$SwitchMap$com$helpshift$log$ILogger$LEVEL:[I
:try_start_0
sget-object v1, Lcom/helpshift/log/ILogger$LEVEL;->ERROR:Lcom/helpshift/log/ILogger$LEVEL;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x1
aput v2, v0, v1
:try_end_0
.catch Ljava/lang/NoSuchFieldError; {:try_start_0 .. :try_end_0} :catch_0
:catch_0
:try_start_1
sget-object v0, Lcom/helpshift/log/InternalHelpshiftLogger$1;->$SwitchMap$com$helpshift$log$ILogger$LEVEL:[I
sget-object v1, Lcom/helpshift/log/ILogger$LEVEL;->WARN:Lcom/helpshift/log/ILogger$LEVEL;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x2
aput v2, v0, v1
:try_end_1
.catch Ljava/lang/NoSuchFieldError; {:try_start_1 .. :try_end_1} :catch_1
:catch_1
:try_start_2
sget-object v0, Lcom/helpshift/log/InternalHelpshiftLogger$1;->$SwitchMap$com$helpshift$log$ILogger$LEVEL:[I
sget-object v1, Lcom/helpshift/log/ILogger$LEVEL;->DEBUG:Lcom/helpshift/log/ILogger$LEVEL;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x3
aput v2, v0, v1
:try_end_2
.catch Ljava/lang/NoSuchFieldError; {:try_start_2 .. :try_end_2} :catch_2
:catch_2
return-void
.end method

View File

@@ -0,0 +1,142 @@
.class public Lcom/helpshift/log/InternalHelpshiftLogger;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/helpshift/log/ILogger;
# instance fields
.field public final isAppInDebugMode:Z
.field public logCollector:Lcom/helpshift/log/LogCollector;
.field public final shouldEnableLogging:Z
# direct methods
.method public constructor <init>(ZZ)V
.locals 0
.line 15
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-boolean p1, p0, Lcom/helpshift/log/InternalHelpshiftLogger;->isAppInDebugMode:Z
iput-boolean p2, p0, Lcom/helpshift/log/InternalHelpshiftLogger;->shouldEnableLogging:Z
return-void
.end method
# virtual methods
.method public d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 1
.line 41
sget-object v0, Lcom/helpshift/log/ILogger$LEVEL;->DEBUG:Lcom/helpshift/log/ILogger$LEVEL;
invoke-virtual {p0, v0, p1, p2, p3}, Lcom/helpshift/log/InternalHelpshiftLogger;->logMessage(Lcom/helpshift/log/ILogger$LEVEL;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 1
.line 51
sget-object v0, Lcom/helpshift/log/ILogger$LEVEL;->ERROR:Lcom/helpshift/log/ILogger$LEVEL;
invoke-virtual {p0, v0, p1, p2, p3}, Lcom/helpshift/log/InternalHelpshiftLogger;->logMessage(Lcom/helpshift/log/ILogger$LEVEL;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public final logMessage(Lcom/helpshift/log/ILogger$LEVEL;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 2
iget-boolean v0, p0, Lcom/helpshift/log/InternalHelpshiftLogger;->shouldEnableLogging:Z
if-nez v0, :cond_0
return-void
.line 63
:cond_0
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
.line 65
sget-object p3, Lcom/helpshift/log/InternalHelpshiftLogger$1;->$SwitchMap$com$helpshift$log$ILogger$LEVEL:[I
invoke-virtual {p1}, Ljava/lang/Enum;->ordinal()I
move-result v0
aget p3, p3, v0
const/4 v0, 0x1
const-string v1, "Helpshift"
if-eq p3, v0, :cond_2
const/4 v0, 0x2
if-eq p3, v0, :cond_1
goto :goto_0
.line 71
:cond_1
invoke-static {v1, p2, p4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_0
.line 67
:cond_2
invoke-static {v1, p2, p4}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:goto_0
iget-object p3, p0, Lcom/helpshift/log/InternalHelpshiftLogger;->logCollector:Lcom/helpshift/log/LogCollector;
if-eqz p3, :cond_3
.line 83
invoke-virtual {p3, v1, p2, p4, p1}, Lcom/helpshift/log/LogCollector;->collectLog(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Lcom/helpshift/log/ILogger$LEVEL;)V
:cond_3
return-void
.end method
.method public setLogCollector(Lcom/helpshift/log/LogCollector;)V
.locals 0
iput-object p1, p0, Lcom/helpshift/log/InternalHelpshiftLogger;->logCollector:Lcom/helpshift/log/LogCollector;
return-void
.end method
.method public w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 1
.line 46
sget-object v0, Lcom/helpshift/log/ILogger$LEVEL;->WARN:Lcom/helpshift/log/ILogger$LEVEL;
invoke-virtual {p0, v0, p1, p2, p3}, Lcom/helpshift/log/InternalHelpshiftLogger;->logMessage(Lcom/helpshift/log/ILogger$LEVEL;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method

View File

@@ -0,0 +1,219 @@
.class public Lcom/helpshift/log/LogCollector$1;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingMethod;
value = Lcom/helpshift/log/LogCollector;->collectLog(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Lcom/helpshift/log/ILogger$LEVEL;)V
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x1
name = null
.end annotation
# instance fields
.field public final synthetic this$0:Lcom/helpshift/log/LogCollector;
.field public final synthetic val$currentThreadId:J
.field public final synthetic val$level:Lcom/helpshift/log/ILogger$LEVEL;
.field public final synthetic val$message:Ljava/lang/String;
.field public final synthetic val$tag:Ljava/lang/String;
.field public final synthetic val$time:J
.field public final synthetic val$tr:Ljava/lang/Throwable;
# direct methods
.method public constructor <init>(Lcom/helpshift/log/LogCollector;JJLcom/helpshift/log/ILogger$LEVEL;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.locals 0
iput-object p1, p0, Lcom/helpshift/log/LogCollector$1;->this$0:Lcom/helpshift/log/LogCollector;
iput-wide p2, p0, Lcom/helpshift/log/LogCollector$1;->val$time:J
iput-wide p4, p0, Lcom/helpshift/log/LogCollector$1;->val$currentThreadId:J
iput-object p6, p0, Lcom/helpshift/log/LogCollector$1;->val$level:Lcom/helpshift/log/ILogger$LEVEL;
iput-object p7, p0, Lcom/helpshift/log/LogCollector$1;->val$tag:Ljava/lang/String;
iput-object p8, p0, Lcom/helpshift/log/LogCollector$1;->val$message:Ljava/lang/String;
iput-object p9, p0, Lcom/helpshift/log/LogCollector$1;->val$tr:Ljava/lang/Throwable;
.line 52
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public run()V
.locals 5
const-string v0, " "
:try_start_0
iget-object v1, p0, Lcom/helpshift/log/LogCollector$1;->this$0:Lcom/helpshift/log/LogCollector;
.line 56
invoke-static {v1}, Lcom/helpshift/log/LogCollector;->access$000(Lcom/helpshift/log/LogCollector;)Ljava/text/SimpleDateFormat;
move-result-object v1
new-instance v2, Ljava/util/Date;
iget-wide v3, p0, Lcom/helpshift/log/LogCollector$1;->val$time:J
invoke-direct {v2, v3, v4}, Ljava/util/Date;-><init>(J)V
invoke-virtual {v1, v2}, Ljava/text/DateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v1
.line 57
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
.line 58
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 59
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/helpshift/log/LogCollector$1;->this$0:Lcom/helpshift/log/LogCollector;
.line 60
invoke-static {v1}, Lcom/helpshift/log/LogCollector;->access$100(Lcom/helpshift/log/LogCollector;)J
move-result-wide v3
invoke-virtual {v2, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v1, "-"
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v3, p0, Lcom/helpshift/log/LogCollector$1;->val$currentThreadId:J
invoke-virtual {v2, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
.line 61
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/helpshift/log/LogCollector$1;->val$level:Lcom/helpshift/log/ILogger$LEVEL;
.line 62
invoke-virtual {v1}, Ljava/lang/Enum;->name()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "/"
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/helpshift/log/LogCollector$1;->val$tag:Ljava/lang/String;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 63
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v0, p0, Lcom/helpshift/log/LogCollector$1;->val$message:Ljava/lang/String;
.line 64
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v0, p0, Lcom/helpshift/log/LogCollector$1;->val$tr:Ljava/lang/Throwable;
.line 67
instance-of v1, v0, Ljava/net/UnknownHostException;
if-eqz v1, :cond_0
.line 68
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
goto :goto_0
:catch_0
move-exception v0
goto :goto_1
.line 70
:cond_0
invoke-static {v0}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
move-result-object v0
.line 73
:goto_0
invoke-static {v0}, Lcom/helpshift/util/Utils;->isEmpty(Ljava/lang/String;)Z
move-result v1
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
const-string v3, "\n"
if-nez v1, :cond_1
.line 74
:try_start_1
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 77
:cond_1
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v0, p0, Lcom/helpshift/log/LogCollector$1;->this$0:Lcom/helpshift/log/LogCollector;
.line 78
invoke-static {v0}, Lcom/helpshift/log/LogCollector;->access$200(Lcom/helpshift/log/LogCollector;)Ljava/io/FileOutputStream;
move-result-object v0
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->getBytes()[B
move-result-object v1
invoke-virtual {v0, v1}, Ljava/io/FileOutputStream;->write([B)V
:try_end_1
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0
goto :goto_2
:goto_1
const-string v1, "Heplshift_LogCollector"
const-string v2, "Error writing to debug log file"
.line 80
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:goto_2
return-void
.end method

View File

@@ -0,0 +1,299 @@
.class public Lcom/helpshift/log/LogCollector;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field public static final logDirPath:Ljava/lang/String;
# instance fields
.field public final dateFormat:Ljava/text/SimpleDateFormat;
.field public final executorService:Ljava/util/concurrent/ExecutorService;
.field public fos:Ljava/io/FileOutputStream;
.field public final logFile:Ljava/io/File;
.field public final mainThreadId:J
# direct methods
.method static constructor <clinit>()V
.locals 2
.line 27
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "helpshift"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v1, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "debugLogs"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/helpshift/log/LogCollector;->logDirPath:Ljava/lang/String;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;Ljava/lang/String;J)V
.locals 3
.line 29
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 21
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadExecutor()Ljava/util/concurrent/ExecutorService;
move-result-object v0
iput-object v0, p0, Lcom/helpshift/log/LogCollector;->executorService:Ljava/util/concurrent/ExecutorService;
.line 22
new-instance v0, Ljava/text/SimpleDateFormat;
const-string v1, "yyyy-MM-dd HH:mm:ss.SSS"
sget-object v2, Ljava/util/Locale;->US:Ljava/util/Locale;
invoke-direct {v0, v1, v2}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
iput-object v0, p0, Lcom/helpshift/log/LogCollector;->dateFormat:Ljava/text/SimpleDateFormat;
.line 30
invoke-virtual {p1}, Landroid/content/Context;->getFilesDir()Ljava/io/File;
move-result-object p1
.line 31
new-instance v0, Ljava/io/File;
sget-object v1, Lcom/helpshift/log/LogCollector;->logDirPath:Ljava/lang/String;
invoke-direct {v0, p1, v1}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 32
invoke-virtual {v0}, Ljava/io/File;->mkdirs()Z
.line 33
invoke-virtual {p0, v0}, Lcom/helpshift/log/LogCollector;->deleteOldFiles(Ljava/io/File;)V
.line 35
new-instance p1, Ljava/io/File;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p2, ".txt"
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, v0, p2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
iput-object p1, p0, Lcom/helpshift/log/LogCollector;->logFile:Ljava/io/File;
iput-wide p3, p0, Lcom/helpshift/log/LogCollector;->mainThreadId:J
return-void
.end method
.method public static synthetic access$000(Lcom/helpshift/log/LogCollector;)Ljava/text/SimpleDateFormat;
.locals 0
.line 18
iget-object p0, p0, Lcom/helpshift/log/LogCollector;->dateFormat:Ljava/text/SimpleDateFormat;
return-object p0
.end method
.method public static synthetic access$100(Lcom/helpshift/log/LogCollector;)J
.locals 2
.line 18
iget-wide v0, p0, Lcom/helpshift/log/LogCollector;->mainThreadId:J
return-wide v0
.end method
.method public static synthetic access$200(Lcom/helpshift/log/LogCollector;)Ljava/io/FileOutputStream;
.locals 0
.line 18
iget-object p0, p0, Lcom/helpshift/log/LogCollector;->fos:Ljava/io/FileOutputStream;
return-object p0
.end method
# virtual methods
.method public collectLog(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;Lcom/helpshift/log/ILogger$LEVEL;)V
.locals 14
move-object v11, p0
.line 40
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v3
.line 41
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Thread;->getId()J
move-result-wide v5
iget-object v0, v11, Lcom/helpshift/log/LogCollector;->fos:Ljava/io/FileOutputStream;
const-string v12, "Heplshift_LogCollector"
if-nez v0, :cond_0
.line 44
:try_start_0
new-instance v0, Ljava/io/FileOutputStream;
iget-object v1, v11, Lcom/helpshift/log/LogCollector;->logFile:Ljava/io/File;
const/4 v2, 0x1
invoke-direct {v0, v1, v2}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
iput-object v0, v11, Lcom/helpshift/log/LogCollector;->fos:Ljava/io/FileOutputStream;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception v0
.line 46
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Error opening debug log file: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, v11, Lcom/helpshift/log/LogCollector;->logFile:Ljava/io/File;
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v12, v1, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
return-void
:cond_0
:goto_0
:try_start_1
iget-object v0, v11, Lcom/helpshift/log/LogCollector;->executorService:Ljava/util/concurrent/ExecutorService;
.line 52
new-instance v13, Lcom/helpshift/log/LogCollector$1;
move-object v1, v13
move-object v2, p0
move-object/from16 v7, p4
move-object v8, p1
move-object/from16 v9, p2
move-object/from16 v10, p3
invoke-direct/range {v1 .. v10}, Lcom/helpshift/log/LogCollector$1;-><init>(Lcom/helpshift/log/LogCollector;JJLcom/helpshift/log/ILogger$LEVEL;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
invoke-interface {v0, v13}, Ljava/util/concurrent/ExecutorService;->submit(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
:try_end_1
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_1
goto :goto_1
:catch_1
move-exception v0
const-string v1, "Error submitting to executor"
.line 85
invoke-static {v12, v1, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:goto_1
return-void
.end method
.method public final deleteOldFiles(Ljava/io/File;)V
.locals 3
.line 90
invoke-virtual {p1}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object p1
if-eqz p1, :cond_0
.line 91
array-length v0, p1
const/4 v1, 0x5
if-le v0, v1, :cond_0
.line 92
invoke-static {p1}, Ljava/util/Arrays;->sort([Ljava/lang/Object;)V
const/4 v0, 0x0
.line 93
:goto_0
array-length v2, p1
sub-int/2addr v2, v1
if-ge v0, v2, :cond_0
.line 94
aget-object v2, p1, v0
invoke-virtual {v2}, Ljava/io/File;->delete()Z
add-int/lit8 v0, v0, 0x1
goto :goto_0
:cond_0
return-void
.end method

View File

@@ -0,0 +1,115 @@
.class public abstract synthetic Lcom/helpshift/log/WebviewConsoleLogger$1;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/helpshift/log/WebviewConsoleLogger;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x1009
name = null
.end annotation
# static fields
.field public static final synthetic $SwitchMap$android$webkit$ConsoleMessage$MessageLevel:[I
# direct methods
.method static constructor <clinit>()V
.locals 3
.line 15
invoke-static {}, Landroid/webkit/ConsoleMessage$MessageLevel;->values()[Landroid/webkit/ConsoleMessage$MessageLevel;
move-result-object v0
array-length v0, v0
new-array v0, v0, [I
sput-object v0, Lcom/helpshift/log/WebviewConsoleLogger$1;->$SwitchMap$android$webkit$ConsoleMessage$MessageLevel:[I
:try_start_0
sget-object v1, Landroid/webkit/ConsoleMessage$MessageLevel;->ERROR:Landroid/webkit/ConsoleMessage$MessageLevel;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x1
aput v2, v0, v1
:try_end_0
.catch Ljava/lang/NoSuchFieldError; {:try_start_0 .. :try_end_0} :catch_0
:catch_0
:try_start_1
sget-object v0, Lcom/helpshift/log/WebviewConsoleLogger$1;->$SwitchMap$android$webkit$ConsoleMessage$MessageLevel:[I
sget-object v1, Landroid/webkit/ConsoleMessage$MessageLevel;->WARNING:Landroid/webkit/ConsoleMessage$MessageLevel;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x2
aput v2, v0, v1
:try_end_1
.catch Ljava/lang/NoSuchFieldError; {:try_start_1 .. :try_end_1} :catch_1
:catch_1
:try_start_2
sget-object v0, Lcom/helpshift/log/WebviewConsoleLogger$1;->$SwitchMap$android$webkit$ConsoleMessage$MessageLevel:[I
sget-object v1, Landroid/webkit/ConsoleMessage$MessageLevel;->DEBUG:Landroid/webkit/ConsoleMessage$MessageLevel;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x3
aput v2, v0, v1
:try_end_2
.catch Ljava/lang/NoSuchFieldError; {:try_start_2 .. :try_end_2} :catch_2
:catch_2
:try_start_3
sget-object v0, Lcom/helpshift/log/WebviewConsoleLogger$1;->$SwitchMap$android$webkit$ConsoleMessage$MessageLevel:[I
sget-object v1, Landroid/webkit/ConsoleMessage$MessageLevel;->LOG:Landroid/webkit/ConsoleMessage$MessageLevel;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x4
aput v2, v0, v1
:try_end_3
.catch Ljava/lang/NoSuchFieldError; {:try_start_3 .. :try_end_3} :catch_3
:catch_3
:try_start_4
sget-object v0, Lcom/helpshift/log/WebviewConsoleLogger$1;->$SwitchMap$android$webkit$ConsoleMessage$MessageLevel:[I
sget-object v1, Landroid/webkit/ConsoleMessage$MessageLevel;->TIP:Landroid/webkit/ConsoleMessage$MessageLevel;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x5
aput v2, v0, v1
:try_end_4
.catch Ljava/lang/NoSuchFieldError; {:try_start_4 .. :try_end_4} :catch_4
:catch_4
return-void
.end method

View File

@@ -0,0 +1,52 @@
.class public abstract Lcom/helpshift/log/WebviewConsoleLogger;
.super Ljava/lang/Object;
.source "SourceFile"
# direct methods
.method public static log(Landroid/webkit/ConsoleMessage$MessageLevel;Ljava/lang/String;Ljava/lang/String;)V
.locals 1
if-nez p0, :cond_0
.line 12
invoke-static {p1, p2}, Lcom/helpshift/log/HSLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 15
:cond_0
sget-object v0, Lcom/helpshift/log/WebviewConsoleLogger$1;->$SwitchMap$android$webkit$ConsoleMessage$MessageLevel:[I
invoke-virtual {p0}, Ljava/lang/Enum;->ordinal()I
move-result p0
aget p0, v0, p0
const/4 v0, 0x1
if-eq p0, v0, :cond_2
const/4 v0, 0x2
if-eq p0, v0, :cond_1
.line 26
invoke-static {p1, p2}, Lcom/helpshift/log/HSLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_0
.line 20
:cond_1
invoke-static {p1, p2}, Lcom/helpshift/log/HSLogger;->w(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_0
.line 17
:cond_2
invoke-static {p1, p2}, Lcom/helpshift/log/HSLogger;->e(Ljava/lang/String;Ljava/lang/String;)V
:goto_0
return-void
.end method