AsyncServiceHelper$3.smali
.class Lorg/opencv/android/AsyncServiceHelper$3;
.super Ljava/lang/Object;
# interfaces
.implements Landroid/content/ServiceConnection;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lorg/opencv/android/AsyncServiceHelper;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x0
name = null
.end annotation
# instance fields
.field final synthetic this$0:Lorg/opencv/android/AsyncServiceHelper;
# direct methods
.method constructor <init>(Lorg/opencv/android/AsyncServiceHelper;)V
.registers 2
iput-object p1, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public onServiceConnected(Landroid/content/ComponentName;Landroid/os/IBinder;)V
.registers 10
const-string p1, "Calling using callback"
const-string v0, "Unbind from service"
const-string v1, "OpenCVManager/Helper"
const-string v2, "Service connection created"
invoke-static {v1, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object v2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
invoke-static {p2}, Lorg/opencv/engine/OpenCVEngineInterface$Stub;->asInterface(Landroid/os/IBinder;)Lorg/opencv/engine/OpenCVEngineInterface;
move-result-object p2
iput-object p2, v2, Lorg/opencv/android/AsyncServiceHelper;->mEngineService:Lorg/opencv/engine/OpenCVEngineInterface;
iget-object p2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p2, p2, Lorg/opencv/android/AsyncServiceHelper;->mEngineService:Lorg/opencv/engine/OpenCVEngineInterface;
if-nez p2, :cond_29
const-string p1, "OpenCV Manager Service connection fails. May be service was not installed?"
invoke-static {v1, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p1, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p2, p1, Lorg/opencv/android/AsyncServiceHelper;->mAppContext:Landroid/content/Context;
iget-object p1, p1, Lorg/opencv/android/AsyncServiceHelper;->mUserAppCallback:Lorg/opencv/android/LoaderCallbackInterface;
invoke-static {p2, p1}, Lorg/opencv/android/AsyncServiceHelper;->InstallService(Landroid/content/Context;Lorg/opencv/android/LoaderCallbackInterface;)V
goto/16 :goto_139
:cond_29
const/4 v2, 0x0
sput-boolean v2, Lorg/opencv/android/AsyncServiceHelper;->mServiceInstallationProgress:Z
const/16 v3, 0xff
:try_start_2e
invoke-interface {p2}, Lorg/opencv/engine/OpenCVEngineInterface;->getEngineVersion()I
move-result p2
const/4 v4, 0x2
if-ge p2, v4, :cond_54
const-string p2, "Init finished with status 4"
invoke-static {v1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p2, p2, Lorg/opencv/android/AsyncServiceHelper;->mAppContext:Landroid/content/Context;
iget-object v2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v2, v2, Lorg/opencv/android/AsyncServiceHelper;->mServiceConnection:Landroid/content/ServiceConnection;
invoke-virtual {p2, v2}, Landroid/content/Context;->unbindService(Landroid/content/ServiceConnection;)V
invoke-static {v1, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p2, p2, Lorg/opencv/android/AsyncServiceHelper;->mUserAppCallback:Lorg/opencv/android/LoaderCallbackInterface;
const/4 v2, 0x4
invoke-interface {p2, v2}, Lorg/opencv/android/LoaderCallbackInterface;->onManagerConnected(I)V
return-void
:cond_54
const-string p2, "Trying to get library path"
invoke-static {v1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p2, p2, Lorg/opencv/android/AsyncServiceHelper;->mEngineService:Lorg/opencv/engine/OpenCVEngineInterface;
iget-object v4, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v4, v4, Lorg/opencv/android/AsyncServiceHelper;->mOpenCVersion:Ljava/lang/String;
invoke-interface {p2, v4}, Lorg/opencv/engine/OpenCVEngineInterface;->getLibPathByVersion(Ljava/lang/String;)Ljava/lang/String;
move-result-object p2
if-eqz p2, :cond_fb
invoke-virtual {p2}, Ljava/lang/String;->length()I
move-result v4
if-nez v4, :cond_6f
goto/16 :goto_fb
:cond_6f
const-string v4, "Trying to get library list"
invoke-static {v1, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
sput-boolean v2, Lorg/opencv/android/AsyncServiceHelper;->mLibraryInstallationProgress:Z
iget-object v4, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v4, v4, Lorg/opencv/android/AsyncServiceHelper;->mEngineService:Lorg/opencv/engine/OpenCVEngineInterface;
iget-object v5, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v5, v5, Lorg/opencv/android/AsyncServiceHelper;->mOpenCVersion:Ljava/lang/String;
invoke-interface {v4, v5}, Lorg/opencv/engine/OpenCVEngineInterface;->getLibraryList(Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "Library list: \""
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v6, "\""
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v1, v5}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
const-string v5, "First attempt to load libs"
invoke-static {v1, v5}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object v5, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
# invokes: Lorg/opencv/android/AsyncServiceHelper;->initOpenCVLibs(Ljava/lang/String;Ljava/lang/String;)Z
invoke-static {v5, p2, v4}, Lorg/opencv/android/AsyncServiceHelper;->access$000(Lorg/opencv/android/AsyncServiceHelper;Ljava/lang/String;Ljava/lang/String;)Z
move-result p2
if-eqz p2, :cond_c7
const-string p2, "First attempt to load libs is OK"
invoke-static {v1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
const-string p2, "line.separator"
invoke-static {p2}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object p2
invoke-static {}, Lorg/opencv/core/Core;->getBuildInformation()Ljava/lang/String;
move-result-object v4
invoke-virtual {v4, p2}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object p2
array-length v4, p2
const/4 v5, 0x0
:goto_bd
if-ge v5, v4, :cond_ce
aget-object v6, p2, v5
invoke-static {v1, v6}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
add-int/lit8 v5, v5, 0x1
goto :goto_bd
:cond_c7
const-string p2, "First attempt to load libs fails"
invoke-static {v1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
const/16 v2, 0xff
:cond_ce
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Init finished with status "
invoke-virtual {p2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-static {v1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p2, p2, Lorg/opencv/android/AsyncServiceHelper;->mAppContext:Landroid/content/Context;
iget-object v4, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v4, v4, Lorg/opencv/android/AsyncServiceHelper;->mServiceConnection:Landroid/content/ServiceConnection;
invoke-virtual {p2, v4}, Landroid/content/Context;->unbindService(Landroid/content/ServiceConnection;)V
invoke-static {v1, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p2, p2, Lorg/opencv/android/AsyncServiceHelper;->mUserAppCallback:Lorg/opencv/android/LoaderCallbackInterface;
invoke-interface {p2, v2}, Lorg/opencv/android/LoaderCallbackInterface;->onManagerConnected(I)V
goto :goto_139
:cond_fb
:goto_fb
sget-boolean p2, Lorg/opencv/android/AsyncServiceHelper;->mLibraryInstallationProgress:Z
if-nez p2, :cond_10c
new-instance p2, Lorg/opencv/android/AsyncServiceHelper$3$1;
invoke-direct {p2, p0}, Lorg/opencv/android/AsyncServiceHelper$3$1;-><init>(Lorg/opencv/android/AsyncServiceHelper$3;)V
iget-object v4, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v4, v4, Lorg/opencv/android/AsyncServiceHelper;->mUserAppCallback:Lorg/opencv/android/LoaderCallbackInterface;
invoke-interface {v4, v2, p2}, Lorg/opencv/android/LoaderCallbackInterface;->onPackageInstall(ILorg/opencv/android/InstallCallbackInterface;)V
goto :goto_119
:cond_10c
new-instance p2, Lorg/opencv/android/AsyncServiceHelper$3$2;
invoke-direct {p2, p0}, Lorg/opencv/android/AsyncServiceHelper$3$2;-><init>(Lorg/opencv/android/AsyncServiceHelper$3;)V
iget-object v2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v2, v2, Lorg/opencv/android/AsyncServiceHelper;->mUserAppCallback:Lorg/opencv/android/LoaderCallbackInterface;
const/4 v4, 0x1
invoke-interface {v2, v4, p2}, Lorg/opencv/android/LoaderCallbackInterface;->onPackageInstall(ILorg/opencv/android/InstallCallbackInterface;)V
:try_end_119
.catch Landroid/os/RemoteException; {:try_start_2e .. :try_end_119} :catch_11a
:goto_119
return-void
:catch_11a
move-exception p2
invoke-virtual {p2}, Landroid/os/RemoteException;->printStackTrace()V
const-string p2, "Init finished with status 255"
invoke-static {v1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p2, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object v0, p2, Lorg/opencv/android/AsyncServiceHelper;->mAppContext:Landroid/content/Context;
iget-object p2, p2, Lorg/opencv/android/AsyncServiceHelper;->mServiceConnection:Landroid/content/ServiceConnection;
invoke-virtual {v0, p2}, Landroid/content/Context;->unbindService(Landroid/content/ServiceConnection;)V
invoke-static {v1, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
iget-object p1, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
iget-object p1, p1, Lorg/opencv/android/AsyncServiceHelper;->mUserAppCallback:Lorg/opencv/android/LoaderCallbackInterface;
invoke-interface {p1, v3}, Lorg/opencv/android/LoaderCallbackInterface;->onManagerConnected(I)V
:goto_139
return-void
.end method
.method public onServiceDisconnected(Landroid/content/ComponentName;)V
.registers 3
iget-object p1, p0, Lorg/opencv/android/AsyncServiceHelper$3;->this$0:Lorg/opencv/android/AsyncServiceHelper;
const/4 v0, 0x0
iput-object v0, p1, Lorg/opencv/android/AsyncServiceHelper;->mEngineService:Lorg/opencv/engine/OpenCVEngineInterface;
return-void
.end method