ReLinkerInstance.smali

.class public Lio/rong/imlib/relinker/ReLinkerInstance;
.super Ljava/lang/Object;
.source "ReLinkerInstance.java"


# static fields
.field private static final LIB_DIR:Ljava/lang/String; = "lib"


# instance fields
.field protected force:Z

.field protected final libraryInstaller:Lio/rong/imlib/relinker/ReLinker$LibraryInstaller;

.field protected final libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

.field protected final loadedLibraries:Ljava/util/Set;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Set<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field

.field protected logger:Lio/rong/imlib/relinker/ReLinker$Logger;

.field protected recursive:Z


# direct methods
.method protected constructor <init>()V
    .registers 3

    .line 1
    new-instance v0, Lio/rong/imlib/relinker/SystemLibraryLoader;

    invoke-direct {v0}, Lio/rong/imlib/relinker/SystemLibraryLoader;-><init>()V

    new-instance v1, Lio/rong/imlib/relinker/ApkLibraryInstaller;

    invoke-direct {v1}, Lio/rong/imlib/relinker/ApkLibraryInstaller;-><init>()V

    invoke-direct {p0, v0, v1}, Lio/rong/imlib/relinker/ReLinkerInstance;-><init>(Lio/rong/imlib/relinker/ReLinker$LibraryLoader;Lio/rong/imlib/relinker/ReLinker$LibraryInstaller;)V

    return-void
.end method

.method protected constructor <init>(Lio/rong/imlib/relinker/ReLinker$LibraryLoader;Lio/rong/imlib/relinker/ReLinker$LibraryInstaller;)V
    .registers 4

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

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

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

    iput-object v0, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->loadedLibraries:Ljava/util/Set;

    if-eqz p1, :cond_1b

    if-eqz p2, :cond_13

    .line 4
    iput-object p1, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

    .line 5
    iput-object p2, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryInstaller:Lio/rong/imlib/relinker/ReLinker$LibraryInstaller;

    return-void

    .line 6
    :cond_13
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string p2, "Cannot pass null library installer"

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

    throw p1

    .line 7
    :cond_1b
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string p2, "Cannot pass null library loader"

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

    throw p1
.end method

