Rabbit-R1/android (non root)/smali/smali_classes3/io/sentry/internal/modules/ModulesLoader.smali

271 lines
6.9 KiB
Smali
Raw Normal View History

2024-05-21 21:08:36 +00:00
.class public abstract Lio/sentry/internal/modules/ModulesLoader;
.super Ljava/lang/Object;
.source "ModulesLoader.java"
# interfaces
.implements Lio/sentry/internal/modules/IModulesLoader;
# static fields
.field public static final EXTERNAL_MODULES_FILENAME:Ljava/lang/String; = "sentry-external-modules.txt"
.field private static final UTF_8:Ljava/nio/charset/Charset;
# instance fields
.field private cachedModules:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field protected final logger:Lio/sentry/ILogger;
# direct methods
.method static constructor <clinit>()V
.locals 1
const-string v0, "UTF-8"
.line 20
invoke-static {v0}, Ljava/nio/charset/Charset;->forName(Ljava/lang/String;)Ljava/nio/charset/Charset;
move-result-object v0
sput-object v0, Lio/sentry/internal/modules/ModulesLoader;->UTF_8:Ljava/nio/charset/Charset;
return-void
.end method
.method public constructor <init>(Lio/sentry/ILogger;)V
.locals 1
.line 26
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
iput-object v0, p0, Lio/sentry/internal/modules/ModulesLoader;->cachedModules:Ljava/util/Map;
iput-object p1, p0, Lio/sentry/internal/modules/ModulesLoader;->logger:Lio/sentry/ILogger;
return-void
.end method
# virtual methods
.method public getOrLoadModules()Ljava/util/Map;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
iget-object v0, p0, Lio/sentry/internal/modules/ModulesLoader;->cachedModules:Ljava/util/Map;
if-eqz v0, :cond_0
return-object v0
.line 35
:cond_0
invoke-virtual {p0}, Lio/sentry/internal/modules/ModulesLoader;->loadModules()Ljava/util/Map;
move-result-object v0
iput-object v0, p0, Lio/sentry/internal/modules/ModulesLoader;->cachedModules:Ljava/util/Map;
return-object v0
.end method
.method protected abstract loadModules()Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.end method
.method protected parseStream(Ljava/io/InputStream;)Ljava/util/Map;
.locals 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/io/InputStream;",
")",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.line 42
new-instance v0, Ljava/util/TreeMap;
invoke-direct {v0}, Ljava/util/TreeMap;-><init>()V
.line 43
:try_start_0
new-instance v1, Ljava/io/BufferedReader;
new-instance v2, Ljava/io/InputStreamReader;
sget-object v3, Lio/sentry/internal/modules/ModulesLoader;->UTF_8:Ljava/nio/charset/Charset;
invoke-direct {v2, p1, v3}, Ljava/io/InputStreamReader;-><init>(Ljava/io/InputStream;Ljava/nio/charset/Charset;)V
invoke-direct {v1, v2}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;)V
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_1
.catch Ljava/lang/RuntimeException; {:try_start_0 .. :try_end_0} :catch_0
.line 44
:try_start_1
invoke-virtual {v1}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object p1
:goto_0
const/4 v2, 0x0
if-eqz p1, :cond_0
const/16 v3, 0x3a
.line 46
invoke-virtual {p1, v3}, Ljava/lang/String;->lastIndexOf(I)I
move-result v3
.line 47
invoke-virtual {p1, v2, v3}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v2
add-int/lit8 v3, v3, 0x1
.line 48
invoke-virtual {p1, v3}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object p1
.line 49
invoke-interface {v0, v2, p1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 50
invoke-virtual {v1}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object p1
goto :goto_0
:cond_0
iget-object p1, p0, Lio/sentry/internal/modules/ModulesLoader;->logger:Lio/sentry/ILogger;
.line 52
sget-object v3, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
const-string v4, "Extracted %d modules from resources."
const/4 v5, 0x1
new-array v5, v5, [Ljava/lang/Object;
invoke-interface {v0}, Ljava/util/Map;->size()I
move-result v6
invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v6
aput-object v6, v5, v2
invoke-interface {p1, v3, v4, v5}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
.line 53
:try_start_2
invoke-virtual {v1}, Ljava/io/BufferedReader;->close()V
:try_end_2
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_1
.catch Ljava/lang/RuntimeException; {:try_start_2 .. :try_end_2} :catch_0
goto :goto_2
:catchall_0
move-exception p1
.line 43
:try_start_3
invoke-virtual {v1}, Ljava/io/BufferedReader;->close()V
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_1
goto :goto_1
:catchall_1
move-exception v1
:try_start_4
invoke-virtual {p1, v1}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V
:goto_1
throw p1
:try_end_4
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_1
.catch Ljava/lang/RuntimeException; {:try_start_4 .. :try_end_4} :catch_0
:catch_0
move-exception p1
iget-object p0, p0, Lio/sentry/internal/modules/ModulesLoader;->logger:Lio/sentry/ILogger;
.line 56
sget-object v1, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
const-string v2, "sentry-external-modules.txt"
filled-new-array {v2}, [Ljava/lang/Object;
move-result-object v2
const-string v3, "%s file is malformed."
invoke-interface {p0, v1, p1, v3, v2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_2
:catch_1
move-exception p1
iget-object p0, p0, Lio/sentry/internal/modules/ModulesLoader;->logger:Lio/sentry/ILogger;
.line 54
sget-object v1, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel;
const-string v2, "Error extracting modules."
invoke-interface {p0, v1, v2, p1}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;Ljava/lang/Throwable;)V
:goto_2
return-object v0
.end method