SoLoader$1.smali
.class final Lcom/facebook/soloader/SoLoader$1;
.super Ljava/lang/Object;
.source "SoLoader.java"
# 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 370
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 413
: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 414
invoke-static {p1}, Ljava/security/MessageDigest;->getInstance(Ljava/lang/String;)Ljava/security/MessageDigest;
move-result-object p1
.line 415
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_55
.catch Ljava/lang/SecurityException; {:try_start_0 .. :try_end_10} :catch_4f
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_0 .. :try_end_10} :catch_49
const/16 v0, 0x1000
:try_start_12
new-array v0, v0, [B
.line 418
: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 419
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 421
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 422
: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_55
.catch Ljava/lang/SecurityException; {:try_start_33 .. :try_end_36} :catch_4f
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_33 .. :try_end_36} :catch_49
goto :goto_5a
:catchall_37
move-exception p1
.line 415
:try_start_38
throw p1
:try_end_39
.catchall {:try_start_38 .. :try_end_39} :catchall_39
:catchall_39
move-exception v0
if-eqz p1, :cond_45
.line 422
:try_start_3c
invoke-virtual {v1}, Ljava/io/InputStream;->close()V
:try_end_3f
.catchall {:try_start_3c .. :try_end_3f} :catchall_40
goto :goto_48
:catchall_40
move-exception v1
:try_start_41
invoke-virtual {p1, v1}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V
goto :goto_48
:cond_45
invoke-virtual {v1}, Ljava/io/InputStream;->close()V
:goto_48
throw v0
:try_end_49
.catch Ljava/io/IOException; {:try_start_41 .. :try_end_49} :catch_55
.catch Ljava/lang/SecurityException; {:try_start_41 .. :try_end_49} :catch_4f
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_41 .. :try_end_49} :catch_49
:catch_49
move-exception p1
.line 428
invoke-virtual {p1}, Ljava/security/NoSuchAlgorithmException;->toString()Ljava/lang/String;
move-result-object p1
goto :goto_5a
:catch_4f
move-exception p1
.line 426
invoke-virtual {p1}, Ljava/lang/SecurityException;->toString()Ljava/lang/String;
move-result-object p1
goto :goto_5a
:catch_55
move-exception p1
.line 424
invoke-virtual {p1}, Ljava/io/IOException;->toString()Ljava/lang/String;
move-result-object p1
:goto_5a
return-object p1
.end method
# virtual methods
.method public load(Ljava/lang/String;I)V
.registers 11
.line 374
iget-boolean v0, p0, Lcom/facebook/soloader/SoLoader$1;->val$hasNativeLoadMethod:Z
if-eqz v0, :cond_c9
const/4 v0, 0x4
and-int/2addr p2, v0
const/4 v1, 0x1
const/4 v2, 0x0
if-ne p2, v0, :cond_c
move p2, v1
goto :goto_d
:cond_c
move p2, v2
:goto_d
if-eqz p2, :cond_12
.line 376
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 378
: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_80
.catch Ljava/lang/IllegalArgumentException; {:try_start_15 .. :try_end_18} :catch_7e
.catch Ljava/lang/reflect/InvocationTargetException; {:try_start_15 .. :try_end_18} :catch_7c
.catchall {:try_start_15 .. :try_end_18} :catchall_77
.line 379
:try_start_18
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 v6, 0x3
new-array v6, v6, [Ljava/lang/Object;
aput-object p1, v6, v2
const-class v2, Lcom/facebook/soloader/SoLoader;
.line 382
invoke-virtual {v2}, Ljava/lang/Class;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v2
aput-object v2, v6, v1
const/4 v1, 0x2
aput-object p2, v6, v1
.line 381
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_32
.catchall {:try_start_18 .. :try_end_32} :catchall_69
if-nez v1, :cond_63
.line 386
:try_start_34
monitor-exit v3
:try_end_35
.catchall {:try_start_34 .. :try_end_35} :catchall_75
if-eqz v1, :cond_cc
const-string v0, "SoLoader"
.line 394
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Error when loading lib: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " lib hash: "
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 399
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
.line 394
invoke-static {v0, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
goto/16 :goto_cc
.line 384
:cond_63
:try_start_63
new-instance v0, Ljava/lang/UnsatisfiedLinkError;
invoke-direct {v0, v1}, Ljava/lang/UnsatisfiedLinkError;-><init>(Ljava/lang/String;)V
throw v0
:catchall_69
move-exception v1
move-object v7, v1
move-object v1, v0
move-object v0, v7
.line 386
:goto_6d
monitor-exit v3
:try_end_6e
.catchall {:try_start_63 .. :try_end_6e} :catchall_75
:try_start_6e
throw v0
:try_end_6f
.catch Ljava/lang/IllegalAccessException; {:try_start_6e .. :try_end_6f} :catch_73
.catch Ljava/lang/IllegalArgumentException; {:try_start_6e .. :try_end_6f} :catch_71
.catch Ljava/lang/reflect/InvocationTargetException; {:try_start_6e .. :try_end_6f} :catch_6f
.catchall {:try_start_6e .. :try_end_6f} :catchall_9b
:catch_6f
move-exception v0
goto :goto_84
:catch_71
move-exception v0
goto :goto_84
:catch_73
move-exception v0
goto :goto_84
:catchall_75
move-exception v0
goto :goto_6d
:catchall_77
move-exception v1
move-object v7, v1
move-object v1, v0
move-object v0, v7
goto :goto_9c
:catch_7c
move-exception v1
goto :goto_81
:catch_7e
move-exception v1
goto :goto_81
:catch_80
move-exception v1
:goto_81
move-object v7, v1
move-object v1, v0
move-object v0, v7
.line 390
:goto_84
:try_start_84
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Error: Cannot load "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 391
new-instance v2, Ljava/lang/RuntimeException;
invoke-direct {v2, v1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
:try_end_9b
.catchall {:try_start_84 .. :try_end_9b} :catchall_9b
:catchall_9b
move-exception v0
:goto_9c
if-eqz v1, :cond_c8
const-string v2, "SoLoader"
.line 394
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Error when loading lib: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " lib hash: "
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 399
invoke-direct {p0, p1}, Lcom/facebook/soloader/SoLoader$1;->getLibHash(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, " search path is "
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 394
invoke-static {v2, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 403
:cond_c8
throw v0
.line 405
:cond_c9
invoke-static {p1}, Ljava/lang/System;->load(Ljava/lang/String;)V
:cond_cc
:goto_cc
return-void
.end method