.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 ()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 (Lio/sentry/ILogger;)V .locals 1 .line 26 invoke-direct {p0}, Ljava/lang/Object;->()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;->()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;->(Ljava/io/InputStream;Ljava/nio/charset/Charset;)V invoke-direct {v1, v2}, Ljava/io/BufferedReader;->(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