.method static synthetic access$000(Lio/rong/imlib/relinker/ReLinkerInstance;Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V
    .registers 4

    .line 1
    invoke-direct {p0, p1, p2, p3}, Lio/rong/imlib/relinker/ReLinkerInstance;->loadLibraryInternal(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method private loadLibraryInternal(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V
    .registers 15

    .line 1
    iget-object v0, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->loadedLibraries:Ljava/util/Set;

    invoke-interface {v0, p2}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z

    move-result v0

    const/4 v1, 0x0

    const/4 v2, 0x1

    if-eqz v0, :cond_18

    iget-boolean v0, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->force:Z

    if-nez v0, :cond_18

    .line 2
    new-array p1, v2, [Ljava/lang/Object;

    aput-object p2, p1, v1

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

    invoke-virtual {p0, p2, p1}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;[Ljava/lang/Object;)V

    return-void

    :cond_18
    const/4 v0, 0x2

    .line 3
    :try_start_19
    iget-object v3, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

    invoke-interface {v3, p2}, Lio/rong/imlib/relinker/ReLinker$LibraryLoader;->loadLibrary(Ljava/lang/String;)V

    .line 4
    iget-object v3, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->loadedLibraries:Ljava/util/Set;

    invoke-interface {v3, p2}, Ljava/util/Set;->add(Ljava/lang/Object;)Z

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

    .line 5
    new-array v4, v0, [Ljava/lang/Object;

    aput-object p2, v4, v1

    aput-object p3, v4, v2

    invoke-virtual {p0, v3, v4}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;[Ljava/lang/Object;)V
    :try_end_2e
    .catch Ljava/lang/UnsatisfiedLinkError; {:try_start_19 .. :try_end_2e} :catch_2f

    return-void

    :catch_2f
    move-exception v3

    .line 6
    new-array v4, v2, [Ljava/lang/Object;

    invoke-static {v3}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object v3

    aput-object v3, v4, v1

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

    invoke-virtual {p0, v3, v4}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 7
    new-array v3, v0, [Ljava/lang/Object;

    aput-object p2, v3, v1

    aput-object p3, v3, v2

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

    invoke-virtual {p0, v4, v3}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 8
    invoke-virtual {p0, p1, p2, p3}, Lio/rong/imlib/relinker/ReLinkerInstance;->getWorkaroundLibFile(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Ljava/io/File;

    move-result-object v3

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

    move-result v4

    if-eqz v4, :cond_56

    iget-boolean v4, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->force:Z

    if-eqz v4, :cond_7c

    .line 10
    :cond_56
    iget-boolean v4, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->force:Z

    if-eqz v4, :cond_65

    .line 11
    new-array v4, v0, [Ljava/lang/Object;

    aput-object p2, v4, v1

    aput-object p3, v4, v2

    const-string v5, "Forcing a re-link of %s (%s)..."

    invoke-virtual {p0, v5, v4}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 12
    :cond_65
    invoke-virtual {p0, p1, p2, p3}, Lio/rong/imlib/relinker/ReLinkerInstance;->cleanupOldLibFiles(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V

    .line 13
    iget-object v5, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryInstaller:Lio/rong/imlib/relinker/ReLinker$LibraryInstaller;

    iget-object v4, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

    invoke-interface {v4}, Lio/rong/imlib/relinker/ReLinker$LibraryLoader;->supportedAbis()[Ljava/lang/String;

    move-result-object v7

    iget-object v4, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

    .line 14
    invoke-interface {v4, p2}, Lio/rong/imlib/relinker/ReLinker$LibraryLoader;->mapLibraryName(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v8

    move-object v6, p1

    move-object v9, v3

    move-object v10, p0

    .line 15
    invoke-interface/range {v5 .. v10}, Lio/rong/imlib/relinker/ReLinker$LibraryInstaller;->installLibrary(Landroid/content/Context;[Ljava/lang/String;Ljava/lang/String;Ljava/io/File;Lio/rong/imlib/relinker/ReLinkerInstance;)V

    .line 16
    :cond_7c
    :try_start_7c
    iget-boolean v4, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->recursive:Z
    :try_end_7e
    .catch Ljava/io/IOException; {:try_start_7c .. :try_end_7e} :catch_b1

    if-eqz v4, :cond_b1

    const/4 v4, 0x0

    .line 17
    :try_start_81
    new-instance v5, Lio/rong/imlib/relinker/elf/ElfParser;

    invoke-direct {v5, v3}, Lio/rong/imlib/relinker/elf/ElfParser;-><init>(Ljava/io/File;)V
    :try_end_86
    .catchall {:try_start_81 .. :try_end_86} :catchall_aa

    .line 18
    :try_start_86
    invoke-virtual {v5}, Lio/rong/imlib/relinker/elf/ElfParser;->parseNeededDependencies()Ljava/util/List;

    move-result-object v4
    :try_end_8a
    .catchall {:try_start_86 .. :try_end_8a} :catchall_a7

    .line 19
    :try_start_8a
    invoke-virtual {v5}, Lio/rong/imlib/relinker/elf/ElfParser;->close()V

    .line 20
    invoke-interface {v4}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v4

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

    move-result v5

    if-eqz v5, :cond_b1

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

    move-result-object v5

    check-cast v5, Ljava/lang/String;

    .line 21
    iget-object v6, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

    invoke-interface {v6, v5}, Lio/rong/imlib/relinker/ReLinker$LibraryLoader;->unmapLibraryName(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v5

    invoke-virtual {p0, p1, v5}, Lio/rong/imlib/relinker/ReLinkerInstance;->loadLibrary(Landroid/content/Context;Ljava/lang/String;)V

    goto :goto_91

    :catchall_a7
    move-exception p1

    move-object v4, v5

    goto :goto_ab

    :catchall_aa
    move-exception p1

    :goto_ab
    if-eqz v4, :cond_b0

    .line 22
    invoke-virtual {v4}, Lio/rong/imlib/relinker/elf/ElfParser;->close()V

    :cond_b0
    throw p1
    :try_end_b1
    .catch Ljava/io/IOException; {:try_start_8a .. :try_end_b1} :catch_b1

    .line 23
    :catch_b1
    :cond_b1
    iget-object p1, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

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

    move-result-object v3

    invoke-interface {p1, v3}, Lio/rong/imlib/relinker/ReLinker$LibraryLoader;->loadPath(Ljava/lang/String;)V

    .line 24
    iget-object p1, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->loadedLibraries:Ljava/util/Set;

    invoke-interface {p1, p2}, Ljava/util/Set;->add(Ljava/lang/Object;)Z

    .line 25
    new-array p1, v0, [Ljava/lang/Object;

    aput-object p2, p1, v1

    aput-object p3, p1, v2

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

    invoke-virtual {p0, p2, p1}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;[Ljava/lang/Object;)V

    return-void
.end method


# virtual methods
.method protected cleanupOldLibFiles(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V
    .registers 8

    .line 1
    invoke-virtual {p0, p1}, Lio/rong/imlib/relinker/ReLinkerInstance;->getWorkaroundLibDir(Landroid/content/Context;)Ljava/io/File;

    move-result-object v0

    .line 2
    invoke-virtual {p0, p1, p2, p3}, Lio/rong/imlib/relinker/ReLinkerInstance;->getWorkaroundLibFile(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Ljava/io/File;

    move-result-object p1

    .line 3
    iget-object p3, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

    invoke-interface {p3, p2}, Lio/rong/imlib/relinker/ReLinker$LibraryLoader;->mapLibraryName(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p2

    .line 4
    new-instance p3, Lio/rong/imlib/relinker/ReLinkerInstance$2;

    invoke-direct {p3, p0, p2}, Lio/rong/imlib/relinker/ReLinkerInstance$2;-><init>(Lio/rong/imlib/relinker/ReLinkerInstance;Ljava/lang/String;)V

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

    move-result-object p2

    if-nez p2, :cond_1a

    return-void

    .line 5
    :cond_1a
    array-length p3, p2

    const/4 v0, 0x0

    :goto_1c
    if-ge v0, p3, :cond_38

    aget-object v1, p2, v0

    .line 6
    iget-boolean v2, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->force:Z

    if-nez v2, :cond_32

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

    move-result-object v2

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

    move-result-object v3

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

    move-result v2

    if-nez v2, :cond_35

    .line 7
    :cond_32
    invoke-virtual {v1}, Ljava/io/File;->delete()Z

    :cond_35
    add-int/lit8 v0, v0, 0x1

    goto :goto_1c

    :cond_38
    return-void
.end method

.method public force()Lio/rong/imlib/relinker/ReLinkerInstance;
    .registers 2

    const/4 v0, 0x1

    .line 1
    iput-boolean v0, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->force:Z

    return-object p0
.end method

.method protected getWorkaroundLibDir(Landroid/content/Context;)Ljava/io/File;
    .registers 4

    const-string v0, "lib"

    const/4 v1, 0x0

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

    move-result-object p1

    return-object p1
.end method

.method protected getWorkaroundLibFile(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)Ljava/io/File;
    .registers 6

    .line 1
    iget-object v0, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->libraryLoader:Lio/rong/imlib/relinker/ReLinker$LibraryLoader;

    invoke-interface {v0, p2}, Lio/rong/imlib/relinker/ReLinker$LibraryLoader;->mapLibraryName(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p2

    .line 2
    invoke-static {p3}, Lio/rong/imlib/relinker/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v0

    if-eqz v0, :cond_16

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

    invoke-virtual {p0, p1}, Lio/rong/imlib/relinker/ReLinkerInstance;->getWorkaroundLibDir(Landroid/content/Context;)Ljava/io/File;

    move-result-object p1

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

    return-object p3

    .line 4
    :cond_16
    new-instance v0, Ljava/io/File;

    invoke-virtual {p0, p1}, Lio/rong/imlib/relinker/ReLinkerInstance;->getWorkaroundLibDir(Landroid/content/Context;)Ljava/io/File;

    move-result-object p1

    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, "."

    invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v1, p3}, 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 {v0, p1, p2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V

    return-object v0
.end method

.method public loadLibrary(Landroid/content/Context;Ljava/lang/String;)V
    .registers 4

    const/4 v0, 0x0

    .line 1
    invoke-virtual {p0, p1, p2, v0, v0}, Lio/rong/imlib/relinker/ReLinkerInstance;->loadLibrary(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/relinker/ReLinker$LoadListener;)V

    return-void
.end method

.method public loadLibrary(Landroid/content/Context;Ljava/lang/String;Lio/rong/imlib/relinker/ReLinker$LoadListener;)V
    .registers 5

    const/4 v0, 0x0

    .line 3
    invoke-virtual {p0, p1, p2, v0, p3}, Lio/rong/imlib/relinker/ReLinkerInstance;->loadLibrary(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/relinker/ReLinker$LoadListener;)V

    return-void
.end method

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

    const/4 v0, 0x0

    .line 2
    invoke-virtual {p0, p1, p2, p3, v0}, Lio/rong/imlib/relinker/ReLinkerInstance;->loadLibrary(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/relinker/ReLinker$LoadListener;)V

    return-void
.end method

.method public loadLibrary(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/relinker/ReLinker$LoadListener;)V
    .registers 13

    if-eqz p1, :cond_35

    .line 4
    invoke-static {p2}, Lio/rong/imlib/relinker/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v0

    if-nez v0, :cond_2d

    const/4 v0, 0x1

    .line 5
    new-array v0, v0, [Ljava/lang/Object;

    const/4 v1, 0x0

    aput-object p2, v0, v1

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

    invoke-virtual {p0, v1, v0}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;[Ljava/lang/Object;)V

    if-nez p4, :cond_19

    .line 6
    invoke-direct {p0, p1, p2, p3}, Lio/rong/imlib/relinker/ReLinkerInstance;->loadLibraryInternal(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_2c

    .line 7
    :cond_19
    new-instance v0, Ljava/lang/Thread;

    new-instance v7, Lio/rong/imlib/relinker/ReLinkerInstance$1;

    move-object v1, v7

    move-object v2, p0

    move-object v3, p1

    move-object v4, p2

    move-object v5, p3

    move-object v6, p4

    invoke-direct/range {v1 .. v6}, Lio/rong/imlib/relinker/ReLinkerInstance$1;-><init>(Lio/rong/imlib/relinker/ReLinkerInstance;Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/relinker/ReLinker$LoadListener;)V

    invoke-direct {v0, v7}, Ljava/lang/Thread;-><init>(Ljava/lang/Runnable;)V

    .line 8
    invoke-virtual {v0}, Ljava/lang/Thread;->start()V

    :goto_2c
    return-void

    .line 9
    :cond_2d
    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 10
    :cond_35
    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 log(Lio/rong/imlib/relinker/ReLinker$Logger;)Lio/rong/imlib/relinker/ReLinkerInstance;
    .registers 2

    .line 1
    iput-object p1, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->logger:Lio/rong/imlib/relinker/ReLinker$Logger;

    return-object p0
.end method

.method public log(Ljava/lang/String;)V
    .registers 3

    .line 3
    iget-object v0, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->logger:Lio/rong/imlib/relinker/ReLinker$Logger;

    if-eqz v0, :cond_7

    .line 4
    invoke-interface {v0, p1}, Lio/rong/imlib/relinker/ReLinker$Logger;->log(Ljava/lang/String;)V

    :cond_7
    return-void
.end method

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

    .line 2
    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;

    move-result-object p1

    invoke-virtual {p0, p1}, Lio/rong/imlib/relinker/ReLinkerInstance;->log(Ljava/lang/String;)V

    return-void
.end method

.method public recursively()Lio/rong/imlib/relinker/ReLinkerInstance;
    .registers 2

    const/4 v0, 0x1

    .line 1
    iput-boolean v0, p0, Lio/rong/imlib/relinker/ReLinkerInstance;->recursive:Z

    return-object p0
.end method