e.smali

.class public final Lcom/getkeepsafe/relinker/e;
.super Ljava/lang/Object;
.source "SourceFile"


# static fields
.field public static final f:Ljava/util/List;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/List<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field


# instance fields
.field public final a:Ljava/util/HashSet;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Set<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field

.field public final b:Lcom/getkeepsafe/relinker/c$b;

.field public final c:Lcom/getkeepsafe/relinker/c$a;

.field public d:Z

.field public final e:Ljava/util/ArrayList;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/List<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field


# direct methods
.method public static constructor <clinit>()V
    .registers 6

    const-string v0, "libandroid.so"

    const-string v1, "liblog.so"

    const-string v2, "libm.so"

    const-string v3, "libc++_shared.so"

    const-string v4, "libdl.so"

    const-string v5, "libc.so"

    filled-new-array/range {v0 .. v5}, [Ljava/lang/String;

    move-result-object v0

    invoke-static {v0}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;

    move-result-object v0

    sput-object v0, Lcom/getkeepsafe/relinker/e;->f:Ljava/util/List;

    return-void
.end method

.method public constructor <init>()V
    .registers 5

    .line 1
    new-instance v0, Lcom/getkeepsafe/relinker/f;

    invoke-direct {v0}, Lcom/getkeepsafe/relinker/f;-><init>()V

    new-instance v1, Lcom/getkeepsafe/relinker/a;

    invoke-direct {v1}, Lcom/getkeepsafe/relinker/a;-><init>()V

    .line 2
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 3
    new-instance v2, Ljava/util/HashSet;

    invoke-direct {v2}, Ljava/util/HashSet;-><init>()V

    iput-object v2, p0, Lcom/getkeepsafe/relinker/e;->a:Ljava/util/HashSet;

    .line 4
    new-instance v2, Ljava/util/ArrayList;

    sget-object v3, Lcom/getkeepsafe/relinker/e;->f:Ljava/util/List;

    invoke-direct {v2, v3}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V

    iput-object v2, p0, Lcom/getkeepsafe/relinker/e;->e:Ljava/util/ArrayList;

    .line 5
    iput-object v0, p0, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    .line 6
    iput-object v1, p0, Lcom/getkeepsafe/relinker/e;->c:Lcom/getkeepsafe/relinker/c$a;

    return-void
.end method


# virtual methods
.method public final a(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Ljava/io/File;
    .registers 7

    .line 1
    iget-object v0, p0, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    check-cast v0, Lcom/getkeepsafe/relinker/f;

    invoke-virtual {v0, p2}, Lcom/getkeepsafe/relinker/f;->a(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p2

    .line 2
    invoke-static {p3}, Landroidx/appcompat/c;->p0(Ljava/lang/CharSequence;)Z

    move-result v0

    const/4 v1, 0x0

    const-string v2, "lib"

    if-eqz v0, :cond_1b

    .line 3
    new-instance p3, Ljava/io/File;

    .line 4
    invoke-virtual {p1, v2, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File;

    move-result-object p1

    .line 5
    invoke-direct {p3, p1, p2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V

    return-object p3

    .line 6
    :cond_1b
    new-instance v0, Ljava/io/File;

    .line 7
    invoke-virtual {p1, v2, v1}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File;

    move-result-object p1

    const-string v1, "."

    .line 8
    invoke-static {p2, v1, p3}, Landroidx/biometric/i0;->c(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object p2

    .line 9
    invoke-direct {v0, p1, p2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V

    return-object v0
.end method

.method public final b(Landroid/content/Context;Ljava/lang/String;)V
    .registers 5

    if-eqz p1, :cond_20

    .line 1
    invoke-static {p2}, Landroidx/appcompat/c;->p0(Ljava/lang/CharSequence;)Z

    move-result v0

    if-nez v0, :cond_18

    const/4 v0, 0x1

    new-array v0, v0, [Ljava/lang/Object;

    const/4 v1, 0x0

    aput-object p2, v0, v1

    const-string v1, "Beginning load of %s..."

    .line 2
    invoke-virtual {p0, v1, v0}, Lcom/getkeepsafe/relinker/e;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    const/4 v0, 0x0

    .line 3
    invoke-virtual {p0, p1, p2, v0}, Lcom/getkeepsafe/relinker/e;->c(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V

    return-void

    .line 4
    :cond_18
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string p2, "Given library is either null or empty"

    invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V

    throw p1

    .line 5
    :cond_20
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string p2, "Given context is null"

    invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V

    throw p1
.end method

.method public final c(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V
    .registers 23

    move-object/from16 v1, p0

    move-object/from16 v2, p1

    move-object/from16 v3, p2

    .line 1
    iget-object v0, v1, Lcom/getkeepsafe/relinker/e;->a:Ljava/util/HashSet;

    invoke-virtual {v0, v3}, Ljava/util/HashSet;->contains(Ljava/lang/Object;)Z

    move-result v0

    const/4 v4, 0x0

    const/4 v5, 0x1

    if-eqz v0, :cond_1a

    new-array v0, v5, [Ljava/lang/Object;

    aput-object v3, v0, v4

    const-string v2, "%s already loaded previously!"

    .line 2
    invoke-virtual {v1, v2, v0}, Lcom/getkeepsafe/relinker/e;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    return-void

    :cond_1a
    const/4 v6, 0x2

    .line 3
    :try_start_1b
    iget-object v0, v1, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    check-cast v0, Lcom/getkeepsafe/relinker/f;

    invoke-static {v0}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object;

    .line 4
    invoke-static/range {p2 .. p2}, Ljava/lang/System;->loadLibrary(Ljava/lang/String;)V

    .line 5
    iget-object v0, v1, Lcom/getkeepsafe/relinker/e;->a:Ljava/util/HashSet;

    invoke-virtual {v0, v3}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z

    const-string v0, "%s (%s) was loaded normally!"

    new-array v7, v6, [Ljava/lang/Object;

    aput-object v3, v7, v4

    aput-object p3, v7, v5

    .line 6
    invoke-virtual {v1, v0, v7}, Lcom/getkeepsafe/relinker/e;->d(Ljava/lang/String;[Ljava/lang/Object;)V
    :try_end_35
    .catch Ljava/lang/UnsatisfiedLinkError; {:try_start_1b .. :try_end_35} :catch_36

    return-void

    :catch_36
    move-exception v0

    new-array v7, v5, [Ljava/lang/Object;

    .line 7
    invoke-static {v0}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object v0

    aput-object v0, v7, v4

    const-string v0, "Loading the library normally failed: %s"

    invoke-virtual {v1, v0, v7}, Lcom/getkeepsafe/relinker/e;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    new-array v0, v6, [Ljava/lang/Object;

    aput-object v3, v0, v4

    aput-object p3, v0, v5

    const-string v7, "%s (%s) was not loaded normally, re-linking..."

    .line 8
    invoke-virtual {v1, v7, v0}, Lcom/getkeepsafe/relinker/e;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 9
    invoke-virtual/range {p0 .. p3}, Lcom/getkeepsafe/relinker/e;->a(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Ljava/io/File;

    move-result-object v7

    .line 10
    invoke-virtual {v7}, Ljava/io/File;->exists()Z

    move-result v0

    if-eqz v0, :cond_5b

    goto/16 :goto_159

    :cond_5b
    const-string v0, "lib"

    .line 11
    invoke-virtual {v2, v0, v4}, Landroid/content/Context;->getDir(Ljava/lang/String;I)Ljava/io/File;

    move-result-object v0

    .line 12
    invoke-virtual/range {p0 .. p3}, Lcom/getkeepsafe/relinker/e;->a(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Ljava/io/File;

    move-result-object v9

    .line 13
    iget-object v10, v1, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    check-cast v10, Lcom/getkeepsafe/relinker/f;

    invoke-virtual {v10, v3}, Lcom/getkeepsafe/relinker/f;->a(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v10

    .line 14
    new-instance v11, Lcom/getkeepsafe/relinker/d;

    invoke-direct {v11, v10}, Lcom/getkeepsafe/relinker/d;-><init>(Ljava/lang/String;)V

    invoke-virtual {v0, v11}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;

    move-result-object v0

    if-nez v0, :cond_79

    goto :goto_93

    .line 15
    :cond_79
    array-length v10, v0

    const/4 v11, 0x0

    :goto_7b
    if-ge v11, v10, :cond_93

    aget-object v12, v0, v11

    .line 16
    invoke-virtual {v12}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v13

    invoke-virtual {v9}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v14

    invoke-virtual {v13, v14}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v13

    if-nez v13, :cond_90

    .line 17
    invoke-virtual {v12}, Ljava/io/File;->delete()Z

    :cond_90
    add-int/lit8 v11, v11, 0x1

    goto :goto_7b

    .line 18
    :cond_93
    :goto_93
    iget-object v0, v1, Lcom/getkeepsafe/relinker/e;->c:Lcom/getkeepsafe/relinker/c$a;

    iget-object v9, v1, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    check-cast v9, Lcom/getkeepsafe/relinker/f;

    invoke-static {v9}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object;

    .line 19
    sget-object v9, Landroid/os/Build;->SUPPORTED_ABIS:[Ljava/lang/String;

    array-length v10, v9

    if-lez v10, :cond_a2

    goto :goto_ba

    .line 20
    :cond_a2
    sget-object v9, Landroid/os/Build;->CPU_ABI2:Ljava/lang/String;

    invoke-static {v9}, Landroidx/appcompat/c;->p0(Ljava/lang/CharSequence;)Z

    move-result v10

    if-nez v10, :cond_b4

    new-array v10, v6, [Ljava/lang/String;

    .line 21
    sget-object v11, Landroid/os/Build;->CPU_ABI:Ljava/lang/String;

    aput-object v11, v10, v4

    aput-object v9, v10, v5

    move-object v9, v10

    goto :goto_ba

    :cond_b4
    new-array v9, v5, [Ljava/lang/String;

    .line 22
    sget-object v10, Landroid/os/Build;->CPU_ABI:Ljava/lang/String;

    aput-object v10, v9, v4

    .line 23
    :goto_ba
    iget-object v10, v1, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    .line 24
    check-cast v10, Lcom/getkeepsafe/relinker/f;

    invoke-virtual {v10, v3}, Lcom/getkeepsafe/relinker/f;->a(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v10

    .line 25
    move-object v11, v0

    check-cast v11, Lcom/getkeepsafe/relinker/a;

    invoke-static {v11}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object;

    .line 26
    :try_start_c8
    invoke-virtual {v11, v2, v9, v10, v1}, Lcom/getkeepsafe/relinker/a;->b(Landroid/content/Context;[Ljava/lang/String;Ljava/lang/String;Lcom/getkeepsafe/relinker/e;)Lcom/getkeepsafe/relinker/a$a;

    move-result-object v12
    :try_end_cc
    .catchall {:try_start_c8 .. :try_end_cc} :catchall_1ef

    if-eqz v12, :cond_1d5

    const/4 v0, 0x0

    :goto_cf
    add-int/lit8 v9, v0, 0x1

    const/4 v13, 0x5

    if-ge v0, v13, :cond_152

    :try_start_d4
    const-string v0, "Found %s! Extracting..."

    new-array v13, v5, [Ljava/lang/Object;

    aput-object v10, v13, v4

    .line 27
    invoke-virtual {v1, v0, v13}, Lcom/getkeepsafe/relinker/e;->d(Ljava/lang/String;[Ljava/lang/Object;)V
    :try_end_dd
    .catchall {:try_start_d4 .. :try_end_dd} :catchall_1da

    .line 28
    :try_start_dd
    invoke-virtual {v7}, Ljava/io/File;->exists()Z

    move-result v0

    if-nez v0, :cond_ea

    invoke-virtual {v7}, Ljava/io/File;->createNewFile()Z

    move-result v0
    :try_end_e7
    .catch Ljava/io/IOException; {:try_start_dd .. :try_end_e7} :catch_14d
    .catchall {:try_start_dd .. :try_end_e7} :catchall_1da

    if-nez v0, :cond_ea

    goto :goto_14d

    .line 29
    :cond_ea
    :try_start_ea
    iget-object v0, v12, Lcom/getkeepsafe/relinker/a$a;->a:Ljava/util/zip/ZipFile;

    iget-object v13, v12, Lcom/getkeepsafe/relinker/a$a;->b:Ljava/util/zip/ZipEntry;

    invoke-virtual {v0, v13}, Ljava/util/zip/ZipFile;->getInputStream(Ljava/util/zip/ZipEntry;)Ljava/io/InputStream;

    move-result-object v13
    :try_end_f2
    .catch Ljava/io/FileNotFoundException; {:try_start_ea .. :try_end_f2} :catch_145
    .catch Ljava/io/IOException; {:try_start_ea .. :try_end_f2} :catch_145
    .catchall {:try_start_ea .. :try_end_f2} :catchall_13b

    .line 30
    :try_start_f2
    new-instance v14, Ljava/io/FileOutputStream;

    invoke-direct {v14, v7}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
    :try_end_f7
    .catch Ljava/io/FileNotFoundException; {:try_start_f2 .. :try_end_f7} :catch_146
    .catch Ljava/io/IOException; {:try_start_f2 .. :try_end_f7} :catch_146
    .catchall {:try_start_f2 .. :try_end_f7} :catchall_136

    const/16 v0, 0x1000

    :try_start_f9
    new-array v0, v0, [B

    const-wide/16 v15, 0x0

    .line 31
    :goto_fd
    invoke-virtual {v13, v0}, Ljava/io/InputStream;->read([B)I

    move-result v8

    const/4 v6, -0x1

    if-ne v8, v6, :cond_12b

    .line 32
    invoke-virtual {v14}, Ljava/io/OutputStream;->flush()V

    .line 33
    invoke-virtual {v14}, Ljava/io/FileOutputStream;->getFD()Ljava/io/FileDescriptor;

    move-result-object v0

    invoke-virtual {v0}, Ljava/io/FileDescriptor;->sync()V

    .line 34
    invoke-virtual {v7}, Ljava/io/File;->length()J

    move-result-wide v17
    :try_end_112
    .catch Ljava/io/FileNotFoundException; {:try_start_f9 .. :try_end_112} :catch_147
    .catch Ljava/io/IOException; {:try_start_f9 .. :try_end_112} :catch_147
    .catchall {:try_start_f9 .. :try_end_112} :catchall_133

    cmp-long v0, v15, v17

    if-eqz v0, :cond_117

    goto :goto_147

    .line 35
    :cond_117
    :try_start_117
    invoke-virtual {v11, v13}, Lcom/getkeepsafe/relinker/a;->a(Ljava/io/Closeable;)V

    .line 36
    invoke-virtual {v11, v14}, Lcom/getkeepsafe/relinker/a;->a(Ljava/io/Closeable;)V

    .line 37
    invoke-virtual {v7, v5, v4}, Ljava/io/File;->setReadable(ZZ)Z

    .line 38
    invoke-virtual {v7, v5, v4}, Ljava/io/File;->setExecutable(ZZ)Z

    .line 39
    invoke-virtual {v7, v5}, Ljava/io/File;->setWritable(Z)Z
    :try_end_126
    .catchall {:try_start_117 .. :try_end_126} :catchall_1da

    .line 40
    :try_start_126
    iget-object v0, v12, Lcom/getkeepsafe/relinker/a$a;->a:Ljava/util/zip/ZipFile;
    :try_end_128
    .catch Ljava/io/IOException; {:try_start_126 .. :try_end_128} :catch_159

    if-eqz v0, :cond_159

    goto :goto_156

    .line 41
    :cond_12b
    :try_start_12b
    invoke-virtual {v14, v0, v4, v8}, Ljava/io/OutputStream;->write([BII)V
    :try_end_12e
    .catch Ljava/io/FileNotFoundException; {:try_start_12b .. :try_end_12e} :catch_147
    .catch Ljava/io/IOException; {:try_start_12b .. :try_end_12e} :catch_147
    .catchall {:try_start_12b .. :try_end_12e} :catchall_133

    int-to-long v5, v8

    add-long/2addr v15, v5

    const/4 v5, 0x1

    const/4 v6, 0x2

    goto :goto_fd

    :catchall_133
    move-exception v0

    move-object v8, v14

    goto :goto_138

    :catchall_136
    move-exception v0

    const/4 v8, 0x0

    :goto_138
    move-object v2, v8

    move-object v8, v13

    goto :goto_13e

    :catchall_13b
    move-exception v0

    const/4 v2, 0x0

    const/4 v8, 0x0

    .line 42
    :goto_13e
    :try_start_13e
    invoke-virtual {v11, v8}, Lcom/getkeepsafe/relinker/a;->a(Ljava/io/Closeable;)V

    .line 43
    invoke-virtual {v11, v2}, Lcom/getkeepsafe/relinker/a;->a(Ljava/io/Closeable;)V

    .line 44
    throw v0

    :catch_145
    const/4 v13, 0x0

    :catch_146
    const/4 v14, 0x0

    .line 45
    :catch_147
    :goto_147
    invoke-virtual {v11, v13}, Lcom/getkeepsafe/relinker/a;->a(Ljava/io/Closeable;)V

    .line 46
    invoke-virtual {v11, v14}, Lcom/getkeepsafe/relinker/a;->a(Ljava/io/Closeable;)V
    :try_end_14d
    .catchall {:try_start_13e .. :try_end_14d} :catchall_1da

    :catch_14d
    :goto_14d
    move v0, v9

    const/4 v5, 0x1

    const/4 v6, 0x2

    goto/16 :goto_cf

    .line 47
    :cond_152
    :try_start_152
    iget-object v0, v12, Lcom/getkeepsafe/relinker/a$a;->a:Ljava/util/zip/ZipFile;

    if-eqz v0, :cond_159

    .line 48
    :goto_156
    invoke-virtual {v0}, Ljava/util/zip/ZipFile;->close()V
    :try_end_159
    .catch Ljava/io/IOException; {:try_start_152 .. :try_end_159} :catch_159

    .line 49
    :catch_159
    :cond_159
    :goto_159
    :try_start_159
    iget-boolean v0, v1, Lcom/getkeepsafe/relinker/e;->d:Z
    :try_end_15b
    .catch Ljava/io/IOException; {:try_start_159 .. :try_end_15b} :catch_1b4

    if-eqz v0, :cond_1b4

    .line 50
    :try_start_15d
    new-instance v5, Lcom/getkeepsafe/relinker/elf/i;

    invoke-direct {v5, v7}, Lcom/getkeepsafe/relinker/elf/i;-><init>(Ljava/io/File;)V
    :try_end_162
    .catchall {:try_start_15d .. :try_end_162} :catchall_1ac

    .line 51
    :try_start_162
    invoke-virtual {v5}, Lcom/getkeepsafe/relinker/elf/i;->a()Ljava/util/List;

    move-result-object v0
    :try_end_166
    .catchall {:try_start_162 .. :try_end_166} :catchall_1a9

    .line 52
    :try_start_166
    invoke-virtual {v5}, Lcom/getkeepsafe/relinker/elf/i;->close()V
    :try_end_169
    .catch Ljava/io/IOException; {:try_start_166 .. :try_end_169} :catch_1b4

    .line 53
    :try_start_169
    iget-object v5, v1, Lcom/getkeepsafe/relinker/e;->e:Ljava/util/ArrayList;

    invoke-virtual {v5}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;

    move-result-object v5

    :goto_16f
    invoke-interface {v5}, Ljava/util/Iterator;->hasNext()Z

    move-result v6

    if-eqz v6, :cond_17f

    invoke-interface {v5}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v6

    check-cast v6, Ljava/lang/String;

    .line 54
    invoke-interface {v0, v6}, Ljava/util/List;->remove(Ljava/lang/Object;)Z

    goto :goto_16f

    .line 55
    :cond_17f
    invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v0

    :goto_183
    invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z

    move-result v5

    if-eqz v5, :cond_1b4

    invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v5

    check-cast v5, Ljava/lang/String;

    .line 56
    iget-object v6, v1, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    check-cast v6, Lcom/getkeepsafe/relinker/f;

    invoke-static {v6}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object;

    .line 57
    invoke-virtual {v5}, Ljava/lang/String;->length()I

    move-result v6

    const/4 v8, 0x3

    sub-int/2addr v6, v8

    invoke-virtual {v5, v8, v6}, Ljava/lang/String;->substring(II)Ljava/lang/String;

    move-result-object v5

    .line 58
    invoke-virtual {v1, v2, v5}, Lcom/getkeepsafe/relinker/e;->b(Landroid/content/Context;Ljava/lang/String;)V
    :try_end_1a3
    .catchall {:try_start_169 .. :try_end_1a3} :catchall_1a4

    goto :goto_183

    :catchall_1a4
    move-exception v0

    .line 59
    :try_start_1a5
    invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    goto :goto_1b4

    :catchall_1a9
    move-exception v0

    move-object v8, v5

    goto :goto_1ae

    :catchall_1ac
    move-exception v0

    const/4 v8, 0x0

    :goto_1ae
    if-eqz v8, :cond_1b3

    .line 60
    invoke-virtual {v8}, Lcom/getkeepsafe/relinker/elf/i;->close()V

    .line 61
    :cond_1b3
    throw v0
    :try_end_1b4
    .catch Ljava/io/IOException; {:try_start_1a5 .. :try_end_1b4} :catch_1b4

    .line 62
    :catch_1b4
    :cond_1b4
    :goto_1b4
    iget-object v0, v1, Lcom/getkeepsafe/relinker/e;->b:Lcom/getkeepsafe/relinker/c$b;

    invoke-virtual {v7}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v2

    check-cast v0, Lcom/getkeepsafe/relinker/f;

    invoke-static {v0}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object;

    .line 63
    invoke-static {v2}, Ljava/lang/System;->load(Ljava/lang/String;)V

    .line 64
    iget-object v0, v1, Lcom/getkeepsafe/relinker/e;->a:Ljava/util/HashSet;

    invoke-virtual {v0, v3}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z

    const/4 v2, 0x2

    new-array v0, v2, [Ljava/lang/Object;

    aput-object v3, v0, v4

    const/4 v2, 0x1

    aput-object p3, v0, v2

    const-string v2, "%s (%s) was re-linked!"

    .line 65
    invoke-virtual {v1, v2, v0}, Lcom/getkeepsafe/relinker/e;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    return-void

    .line 66
    :cond_1d5
    :try_start_1d5
    invoke-virtual {v11, v2, v10}, Lcom/getkeepsafe/relinker/a;->c(Landroid/content/Context;Ljava/lang/String;)[Ljava/lang/String;

    move-result-object v0
    :try_end_1d9
    .catch Ljava/lang/Exception; {:try_start_1d5 .. :try_end_1d9} :catch_1dc
    .catchall {:try_start_1d5 .. :try_end_1d9} :catchall_1da

    goto :goto_1e7

    :catchall_1da
    move-exception v0

    goto :goto_1ed

    :catch_1dc
    move-exception v0

    move-object v2, v0

    const/4 v3, 0x1

    :try_start_1df
    new-array v0, v3, [Ljava/lang/String;

    .line 67
    invoke-virtual {v2}, Ljava/lang/Object;->toString()Ljava/lang/String;

    move-result-object v2

    aput-object v2, v0, v4

    .line 68
    :goto_1e7
    new-instance v2, Lcom/getkeepsafe/relinker/b;

    invoke-direct {v2, v10, v9, v0}, Lcom/getkeepsafe/relinker/b;-><init>(Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/String;)V

    throw v2
    :try_end_1ed
    .catchall {:try_start_1df .. :try_end_1ed} :catchall_1da

    :goto_1ed
    move-object v8, v12

    goto :goto_1f1

    :catchall_1ef
    move-exception v0

    const/4 v8, 0x0

    :goto_1f1
    if-eqz v8, :cond_1fa

    .line 69
    :try_start_1f3
    iget-object v2, v8, Lcom/getkeepsafe/relinker/a$a;->a:Ljava/util/zip/ZipFile;

    if-eqz v2, :cond_1fa

    .line 70
    invoke-virtual {v2}, Ljava/util/zip/ZipFile;->close()V
    :try_end_1fa
    .catch Ljava/io/IOException; {:try_start_1f3 .. :try_end_1fa} :catch_1fa

    .line 71
    :catch_1fa
    :cond_1fa
    throw v0
.end method

.method public final varargs d(Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 4

    sget-object v0, Ljava/util/Locale;->US:Ljava/util/Locale;

    invoke-static {v0, p1, p2}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    return-void
.end method