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