SoLoader$1.smali
.class final Lcom/facebook/soloader/SoLoader$1;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/facebook/soloader/SoFileLoader;
# annotations
.annotation system Ldalvik/annotation/EnclosingMethod;
value = Lcom/facebook/soloader/SoLoader;->initSoLoader(Lcom/facebook/soloader/SoFileLoader;)V
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x8
name = null
.end annotation
# instance fields
.field final synthetic val$hasNativeLoadMethod:Z
.field final synthetic val$localLdLibraryPath:Ljava/lang/String;
.field final synthetic val$localLdLibraryPathNoZips:Ljava/lang/String;
.field final synthetic val$nativeLoadRuntimeMethod:Ljava/lang/reflect/Method;
.field final synthetic val$runtime:Ljava/lang/Runtime;
# direct methods
.method constructor <init>(ZLjava/lang/String;Ljava/lang/String;Ljava/lang/Runtime;Ljava/lang/reflect/Method;)V
.registers 6
.line 309
iput-boolean p1, p0, Lcom/facebook/soloader/SoLoader$1;->val$hasNativeLoadMethod:Z
iput-object p2, p0, Lcom/facebook/soloader/SoLoader$1;->val$localLdLibraryPath:Ljava/lang/String;
iput-object p3, p0, Lcom/facebook/soloader/SoLoader$1;->val$localLdLibraryPathNoZips:Ljava/lang/String;
iput-object p4, p0, Lcom/facebook/soloader/SoLoader$1;->val$runtime:Ljava/lang/Runtime;
iput-object p5, p0, Lcom/facebook/soloader/SoLoader$1;->val$nativeLoadRuntimeMethod:Ljava/lang/reflect/Method;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private getLibHash(Ljava/lang/String;)Ljava/lang/String;
.registers 8
.line 357
:try_start_0
new-instance v0, Ljava/io/File;
invoke-direct {v0, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
const-string p1, "MD5"
.line 358
invoke-static {p1}, Ljava/security/MessageDigest;->getInstance(Ljava/lang/String;)Ljava/security/MessageDigest;
move-result-object p1
.line 360
new-instance v1, Ljava/io/FileInputStream;
invoke-direct {v1, v0}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
:try_end_10
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_10} :catch_49
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_0 .. :try_end_10} :catch_43
const/16 v0, 0x1000
:try_start_12
new-array v0, v0, [B
.line 363
:goto_14
invoke-virtual {v1, v0}, Ljava/io/InputStream;->read([B)I
move-result v2
const/4 v3, 0x0
if-lez v2, :cond_1f
.line 364
invoke-virtual {p1, v0, v3, v2}, Ljava/security/MessageDigest;->update([BII)V
goto :goto_14
:cond_1f
const-string v0, "%32x"
const/4 v2, 0x1
new-array v4, v2, [Ljava/lang/Object;
.line 366
new-instance v5, Ljava/math/BigInteger;
invoke-virtual {p1}, Ljava/security/MessageDigest;->digest()[B
move-result-object p1
invoke-direct {v5, v2, p1}, Ljava/math/BigInteger;-><init>(I[B)V
aput-object v5, v4, v3
invoke-static {v0, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
:try_end_33
.catchall {:try_start_12 .. :try_end_33} :catchall_37
.line 367
:try_start_33
invoke-virtual {v1}, Ljava/io/InputStream;->close()V
:try_end_36
.catch Ljava/io/IOException; {:try_start_33 .. :try_end_36} :catch_49
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_33 .. :try_end_36} :catch_43
goto :goto_4e
:catchall_37
move-exception p1
.line 360
:try_start_38
throw p1
:try_end_39
.catchall {:try_start_38 .. :try_end_39} :catchall_39
:catchall_39
move-exception v0
.line 367
:try_start_3a
invoke-virtual {v1}, Ljava/io/InputStream;->close()V
:try_end_3d
.catchall {:try_start_3a .. :try_end_3d} :catchall_3e
goto :goto_42
:catchall_3e
move-exception v1
:try_start_3f
invoke-virtual {p1, v1}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V
:goto_42
throw v0
:try_end_43
.catch Ljava/io/IOException; {:try_start_3f .. :try_end_43} :catch_49
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_3f .. :try_end_43} :catch_43
:catch_43
move-exception p1
.line 372
invoke-virtual {p1}, Ljava/security/NoSuchAlgorithmException;->toString()Ljava/lang/String;
move-result-object p1
goto :goto_4e
:catch_49
move-exception p1
.line 370
invoke-virtual {p1}, Ljava/io/IOException;->toString()Ljava/lang/String;
move-result-object p1
:goto_4e
return-object p1
.end method
# virtual methods
.method public final load(Ljava/lang/String;I)V
.registers 12
.line 313
iget-boolean v0, p0, Lcom/facebook/soloader/SoLoader$1;->val$hasNativeLoadMethod:Z
if-eqz v0, :cond_cb
const/4 v0, 0x4
and-int/2addr p2, v0
const/4 v1, 0x1
const/4 v2, 0x0
if-ne p2, v0, :cond_c
const/4 p2, 0x1
goto :goto_d
:cond_c
const/4 p2, 0x0
:goto_d
if-eqz p2, :cond_12
.line 315
iget-object p2, p0, Lcom/facebook/soloader/SoLoader$1;->val$localLdLibraryPath:Ljava/lang/String;
goto :goto_14
:cond_12
iget-object p2, p0, Lcom/facebook/soloader/SoLoader$1;->val$localLdLibraryPathNoZips:Ljava/lang/String;
:goto_14
const/4 v0, 0x0
.line 317
:try_start_15
iget-object v3, p0, Lcom/facebook/soloader/SoLoader$1;->val$runtime:Ljava/lang/Runtime;
monitor-enter v3
:try_end_18
.catch Ljava/lang/IllegalAccessException; {:try_start_15 .. :try_end_18} :catch_90
.catch Ljava/lang/IllegalArgumentException; {:try_start_15 .. :try_end_18} :catch_8e
.catch Ljava/lang/reflect/InvocationTargetException; {:try_start_15 .. :try_end_18} :catch_8c
.catchall {:try_start_15 .. :try_end_18} :catchall_8a
.line 318
:try_start_18
sget v4, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v5, 0x1b
const/4 v6, 0x2
if-gt v4, v5, :cond_39
iget-object v4, p0, Lcom/facebook/soloader/SoLoader$1;->val$nativeLoadRuntimeMethod:Ljava/lang/reflect/Method;
iget-object v5, p0, Lcom/facebook/soloader/SoLoader$1;->val$runtime:Ljava/lang/Runtime;
const/4 v7, 0x3
new-array v7, v7, [Ljava/lang/Object;
aput-object p1, v7, v2
const-class v2, Lcom/facebook/soloader/SoLoader;
.line 323
invoke-virtual {v2}, Ljava/lang/Class;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v2
aput-object v2, v7, v1
aput-object p2, v7, v6
.line 322
invoke-virtual {v4, v5, v7}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
goto :goto_4f
:cond_39
iget-object v4, p0, Lcom/facebook/soloader/SoLoader$1;->val$nativeLoadRuntimeMethod:Ljava/lang/reflect/Method;
iget-object v5, p0, Lcom/facebook/soloader/SoLoader$1;->val$runtime:Ljava/lang/Runtime;
new-array v6, v6, [Ljava/lang/Object;
aput-object p1, v6, v2
const-class v2, Lcom/facebook/soloader/SoLoader;
.line 326
invoke-virtual {v2}, Ljava/lang/Class;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v2
aput-object v2, v6, v1
.line 325
invoke-virtual {v4, v5, v6}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
:try_end_4f
.catchall {:try_start_18 .. :try_end_4f} :catchall_87
:goto_4f
if-nez v1, :cond_81
.line 330
:try_start_51
monitor-exit v3
:try_end_52
.catchall {:try_start_51 .. :try_end_52} :catchall_7c
if-eqz v1, :cond_7b
.line 338
new-instance v0, Ljava/lang/StringBuilder;
const-string v2, "Error when loading lib: "
invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " lib hash: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 343
invoke-direct {p0, p1}, Lcom/facebook/soloader/SoLoader$1;->getLibHash(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, " search path is "
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "SoLoader"
.line 338
invoke-static {p2, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
:cond_7b
return-void
:catchall_7c
move-exception v0
move-object v8, v1
move-object v1, v0
move-object v0, v8
goto :goto_88
.line 328
:cond_81
:try_start_81
new-instance v0, Ljava/lang/UnsatisfiedLinkError;
invoke-direct {v0, v1}, Ljava/lang/UnsatisfiedLinkError;-><init>(Ljava/lang/String;)V
throw v0
:try_end_87
.catchall {:try_start_81 .. :try_end_87} :catchall_7c
:catchall_87
move-exception v1
.line 330
:goto_88
:try_start_88
monitor-exit v3
:try_end_89
.catchall {:try_start_88 .. :try_end_89} :catchall_87
:try_start_89
throw v1
:try_end_8a
.catch Ljava/lang/IllegalAccessException; {:try_start_89 .. :try_end_8a} :catch_90
.catch Ljava/lang/IllegalArgumentException; {:try_start_89 .. :try_end_8a} :catch_8e
.catch Ljava/lang/reflect/InvocationTargetException; {:try_start_89 .. :try_end_8a} :catch_8c
.catchall {:try_start_89 .. :try_end_8a} :catchall_8a
:catchall_8a
move-exception v1
goto :goto_a1
:catch_8c
move-exception v1
goto :goto_91
:catch_8e
move-exception v1
goto :goto_91
:catch_90
move-exception v1
:goto_91
:try_start_91
const-string v2, "Error: Cannot load "
.line 334
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 335
new-instance v2, Ljava/lang/RuntimeException;
invoke-direct {v2, v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
:try_end_a1
.catchall {:try_start_91 .. :try_end_a1} :catchall_8a
:goto_a1
if-eqz v0, :cond_ca
.line 338
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Error when loading lib: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, " lib hash: "
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 343
invoke-direct {p0, p1}, Lcom/facebook/soloader/SoLoader$1;->getLibHash(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, " search path is "
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "SoLoader"
.line 338
invoke-static {p2, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 347
:cond_ca
throw v1
.line 349
:cond_cb
invoke-static {p1}, Ljava/lang/System;->load(Ljava/lang/String;)V
return-void
.end method