Framework.smali
.class public final Lorg/acdd/framework/Framework;
.super Ljava/lang/Object;
.source "Framework.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/acdd/framework/Framework$SystemBundle;
}
.end annotation
# static fields
.field private static BASEDIR:Ljava/lang/String; = null
.field static DEBUG_BUNDLES:Z = false
.field static DEBUG_CLASSLOADING:Z = false
.field private static final FRAMEWORK_VERSION:Ljava/lang/String; = "1.0.0"
.field private static STORAGE_LOCATION:Ljava/lang/String;
.field private static bundleListeners:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Lorg/osgi/framework/BundleListener;",
">;"
}
.end annotation
.end field
.field private static classNotFoundCallback:Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;
.field static frameworkListeners:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Lorg/osgi/framework/FrameworkListener;",
">;"
}
.end annotation
.end field
.field private static initStartlevel:I
.field private static final log:Lorg/acdd/log/Logger;
.field private static pluginLoadChecker:Lorg/acdd/android/compat/IPluginLoadChecker;
.field private static pluginRemoveListener:Lorg/acdd/framework/PluginRemoveListener;
.field private static properties:Ljava/util/Properties;
.field private static restart:Z
.field static startlevel:I
.field static syncBundleListeners:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Lorg/osgi/framework/BundleListener;",
">;"
}
.end annotation
.end field
.field private static systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
.field static systemClassLoader:Ljava/lang/ClassLoader;
.field private static writeAheads:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
# direct methods
.method static constructor <clinit>()V
.registers 3
.prologue
const/4 v2, 0x0
const/4 v1, 0x1
.line 84
const/4 v0, 0x0
sput-object v0, Lorg/acdd/framework/Framework;->BASEDIR:Ljava/lang/String;
.line 85
sput-boolean v1, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z
.line 86
sput-boolean v1, Lorg/acdd/framework/Framework;->DEBUG_CLASSLOADING:Z
.line 89
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
sput-object v0, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;
.line 91
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
sput-object v0, Lorg/acdd/framework/Framework;->frameworkListeners:Ljava/util/List;
.line 92
sput v1, Lorg/acdd/framework/Framework;->initStartlevel:I
.line 93
invoke-static {}, Lorg/acdd/log/LoggerFactory;->getInstance()Lorg/acdd/log/Logger;
move-result-object v0
sput-object v0, Lorg/acdd/framework/Framework;->log:Lorg/acdd/log/Logger;
.line 95
sput-boolean v2, Lorg/acdd/framework/Framework;->restart:Z
.line 96
sput v2, Lorg/acdd/framework/Framework;->startlevel:I
.line 97
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
sput-object v0, Lorg/acdd/framework/Framework;->syncBundleListeners:Ljava/util/List;
.line 100
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
sput-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
return-void
.end method
.method private constructor <init>()V
.registers 1
.prologue
.line 473
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 474
return-void
.end method
.method private static MergeWirteAheads(Ljava/io/File;)V
.registers 6
.prologue
.line 909
:try_start_0
new-instance v0, Ljava/io/File;
sget-object v1, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
const-string/jumbo v2, "wal"
invoke-direct {v0, v1, v2}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 910
sget-object v1, Lorg/acdd/android/compat/AppBuildConfig;->PROCESSNAME:Ljava/lang/String;
.line 911
sget-object v2, Lorg/acdd/framework/Framework;->log:Lorg/acdd/log/Logger;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "restoreProfile in process "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-interface {v2, v3}, Lorg/acdd/log/Logger;->debug(Ljava/lang/String;)V
.line 912
sget-object v2, Lorg/acdd/runtime/RuntimeVariables;->androidApplication:Landroid/app/Application;
invoke-virtual {v2}, Landroid/app/Application;->getPackageName()Ljava/lang/String;
move-result-object v2
.line 913
if-eqz v1, :cond_37
if-eqz v2, :cond_37
invoke-virtual {v1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_37
.line 914
invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->mergeWalsDir(Ljava/io/File;Ljava/io/File;)V
:try_end_37
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_37} :catch_38
.line 921
:cond_37
:goto_37
return-void
.line 916
:catch_38
move-exception v0
.line 917
sget-object v1, Landroid/os/Build;->MODEL:Ljava/lang/String;
if-eqz v1, :cond_47
sget-object v1, Landroid/os/Build;->MODEL:Ljava/lang/String;
const-string v2, "HTC 802w"
invoke-virtual {v1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_37
.line 918
:cond_47
sget-object v1, Lorg/acdd/framework/Framework;->log:Lorg/acdd/log/Logger;
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;
move-result-object v0
invoke-interface {v1, v2, v0}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_37
.end method
.method static synthetic access$100()Lorg/acdd/framework/Framework$SystemBundle;
.registers 1
.prologue
.line 83
sget-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
return-object v0
.end method
.method static synthetic access$200()V
.registers 0
.prologue
.line 83
invoke-static {}, Lorg/acdd/framework/Framework;->storeMetadata()V
return-void
.end method
.method static synthetic access$300()I
.registers 1
.prologue
.line 83
sget v0, Lorg/acdd/framework/Framework;->initStartlevel:I
return v0
.end method
.method static synthetic access$302(I)I
.registers 1
.prologue
.line 83
sput p0, Lorg/acdd/framework/Framework;->initStartlevel:I
return p0
.end method
.method static synthetic access$400(Landroid/util/SparseArray;ILorg/acdd/framework/BundleImpl;)V
.registers 3
.prologue
.line 83
invoke-static {p0, p1, p2}, Lorg/acdd/framework/Framework;->addValue(Landroid/util/SparseArray;ILorg/acdd/framework/BundleImpl;)V
return-void
.end method
.method static synthetic access$500()Lorg/acdd/log/Logger;
.registers 1
.prologue
.line 83
sget-object v0, Lorg/acdd/framework/Framework;->log:Lorg/acdd/log/Logger;
return-object v0
.end method
.method static addBundleListener(Lorg/osgi/framework/BundleListener;)V
.registers 2
.prologue
.line 924
sget-object v0, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;
invoke-interface {v0, p0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 925
return-void
.end method
.method private static addValue(Landroid/util/SparseArray;ILorg/acdd/framework/BundleImpl;)V
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/util/SparseArray",
"<",
"Ljava/util/List",
"<",
"Lorg/acdd/framework/BundleImpl;",
">;>;I",
"Lorg/acdd/framework/BundleImpl;",
")V"
}
.end annotation
.prologue
.line 953
invoke-virtual {p0, p1}, Landroid/util/SparseArray;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/List;
.line 954
if-nez v0, :cond_e
.line 955
new-instance v0, Ljava/util/ArrayList;
const/4 v1, 0x2
invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(I)V
.line 957
:cond_e
invoke-interface {v0, p2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 958
invoke-virtual {p0, p1, v0}, Landroid/util/SparseArray;->put(ILjava/lang/Object;)V
.line 959
return-void
.end method
.method static clearBundleTrace(Lorg/acdd/framework/BundleImpl;)V
.registers 4
.prologue
const/4 v2, 0x0
.line 939
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->registeredFrameworkListeners:Ljava/util/List;
if-eqz v0, :cond_e
.line 940
sget-object v0, Lorg/acdd/framework/Framework;->frameworkListeners:Ljava/util/List;
iget-object v1, p0, Lorg/acdd/framework/BundleImpl;->registeredFrameworkListeners:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->removeAll(Ljava/util/Collection;)Z
.line 941
iput-object v2, p0, Lorg/acdd/framework/BundleImpl;->registeredFrameworkListeners:Ljava/util/List;
.line 944
:cond_e
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->registeredBundleListeners:Ljava/util/List;
if-eqz v0, :cond_22
.line 945
sget-object v0, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;
iget-object v1, p0, Lorg/acdd/framework/BundleImpl;->registeredBundleListeners:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->removeAll(Ljava/util/Collection;)Z
.line 946
sget-object v0, Lorg/acdd/framework/Framework;->syncBundleListeners:Ljava/util/List;
iget-object v1, p0, Lorg/acdd/framework/BundleImpl;->registeredBundleListeners:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->removeAll(Ljava/util/Collection;)Z
.line 947
iput-object v2, p0, Lorg/acdd/framework/BundleImpl;->registeredBundleListeners:Ljava/util/List;
.line 950
:cond_22
return-void
.end method
.method private static deletePluginsDirectory(Ljava/io/File;)V
.registers 10
.prologue
.line 611
invoke-virtual {p0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v1
.line 612
array-length v2, v1
const/4 v0, 0x0
:goto_6
if-ge v0, v2, :cond_69
aget-object v3, v1, v0
.line 613
invoke-virtual {v3}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v4
.line 614
invoke-virtual {v3}, Ljava/io/File;->isDirectory()Z
move-result v5
if-eqz v5, :cond_66
invoke-static {v4}, Lorg/acdd/framework/Framework;->pluginShouldRemoved(Ljava/lang/String;)Z
move-result v4
if-eqz v4, :cond_66
.line 615
invoke-static {v3}, Lorg/acdd/util/ACDDUtils;->deleteDirectory(Ljava/io/File;)V
.line 616
invoke-virtual {v3}, Ljava/io/File;->exists()Z
move-result v4
if-eqz v4, :cond_66
.line 617
sget-object v4, Lorg/acdd/framework/Framework;->log:Lorg/acdd/log/Logger;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "installPlugin plugin:"
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v5
const-string v6, " delete failed!!!"
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-interface {v4, v5}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;)V
.line 619
:try_start_41
invoke-static {}, Lorg/acdd/framework/ACDD;->getInstance()Lorg/acdd/framework/ACDD;
move-result-object v4
const-string v5, "4042"
new-instance v6, Ljava/lang/RuntimeException;
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string v8, "delete failed file:"
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
.line 620
invoke-virtual {v3}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v3
invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v6, v3}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
.line 619
invoke-virtual {v4, v5, v6}, Lorg/acdd/framework/ACDD;->reportCrash(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_66
.catch Ljava/lang/Throwable; {:try_start_41 .. :try_end_66} :catch_6a
.line 612
:cond_66
:goto_66
add-int/lit8 v0, v0, 0x1
goto :goto_6
.line 627
:cond_69
return-void
.line 621
:catch_6a
move-exception v3
goto :goto_66
.end method
.method public static getClassNotFoundCallback()Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;
.registers 1
.prologue
.line 962
sget-object v0, Lorg/acdd/framework/Framework;->classNotFoundCallback:Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;
return-object v0
.end method
.method static getLastPluginFilePath(Ljava/lang/String;)Ljava/lang/String;
.registers 2
.prologue
.line 744
sget-object v0, Lorg/acdd/runtime/RuntimeVariables;->androidApplication:Landroid/app/Application;
invoke-static {v0, p0}, Lorg/acdd/framework/PathManager;->getLastPluginFilePath(Landroid/app/Application;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public static getProperty(Ljava/lang/String;I)I
.registers 3
.prologue
.line 725
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
if-nez v0, :cond_5
.line 729
:cond_4
:goto_4
return p1
.line 728
:cond_5
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v0, p0}, Ljava/util/Properties;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
.line 729
if-eqz v0, :cond_4
invoke-static {v0}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result p1
goto :goto_4
.end method
.method public static getProperty(Ljava/lang/String;)Ljava/lang/String;
.registers 2
.prologue
.line 733
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
if-nez v0, :cond_6
.line 734
const/4 v0, 0x0
.line 736
:goto_5
return-object v0
:cond_6
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v0, p0}, Ljava/util/Properties;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
goto :goto_5
.end method
.method public static getProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 3
.prologue
.line 740
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
if-nez v0, :cond_5
:goto_4
return-object p1
:cond_5
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v0, p0}, Ljava/util/Properties;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
move-object p1, v0
goto :goto_4
.end method
.method public static getProperty(Ljava/lang/String;Z)Z
.registers 3
.prologue
.line 717
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
if-nez v0, :cond_5
.line 721
:cond_4
:goto_4
return p1
.line 720
:cond_5
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v0, p0}, Ljava/util/Properties;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
.line 721
if-eqz v0, :cond_4
invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Ljava/lang/String;)Ljava/lang/Boolean;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z
move-result p1
goto :goto_4
.end method
.method public static getSystemClassLoader()Ljava/lang/ClassLoader;
.registers 1
.prologue
.line 630
sget-object v0, Lorg/acdd/framework/Framework;->systemClassLoader:Ljava/lang/ClassLoader;
return-object v0
.end method
.method public static initialize()V
.registers 5
.prologue
const/4 v4, 0x1
const/4 v1, 0x0
.line 652
sget-object v0, Lorg/acdd/runtime/RuntimeVariables;->androidApplication:Landroid/app/Application;
invoke-virtual {v0}, Landroid/app/Application;->getFilesDir()Ljava/io/File;
move-result-object v0
.line 653
if-eqz v0, :cond_10
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_16
.line 654
:cond_10
sget-object v0, Lorg/acdd/runtime/RuntimeVariables;->androidApplication:Landroid/app/Application;
invoke-virtual {v0}, Landroid/app/Application;->getFilesDir()Ljava/io/File;
move-result-object v0
.line 656
:cond_16
if-nez v0, :cond_1e
.line 657
sget-object v0, Lorg/acdd/runtime/RuntimeVariables;->androidApplication:Landroid/app/Application;
invoke-static {v0}, Lorg/acdd/util/ApkUtils;->getFilesDir(Landroid/content/Context;)Ljava/io/File;
move-result-object v0
.line 659
:cond_1e
sget-object v2, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
const-string v3, "org.acdd.basedir"
invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v3, v0}, Ljava/util/Properties;->getProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
sput-object v0, Lorg/acdd/framework/Framework;->BASEDIR:Ljava/lang/String;
.line 660
const-string v0, "org.acdd.debug.bundles"
invoke-static {v0, v1}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;Z)Z
move-result v0
sput-boolean v0, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z
.line 661
const-string v0, "org.acdd.debug.classloading"
invoke-static {v0, v1}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;Z)Z
move-result v0
sput-boolean v0, Lorg/acdd/framework/Framework;->DEBUG_CLASSLOADING:Z
.line 662
const-string v0, "org.acdd.debug"
invoke-static {v0, v1}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;Z)Z
move-result v0
if-eqz v0, :cond_4f
.line 663
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v2, "SETTING ALL DEBUG FLAGS"
invoke-virtual {v0, v2}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 664
sput-boolean v4, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z
.line 665
sput-boolean v4, Lorg/acdd/framework/Framework;->DEBUG_CLASSLOADING:Z
.line 667
:cond_4f
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
const-string v2, "org.osgi.framework.system.packages"
invoke-virtual {v0, v2}, Ljava/util/Properties;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 668
if-eqz v0, :cond_77
.line 669
new-instance v2, Ljava/util/StringTokenizer;
const-string v3, ","
invoke-direct {v2, v0, v3}, Ljava/util/StringTokenizer;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 670
invoke-virtual {v2}, Ljava/util/StringTokenizer;->countTokens()I
move-result v3
move v0, v1
.line 671
:goto_65
if-ge v0, v3, :cond_77
.line 672
sget-object v1, Lorg/acdd/framework/BundleClassLoader;->FRAMEWORK_PACKAGES:Ljava/util/HashSet;
invoke-virtual {v2}, Ljava/util/StringTokenizer;->nextToken()Ljava/lang/String;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/String;->trim()Ljava/lang/String;
move-result-object v4
invoke-virtual {v1, v4}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z
.line 671
add-int/lit8 v0, v0, 0x1
goto :goto_65
.line 675
:cond_77
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
const-string v1, "org.osgi.framework.executionenvironment"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "java.specification.name"
invoke-static {v3}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "/"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "java.specification.version"
invoke-static {v3}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 676
const-string v1, "org.osgi.framework.os.name"
.line 677
const-string v0, "os.name"
invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 678
if-nez v0, :cond_ae
.line 679
const-string/jumbo v0, "undefined"
.line 681
:cond_ae
sget-object v2, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v2, v1, v0}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 683
const-string v1, "org.osgi.framework.os.version"
.line 684
const-string v0, "os.version"
invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 685
if-nez v0, :cond_c0
.line 686
const-string/jumbo v0, "undefined"
.line 688
:cond_c0
sget-object v2, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v2, v1, v0}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 690
const-string v1, "org.osgi.framework.processor"
.line 691
const-string v0, "os.arch"
invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 692
if-nez v0, :cond_d2
.line 693
const-string/jumbo v0, "undefined"
.line 695
:cond_d2
sget-object v2, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v2, v1, v0}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 696
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
const-string v1, "org.osgi.framework.version"
const-string v2, "1.0.0"
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 697
sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
const-string v1, "org.osgi.framework.vendor"
const-string v2, "ACDD"
invoke-virtual {v0, v1, v2}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 698
invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;
move-result-object v0
invoke-virtual {v0}, Ljava/util/Locale;->getLanguage()Ljava/lang/String;
move-result-object v0
.line 700
const-string v1, "org.osgi.framework.language"
.line 701
if-nez v0, :cond_f7
.line 702
const-string v0, "en"
.line 704
:cond_f7
sget-object v2, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
invoke-virtual {v2, v1, v0}, Ljava/util/Properties;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 707
return-void
.end method
.method static installNewBundle(Ljava/lang/String;Ljava/io/InputStream;)Lorg/osgi/framework/Bundle;
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
.line 349
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteLock(Ljava/lang/String;)V
.line 350
new-instance v1, Ljava/io/File;
sget-object v0, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
invoke-direct {v1, v0, p0}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 351
invoke-static {}, Lorg/acdd/util/ACDDFileLock;->getInstance()Lorg/acdd/util/ACDDFileLock;
move-result-object v0
invoke-virtual {v0, v1}, Lorg/acdd/util/ACDDFileLock;->lock(Ljava/io/File;)Z
.line 353
const/4 v0, 0x1
:try_start_12
invoke-static {v1, p0, p1, v0}, Lorg/acdd/framework/BundleManager;->installBundle(Ljava/io/File;Ljava/lang/String;Ljava/io/InputStream;Z)Lorg/osgi/framework/Bundle;
move-result-object v0
check-cast v0, Lorg/acdd/framework/BundleImpl;
.line 354
invoke-static {}, Lorg/acdd/framework/Framework;->storeMetadata()V
:try_end_1b
.catch Ljava/lang/Throwable; {:try_start_12 .. :try_end_1b} :catch_26
.catchall {:try_start_12 .. :try_end_1b} :catchall_51
.line 360
:try_start_1b
invoke-static {}, Lorg/acdd/util/ACDDFileLock;->getInstance()Lorg/acdd/util/ACDDFileLock;
move-result-object v2
invoke-virtual {v2, v1}, Lorg/acdd/util/ACDDFileLock;->unLock(Ljava/io/File;)V
.line 361
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
:try_end_25
.catch Ljava/lang/Throwable; {:try_start_1b .. :try_end_25} :catch_5f
.line 366
:goto_25
return-object v0
.line 355
:catch_26
move-exception v0
.line 356
:try_start_27
invoke-static {}, Lorg/acdd/log/LoggerFactory;->getInstance()Lorg/acdd/log/Logger;
move-result-object v2
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "[PluginInstall] NewInstall => Plugin["
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string v4, "] failed!!!"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-interface {v2, v3, v0}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 357
new-instance v2, Lorg/osgi/framework/BundleException;
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v3, v0}, Lorg/osgi/framework/BundleException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
:try_end_51
.catchall {:try_start_27 .. :try_end_51} :catchall_51
.line 359
:catchall_51
move-exception v0
.line 360
:try_start_52
invoke-static {}, Lorg/acdd/util/ACDDFileLock;->getInstance()Lorg/acdd/util/ACDDFileLock;
move-result-object v2
invoke-virtual {v2, v1}, Lorg/acdd/util/ACDDFileLock;->unLock(Ljava/io/File;)V
.line 361
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
:try_end_5c
.catch Ljava/lang/Throwable; {:try_start_52 .. :try_end_5c} :catch_5d
.line 363
:goto_5c
throw v0
.line 362
:catch_5d
move-exception v1
goto :goto_5c
:catch_5f
move-exception v1
goto :goto_25
.end method
.method private static isAllowPluginLoad(Ljava/lang/String;)Z
.registers 2
.prologue
.line 604
sget-object v0, Lorg/acdd/framework/Framework;->pluginLoadChecker:Lorg/acdd/android/compat/IPluginLoadChecker;
if-eqz v0, :cond_b
.line 605
sget-object v0, Lorg/acdd/framework/Framework;->pluginLoadChecker:Lorg/acdd/android/compat/IPluginLoadChecker;
invoke-interface {v0, p0}, Lorg/acdd/android/compat/IPluginLoadChecker;->isAllowPluginLoad(Ljava/lang/String;)Z
move-result v0
.line 607
:goto_a
return v0
:cond_b
const/4 v0, 0x1
goto :goto_a
.end method
.method public static isLegalBundle(Lorg/acdd/framework/bundlestorage/BundleArchiveRevision;Ljava/lang/String;)Z
.registers 3
.prologue
.line 394
:try_start_0
invoke-static {p1}, Lorg/acdd/util/BundleLock;->WriteLock(Ljava/lang/String;)V
.line 396
invoke-virtual {p0}, Lorg/acdd/framework/bundlestorage/BundleArchiveRevision;->computeBundleCrc()V
.line 397
invoke-virtual {p0}, Lorg/acdd/framework/bundlestorage/BundleArchiveRevision;->isLegalBundleArchiveFile()Z
:try_end_9
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_9} :catch_e
.catchall {:try_start_0 .. :try_end_9} :catchall_14
move-result v0
.line 400
invoke-static {p1}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
.line 402
:goto_d
return v0
.line 398
:catch_e
move-exception v0
.line 400
invoke-static {p1}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
.line 402
const/4 v0, 0x0
goto :goto_d
.line 400
:catchall_14
move-exception v0
invoke-static {p1}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
throw v0
.end method
.method public static isLegalBundle(Lorg/osgi/framework/Bundle;Ljava/lang/String;)Z
.registers 3
.prologue
.line 406
invoke-interface {p0}, Lorg/osgi/framework/Bundle;->getArchive()Lorg/acdd/framework/bundlestorage/Archive;
move-result-object v0
.line 407
if-eqz v0, :cond_12
invoke-interface {v0}, Lorg/acdd/framework/bundlestorage/Archive;->getCurrentRevision()Lorg/acdd/framework/bundlestorage/BundleArchiveRevision;
move-result-object v0
invoke-static {v0, p1}, Lorg/acdd/framework/Framework;->isLegalBundle(Lorg/acdd/framework/bundlestorage/BundleArchiveRevision;Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_12
const/4 v0, 0x1
:goto_11
return v0
:cond_12
const/4 v0, 0x0
goto :goto_11
.end method
.method public static isLegalBundleFiles(Ljava/lang/String;)Z
.registers 3
.prologue
.line 379
:try_start_0
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteLock(Ljava/lang/String;)V
.line 380
new-instance v0, Ljava/io/File;
sget-object v1, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
invoke-direct {v0, v1, p0}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 381
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_1b
.line 382
invoke-static {v0, p0}, Lorg/acdd/framework/bundlestorage/BundleArchive;->isLegalBundleArchiveFile(Ljava/io/File;Ljava/lang/String;)Z
:try_end_13
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_13} :catch_20
.catchall {:try_start_0 .. :try_end_13} :catchall_25
move-result v0
.line 383
if-eqz v0, :cond_1b
const/4 v0, 0x1
.line 387
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
.line 389
:goto_1a
return v0
.line 387
:cond_1b
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
.line 389
:goto_1e
const/4 v0, 0x0
goto :goto_1a
.line 385
:catch_20
move-exception v0
.line 387
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
goto :goto_1e
:catchall_25
move-exception v0
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
throw v0
.end method
.method private static launch()V
.registers 7
.prologue
.line 710
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
sget-object v1, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
const-string v2, "org.acdd.storage"
sget-object v3, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
const-string v4, "org.osgi.framework.dir"
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
sget-object v6, Lorg/acdd/framework/Framework;->BASEDIR:Ljava/lang/String;
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
sget-char v6, Ljava/io/File;->separatorChar:C
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v5
const-string/jumbo v6, "storage"
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-virtual {v3, v4, v5}, Ljava/util/Properties;->getProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v1, v2, v3}, Ljava/util/Properties;->getProperty(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
sget-char v1, Ljava/io/File;->separatorChar:C
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
sput-object v0, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
.line 712
new-instance v0, Lorg/acdd/framework/Framework$SystemBundle;
invoke-direct {v0}, Lorg/acdd/framework/Framework$SystemBundle;-><init>()V
sput-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
.line 713
sget-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
const/16 v1, 0x8
iput v1, v0, Lorg/acdd/framework/Framework$SystemBundle;->state:I
.line 714
return-void
.end method
.method private static mergeWalsDir(Ljava/io/File;Ljava/io/File;)V
.registers 14
.prologue
const/4 v2, 0x0
.line 845
sget-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
if-eqz v0, :cond_99
sget-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
if-lez v0, :cond_99
move v1, v2
.line 846
:goto_e
sget-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
if-ge v1, v0, :cond_99
.line 847
sget-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
if-eqz v0, :cond_94
.line 848
new-instance v3, Ljava/io/File;
sget-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
invoke-interface {v0, v1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
invoke-direct {v3, p0, v0}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 850
:try_start_2b
invoke-virtual {v3}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_8e
.line 851
invoke-virtual {v3}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v4
.line 852
if-eqz v4, :cond_8e
.line 853
array-length v5, v4
move v3, v2
:goto_39
if-ge v3, v5, :cond_8e
aget-object v0, v4, v3
.line 854
invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z
move-result v6
if-eqz v6, :cond_82
.line 855
new-instance v6, Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v7
invoke-direct {v6, p1, v7}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 856
invoke-virtual {v6}, Ljava/io/File;->exists()Z
move-result v7
if-eqz v7, :cond_7f
.line 857
new-instance v7, Lorg/acdd/framework/Framework$3;
invoke-direct {v7}, Lorg/acdd/framework/Framework$3;-><init>()V
invoke-virtual {v0, v7}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;
move-result-object v7
.line 863
if-eqz v7, :cond_82
.line 864
array-length v8, v7
move v0, v2
:goto_5f
if-ge v0, v8, :cond_82
aget-object v9, v7, v0
.line 865
new-instance v10, Ljava/io/File;
const-string v11, "meta"
invoke-direct {v10, v9, v11}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v10}, Ljava/io/File;->exists()Z
move-result v10
if-eqz v10, :cond_7c
.line 866
new-instance v10, Ljava/io/File;
invoke-virtual {v9}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v11
invoke-direct {v10, v6, v11}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v9, v10}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
.line 864
:cond_7c
add-int/lit8 v0, v0, 0x1
goto :goto_5f
.line 871
:cond_7f
invoke-virtual {v0, v6}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
:try_end_82
.catch Ljava/lang/Throwable; {:try_start_2b .. :try_end_82} :catch_86
.line 853
:cond_82
add-int/lit8 v0, v3, 0x1
move v3, v0
goto :goto_39
.line 877
:catch_86
move-exception v0
.line 878
sget-object v3, Lorg/acdd/framework/Framework;->log:Lorg/acdd/log/Logger;
const-string v4, "Error while merge wal dir"
invoke-interface {v3, v4, v0}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 880
:cond_8e
sget-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
const/4 v3, 0x0
invoke-interface {v0, v1, v3}, Ljava/util/List;->set(ILjava/lang/Object;)Ljava/lang/Object;
.line 846
:cond_94
add-int/lit8 v0, v1, 0x1
move v1, v0
goto/16 :goto_e
.line 884
:cond_99
invoke-virtual {p0}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_a2
.line 885
invoke-virtual {p0}, Ljava/io/File;->delete()Z
.line 887
:cond_a2
return-void
.end method
.method static notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
.registers 8
.prologue
const/4 v1, 0x0
.line 891
sget-object v0, Lorg/acdd/framework/Framework;->syncBundleListeners:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-eqz v0, :cond_11
sget-object v0, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-nez v0, :cond_55
.line 892
:cond_11
new-instance v3, Lorg/osgi/framework/BundleEvent;
invoke-direct {v3, p0, p1}, Lorg/osgi/framework/BundleEvent;-><init>(ILorg/osgi/framework/Bundle;)V
.line 893
sget-object v0, Lorg/acdd/framework/Framework;->syncBundleListeners:Ljava/util/List;
sget-object v2, Lorg/acdd/framework/Framework;->syncBundleListeners:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
new-array v2, v2, [Lorg/osgi/framework/BundleListener;
invoke-interface {v0, v2}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lorg/osgi/framework/BundleListener;
.line 894
array-length v4, v0
move v2, v1
:goto_28
if-ge v2, v4, :cond_32
aget-object v5, v0, v2
.line 895
invoke-interface {v5, v3}, Lorg/osgi/framework/BundleListener;->bundleChanged(Lorg/osgi/framework/BundleEvent;)V
.line 894
add-int/lit8 v2, v2, 0x1
goto :goto_28
.line 897
:cond_32
sget-object v0, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-nez v0, :cond_55
.line 898
sget-object v0, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;
sget-object v2, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
new-array v2, v2, [Lorg/osgi/framework/BundleListener;
invoke-interface {v0, v2}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lorg/osgi/framework/BundleListener;
.line 899
array-length v2, v0
:goto_4b
if-ge v1, v2, :cond_55
aget-object v4, v0, v1
.line 900
invoke-interface {v4, v3}, Lorg/osgi/framework/BundleListener;->bundleChanged(Lorg/osgi/framework/BundleEvent;)V
.line 899
add-int/lit8 v1, v1, 0x1
goto :goto_4b
.line 905
:cond_55
return-void
.end method
.method static notifyFrameworkListeners(ILorg/osgi/framework/Bundle;Ljava/lang/Throwable;)V
.registers 8
.prologue
.line 928
sget-object v0, Lorg/acdd/framework/Framework;->frameworkListeners:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-nez v0, :cond_29
.line 929
new-instance v2, Lorg/osgi/framework/FrameworkEvent;
invoke-direct {v2, p0, p1, p2}, Lorg/osgi/framework/FrameworkEvent;-><init>(ILorg/osgi/framework/Bundle;Ljava/lang/Throwable;)V
.line 930
sget-object v0, Lorg/acdd/framework/Framework;->frameworkListeners:Ljava/util/List;
sget-object v1, Lorg/acdd/framework/Framework;->frameworkListeners:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v1
new-array v1, v1, [Lorg/osgi/framework/FrameworkListener;
invoke-interface {v0, v1}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lorg/osgi/framework/FrameworkListener;
.line 931
array-length v3, v0
const/4 v1, 0x0
:goto_1f
if-ge v1, v3, :cond_29
aget-object v4, v0, v1
.line 932
invoke-interface {v4, v2}, Lorg/osgi/framework/FrameworkListener;->frameworkEvent(Lorg/osgi/framework/FrameworkEvent;)V
.line 931
add-int/lit8 v1, v1, 0x1
goto :goto_1f
.line 935
:cond_29
return-void
.end method
.method private static pluginShouldRemoved(Ljava/lang/String;)Z
.registers 2
.prologue
.line 600
sget-object v0, Lorg/acdd/framework/Framework;->pluginRemoveListener:Lorg/acdd/framework/PluginRemoveListener;
if-eqz v0, :cond_c
sget-object v0, Lorg/acdd/framework/Framework;->pluginRemoveListener:Lorg/acdd/framework/PluginRemoveListener;
invoke-interface {v0, p0}, Lorg/acdd/framework/PluginRemoveListener;->shouldRemoved(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_e
:cond_c
const/4 v0, 0x1
:goto_d
return v0
:cond_e
const/4 v0, 0x0
goto :goto_d
.end method
.method private static reportFileCorrupt(Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)V
.registers 4
.prologue
.line 442
new-instance v0, Lorg/acdd/framework/Framework$1;
invoke-direct {v0, p2, p1, p0}, Lorg/acdd/framework/Framework$1;-><init>(Ljava/io/File;Ljava/lang/String;Ljava/lang/String;)V
invoke-static {v0}, Landroid/os/AsyncTask;->execute(Ljava/lang/Runnable;)V
.line 471
return-void
.end method
.method private static restoreProfile()I
.registers 10
.prologue
const/4 v1, 0x0
.line 789
:try_start_1
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v2, "Restoring profile"
invoke-virtual {v0, v2}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 790
new-instance v0, Ljava/io/File;
sget-object v2, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
const-string v3, "meta"
invoke-direct {v0, v2, v3}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 791
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v2
if-eqz v2, :cond_101
.line 792
new-instance v2, Ljava/io/DataInputStream;
new-instance v3, Ljava/io/FileInputStream;
invoke-direct {v3, v0}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
invoke-direct {v2, v3}, Ljava/io/DataInputStream;-><init>(Ljava/io/InputStream;)V
.line 793
invoke-virtual {v2}, Ljava/io/DataInputStream;->readInt()I
move-result v0
.line 794
invoke-virtual {v2}, Ljava/io/DataInputStream;->readUTF()Ljava/lang/String;
move-result-object v3
const-string v4, ","
invoke-static {v3, v4}, Lorg/acdd/util/StringUtils;->split(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
move-result-object v3
.line 795
if-eqz v3, :cond_3a
.line 796
sget-object v4, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
invoke-static {v3}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v3
invoke-interface {v4, v3}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
.line 798
:cond_3a
invoke-virtual {v2}, Ljava/io/DataInputStream;->close()V
.line 799
const-string v2, "org.acdd.auto.load"
const/4 v3, 0x1
invoke-static {v2, v3}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;Z)Z
move-result v2
if-nez v2, :cond_47
.line 840
:cond_46
:goto_46
return v0
.line 802
:cond_47
new-instance v2, Ljava/io/File;
sget-object v3, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
invoke-direct {v2, v3}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 803
new-instance v3, Ljava/io/File;
sget-object v4, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
const-string/jumbo v5, "wal"
invoke-direct {v3, v4, v5}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
invoke-static {v3, v2}, Lorg/acdd/framework/Framework;->mergeWalsDir(Ljava/io/File;Ljava/io/File;)V
.line 804
invoke-static {v2}, Lorg/acdd/framework/Framework;->MergeWirteAheads(Ljava/io/File;)V
.line 805
new-instance v3, Lorg/acdd/framework/Framework$2;
invoke-direct {v3}, Lorg/acdd/framework/Framework$2;-><init>()V
invoke-virtual {v2, v3}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;
move-result-object v4
move v3, v1
.line 812
:goto_68
array-length v2, v4
if-ge v3, v2, :cond_46
.line 813
aget-object v2, v4, v3
invoke-virtual {v2}, Ljava/io/File;->isDirectory()Z
move-result v2
if-eqz v2, :cond_a0
new-instance v2, Ljava/io/File;
aget-object v5, v4, v3
const-string v6, "meta"
invoke-direct {v2, v5, v6}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v2
if-eqz v2, :cond_a0
.line 814
aget-object v2, v4, v3
invoke-virtual {v2}, Ljava/io/File;->getName()Ljava/lang/String;
:try_end_87
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_87} :catch_fa
move-result-object v5
.line 816
:try_start_88
new-instance v2, Ljava/io/File;
sget-object v6, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
invoke-direct {v2, v6, v5}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 817
invoke-static {v5}, Lorg/acdd/framework/Framework;->isLegalBundleFiles(Ljava/lang/String;)Z
move-result v6
.line 818
invoke-static {v5}, Lorg/acdd/framework/Framework;->isAllowPluginLoad(Ljava/lang/String;)Z
move-result v7
.line 820
if-eqz v6, :cond_a4
if-eqz v7, :cond_a4
.line 821
aget-object v2, v4, v3
invoke-static {v2, v5}, Lorg/acdd/framework/BundleManager;->loadBundle(Ljava/io/File;Ljava/lang/String;)Lorg/osgi/framework/Bundle;
.line 832
:cond_a0
:goto_a0
add-int/lit8 v2, v3, 0x1
move v3, v2
goto :goto_68
.line 823
:cond_a4
const-string v8, "4057"
invoke-static {v8, v5, v2}, Lorg/acdd/framework/Framework;->reportFileCorrupt(Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)V
.line 824
invoke-static {}, Lorg/acdd/log/LoggerFactory;->getInstance()Lorg/acdd/log/Logger;
move-result-object v2
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "[PluginInstall] Installed => Load Plugin["
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
const-string v9, "] failed!!!, by:legalBundleFiles:"
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v8
invoke-virtual {v8, v6}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
move-result-object v6
const-string v8, ",isAllowPluginLoad:"
invoke-virtual {v6, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-interface {v2, v6}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;)V
:try_end_d7
.catch Ljava/lang/Exception; {:try_start_88 .. :try_end_d7} :catch_d8
goto :goto_a0
.line 828
:catch_d8
move-exception v2
.line 829
:try_start_d9
invoke-static {}, Lorg/acdd/log/LoggerFactory;->getInstance()Lorg/acdd/log/Logger;
move-result-object v6
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
const-string v8, "[PluginInstall] Installed => Load Plugin["
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
invoke-virtual {v7, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
const-string v7, "] failed!!!"
invoke-virtual {v5, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-interface {v6, v5, v2}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_f9
.catch Ljava/lang/Exception; {:try_start_d9 .. :try_end_f9} :catch_fa
goto :goto_a0
.line 838
:catch_fa
move-exception v0
.line 839
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
move v0, v1
.line 840
goto/16 :goto_46
.line 836
:cond_101
:try_start_101
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v2, "Profile not found, performing clean start ..."
invoke-virtual {v0, v2}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
:try_end_108
.catch Ljava/lang/Exception; {:try_start_101 .. :try_end_108} :catch_fa
.line 837
const/4 v0, -0x1
goto/16 :goto_46
.end method
.method static setClassNotFoundCallback(Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;)V
.registers 1
.prologue
.line 966
sput-object p0, Lorg/acdd/framework/Framework;->classNotFoundCallback:Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;
.line 967
return-void
.end method
.method static setPluginLoadChecker(Lorg/acdd/android/compat/IPluginLoadChecker;)V
.registers 1
.prologue
.line 374
sput-object p0, Lorg/acdd/framework/Framework;->pluginLoadChecker:Lorg/acdd/android/compat/IPluginLoadChecker;
.line 375
return-void
.end method
.method static setPluginRemoveListener(Lorg/acdd/framework/PluginRemoveListener;)V
.registers 1
.prologue
.line 370
sput-object p0, Lorg/acdd/framework/Framework;->pluginRemoveListener:Lorg/acdd/framework/PluginRemoveListener;
.line 371
return-void
.end method
.method static shutdown(Z)V
.registers 5
.prologue
const/4 v3, 0x1
.line 634
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, "---------------------------------------------------------"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 635
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, " ACDD OSGi shutting down ..."
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 636
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, " Bye !"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 637
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, "---------------------------------------------------------"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 638
sget-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
const/16 v1, 0x10
iput v1, v0, Lorg/acdd/framework/Framework$SystemBundle;->state:I
.line 639
sget-object v1, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
invoke-static {}, Lorg/acdd/framework/BundleManager;->getBundles()Ljava/util/List;
move-result-object v0
invoke-static {}, Lorg/acdd/framework/BundleManager;->getBundleCount()I
move-result v2
new-array v2, v2, [Lorg/osgi/framework/Bundle;
invoke-interface {v0, v2}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lorg/osgi/framework/Bundle;
const/4 v2, 0x0
# invokes: Lorg/acdd/framework/Framework$SystemBundle;->setLevel([Lorg/osgi/framework/Bundle;IZ)V
invoke-static {v1, v0, v2, v3}, Lorg/acdd/framework/Framework$SystemBundle;->access$000(Lorg/acdd/framework/Framework$SystemBundle;[Lorg/osgi/framework/Bundle;IZ)V
.line 640
invoke-static {}, Lorg/acdd/framework/BundleManager;->removeAllBundle()V
.line 641
sget-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
iput v3, v0, Lorg/acdd/framework/Framework$SystemBundle;->state:I
.line 642
if-eqz p0, :cond_45
.line 644
:try_start_42
invoke-static {}, Lorg/acdd/framework/Framework;->startup()V
:try_end_45
.catch Ljava/lang/Throwable; {:try_start_42 .. :try_end_45} :catch_46
.line 649
:cond_45
:goto_45
return-void
.line 645
:catch_46
move-exception v0
.line 646
invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V
goto :goto_45
.end method
.method private static startup()V
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
const/4 v1, -0x1
const/4 v8, 0x0
const/4 v7, 0x0
const/4 v5, 0x1
.line 486
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v2, "---------------------------------------------------------"
invoke-virtual {v0, v2}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 487
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, " ACDD OSGi 1.0.0 Pre-Release on "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
sget-object v3, Landroid/os/Build;->MODEL:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "/"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
sget-object v3, Landroid/os/Build;->CPU_ABI:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "/"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
sget-object v3, Landroid/os/Build$VERSION;->RELEASE:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, " SDK version "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
sget v3, Landroid/os/Build$VERSION;->SDK_INT:I
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, " starting ..."
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 489
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v2, "---------------------------------------------------------"
invoke-virtual {v0, v2}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 490
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
.line 492
invoke-static {}, Lorg/acdd/framework/Framework;->initialize()V
.line 493
invoke-static {}, Lorg/acdd/framework/Framework;->launch()V
.line 495
const-string v0, "osgi.init"
invoke-static {v0, v7}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;Z)Z
move-result v4
.line 497
if-eqz v4, :cond_121
move v0, v1
.line 504
:goto_69
if-ne v0, v1, :cond_219
.line 505
sput-boolean v7, Lorg/acdd/framework/Framework;->restart:Z
.line 506
new-instance v1, Ljava/io/File;
sget-object v0, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
invoke-direct {v1, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 508
if-eqz v4, :cond_91
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_91
.line 510
:try_start_7c
invoke-static {}, Lorg/acdd/util/ACDDFileLock;->getInstance()Lorg/acdd/util/ACDDFileLock;
move-result-object v0
invoke-virtual {v0, v1}, Lorg/acdd/util/ACDDFileLock;->lock(Ljava/io/File;)Z
.line 511
invoke-static {v1}, Lorg/acdd/framework/Framework;->deletePluginsDirectory(Ljava/io/File;)V
.line 512
invoke-static {}, Lorg/acdd/util/ACDDFileLock;->getInstance()Lorg/acdd/util/ACDDFileLock;
move-result-object v0
invoke-virtual {v0, v1}, Lorg/acdd/util/ACDDFileLock;->unLock(Ljava/io/File;)V
.line 516
const/4 v0, 0x0
invoke-static {v0}, Lorg/acdd/framework/Framework;->setPluginRemoveListener(Lorg/acdd/framework/PluginRemoveListener;)V
:try_end_91
.catch Ljava/lang/Throwable; {:try_start_7c .. :try_end_91} :catch_129
.line 560
:cond_91
:goto_91
:try_start_91
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_1ec
.line 561
invoke-static {}, Lorg/acdd/framework/Framework;->restoreProfile()I
move-result v0
.line 566
:goto_9b
const-string v1, "osgi.maxLevel"
const/4 v4, 0x1
invoke-static {v1, v4}, Ljava/lang/Integer;->getInteger(Ljava/lang/String;I)Ljava/lang/Integer;
.line 567
const-string v1, "osgi.startlevel.bundle"
const/4 v4, 0x1
invoke-static {v1, v4}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;I)I
move-result v1
sput v1, Lorg/acdd/framework/Framework;->initStartlevel:I
:try_end_aa
.catch Ljava/lang/Throwable; {:try_start_91 .. :try_end_aa} :catch_1f8
move v1, v0
.line 573
:goto_ab
sget-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
invoke-static {v7, v0, v8}, Lorg/acdd/framework/Framework;->notifyFrameworkListeners(ILorg/osgi/framework/Bundle;Ljava/lang/Throwable;)V
.line 575
sget-object v4, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
invoke-static {}, Lorg/acdd/framework/BundleManager;->getBundles()Ljava/util/List;
move-result-object v0
invoke-static {}, Lorg/acdd/framework/BundleManager;->getBundleCount()I
move-result v5
new-array v5, v5, [Lorg/osgi/framework/Bundle;
invoke-interface {v0, v5}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lorg/osgi/framework/Bundle;
# invokes: Lorg/acdd/framework/Framework$SystemBundle;->setLevel([Lorg/osgi/framework/Bundle;IZ)V
invoke-static {v4, v0, v1, v7}, Lorg/acdd/framework/Framework$SystemBundle;->access$000(Lorg/acdd/framework/Framework$SystemBundle;[Lorg/osgi/framework/Bundle;IZ)V
.line 577
sget-boolean v0, Lorg/acdd/framework/Framework;->restart:Z
if-nez v0, :cond_cc
.line 579
:try_start_c9
invoke-static {}, Lorg/acdd/framework/Framework;->storeProfile()V
:try_end_cc
.catch Ljava/lang/Throwable; {:try_start_c9 .. :try_end_cc} :catch_201
.line 585
:cond_cc
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
sub-long v2, v0, v2
.line 586
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, "---------------------------------------------------------"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 587
sget-object v1, Ljava/lang/System;->out:Ljava/io/PrintStream;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, " Framework "
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
sget-boolean v0, Lorg/acdd/framework/Framework;->restart:Z
if-eqz v0, :cond_20b
const-string v0, "restarted"
:goto_ec
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v4, " in "
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v0
const-string v2, " milliseconds."
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 588
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, "---------------------------------------------------------"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 589
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
invoke-virtual {v0}, Ljava/io/PrintStream;->flush()V
.line 592
:try_start_113
sget-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
const/16 v1, 0x20
iput v1, v0, Lorg/acdd/framework/Framework$SystemBundle;->state:I
.line 593
const/4 v0, 0x1
sget-object v1, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;
const/4 v2, 0x0
invoke-static {v0, v1, v2}, Lorg/acdd/framework/Framework;->notifyFrameworkListeners(ILorg/osgi/framework/Bundle;Ljava/lang/Throwable;)V
:try_end_120
.catch Ljava/lang/Throwable; {:try_start_113 .. :try_end_120} :catch_210
.line 597
return-void
.line 500
:cond_121
invoke-static {}, Lorg/acdd/framework/Framework;->restoreProfile()I
move-result v0
.line 501
sput-boolean v5, Lorg/acdd/framework/Framework;->restart:Z
goto/16 :goto_69
.line 517
:catch_129
move-exception v0
.line 518
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
.line 520
:try_start_12f
const-string v5, "ACDD : purge storage failed #1"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 521
const/16 v5, 0x5b
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v5
const/16 v6, 0x5d
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
.line 522
const-string v5, " "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v5, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 524
new-instance v5, Ljava/io/File;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
sget-object v6, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v6, ".tmp"
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v5, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 526
const-string v0, " Attempting to rename"
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 527
const/16 v0, 0x5b
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const/16 v6, 0x5d
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
:try_end_17e
.catch Ljava/lang/Throwable; {:try_start_12f .. :try_end_17e} :catch_195
.line 530
:try_start_17e
invoke-virtual {v5}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_187
invoke-static {v5}, Lorg/acdd/util/ACDDUtils;->deleteDirectory(Ljava/io/File;)V
:try_end_187
.catch Ljava/lang/Throwable; {:try_start_17e .. :try_end_187} :catch_1c9
.line 535
:cond_187
:goto_187
:try_start_187
const-string v0, " rename result : "
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 536
invoke-virtual {v1, v5}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
move-result v0
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
:try_end_193
.catch Ljava/lang/Throwable; {:try_start_187 .. :try_end_193} :catch_195
goto/16 :goto_91
.line 537
:catch_195
move-exception v0
.line 539
:try_start_196
new-instance v2, Ljava/io/File;
invoke-virtual {v1}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v1
const-string/jumbo v3, "storage.test"
invoke-direct {v2, v1, v3}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 540
const-string v1, " test directory["
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
const/16 v3, 0x5d
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
.line 542
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_1d8
.line 543
const-string v1, " existed."
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 549
:goto_1bc
invoke-static {v2}, Lorg/acdd/util/ACDDUtils;->deleteDirectory(Ljava/io/File;)V
:try_end_1bf
.catch Ljava/lang/Throwable; {:try_start_196 .. :try_end_1bf} :catch_1e1
.line 554
:goto_1bf
new-instance v1, Ljava/lang/RuntimeException;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.line 531
:catch_1c9
move-exception v0
.line 532
:try_start_1ca
const-string v6, " delete tmp file failed #2 "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:try_end_1d7
.catch Ljava/lang/Throwable; {:try_start_1ca .. :try_end_1d7} :catch_195
goto :goto_187
.line 545
:cond_1d8
:try_start_1d8
invoke-virtual {v2}, Ljava/io/File;->mkdir()Z
.line 546
const-string v1, " was create successfully."
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
:try_end_1e0
.catch Ljava/lang/Throwable; {:try_start_1d8 .. :try_end_1e0} :catch_1e1
goto :goto_1bc
.line 550
:catch_1e1
move-exception v1
.line 551
const-string v2, " attempting to test the file system viability failed #3 "
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
goto :goto_1bf
.line 563
:cond_1ec
:try_start_1ec
invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z
.line 564
const-string v0, "osgi.startlevel.framework"
const/4 v1, 0x1
invoke-static {v0, v1}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;I)I
:try_end_1f5
.catch Ljava/lang/Throwable; {:try_start_1ec .. :try_end_1f5} :catch_1f8
move-result v0
goto/16 :goto_9b
.line 568
:catch_1f8
move-exception v0
.line 569
new-instance v1, Ljava/lang/RuntimeException;
const-string v2, "mkdirs failed"
invoke-direct {v1, v2, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.line 580
:catch_201
move-exception v0
.line 581
new-instance v1, Ljava/lang/RuntimeException;
const-string/jumbo v2, "storeProfile failed"
invoke-direct {v1, v2, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.line 587
:cond_20b
const-string/jumbo v0, "started"
goto/16 :goto_ec
.line 594
:catch_210
move-exception v0
.line 595
new-instance v1, Ljava/lang/RuntimeException;
const-string v2, "notifyFrameworkListeners failed"
invoke-direct {v1, v2, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
:cond_219
move v1, v0
goto/16 :goto_ab
.end method
.method static startup(Ljava/util/Properties;)V
.registers 1
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
.line 477
if-nez p0, :cond_7
.line 478
new-instance p0, Ljava/util/Properties;
invoke-direct {p0}, Ljava/util/Properties;-><init>()V
.line 480
:cond_7
sput-object p0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;
.line 481
invoke-static {}, Lorg/acdd/framework/Framework;->startup()V
.line 482
return-void
.end method
.method private static storeMetadata()V
.registers 6
.prologue
.line 767
:try_start_0
new-instance v0, Ljava/io/File;
sget-object v1, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
const-string v2, "meta"
invoke-direct {v0, v1, v2}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 768
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v1
if-nez v1, :cond_12
.line 769
invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z
.line 771
:cond_12
new-instance v1, Ljava/io/DataOutputStream;
new-instance v2, Ljava/io/FileOutputStream;
invoke-direct {v2, v0}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
invoke-direct {v1, v2}, Ljava/io/DataOutputStream;-><init>(Ljava/io/OutputStream;)V
.line 772
sget v0, Lorg/acdd/framework/Framework;->startlevel:I
invoke-virtual {v1, v0}, Ljava/io/DataOutputStream;->writeInt(I)V
.line 773
sget-object v0, Lorg/acdd/framework/Framework;->writeAheads:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->toArray()[Ljava/lang/Object;
move-result-object v0
const-string v2, ","
invoke-static {v0, v2}, Lorg/acdd/util/StringUtils;->join([Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 774
if-nez v0, :cond_31
.line 775
const-string v0, ""
.line 777
:cond_31
invoke-virtual {v1, v0}, Ljava/io/DataOutputStream;->writeUTF(Ljava/lang/String;)V
.line 778
invoke-virtual {v1}, Ljava/io/DataOutputStream;->flush()V
.line 779
invoke-virtual {v1}, Ljava/io/DataOutputStream;->close()V
:try_end_3a
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_3a} :catch_3b
.line 785
:goto_3a
return-void
.line 781
:catch_3b
move-exception v5
.line 782
invoke-static {}, Lorg/acdd/log/ACDDMonitor;->getInstance()Lorg/acdd/log/ACDDMonitor;
move-result-object v0
const/4 v1, -0x3
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
const-string v2, ""
const-string v3, ""
const-string/jumbo v4, "storeMetadata failed "
invoke-virtual/range {v0 .. v5}, Lorg/acdd/log/ACDDMonitor;->trace(Ljava/lang/Integer;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 783
sget-object v0, Lorg/acdd/framework/Framework;->log:Lorg/acdd/log/Logger;
const-string v1, "Could not save meta data."
invoke-interface {v0, v1, v5}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_3a
.end method
.method private static storeProfile()V
.registers 5
.prologue
.line 755
invoke-static {}, Lorg/acdd/framework/BundleManager;->getBundles()Ljava/util/List;
move-result-object v0
invoke-static {}, Lorg/acdd/framework/BundleManager;->getBundleCount()I
move-result v1
new-array v1, v1, [Lorg/osgi/framework/Bundle;
invoke-interface {v0, v1}, Ljava/util/List;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lorg/osgi/framework/Bundle;
.line 756
array-length v3, v0
const/4 v1, 0x0
move v2, v1
:goto_13
if-ge v2, v3, :cond_24
aget-object v1, v0, v2
.line 757
instance-of v4, v1, Lorg/acdd/framework/BundleImpl;
if-eqz v4, :cond_20
.line 758
check-cast v1, Lorg/acdd/framework/BundleImpl;
invoke-virtual {v1}, Lorg/acdd/framework/BundleImpl;->updateMetadata()V
.line 756
:cond_20
add-int/lit8 v1, v2, 0x1
move v2, v1
goto :goto_13
.line 761
:cond_24
invoke-static {}, Lorg/acdd/framework/Framework;->storeMetadata()V
.line 762
return-void
.end method
.method public static tryLoadBundleInstance(Ljava/lang/String;)Lorg/osgi/framework/Bundle;
.registers 9
.prologue
const/4 v0, 0x0
.line 411
const/4 v2, 0x0
.line 413
:try_start_2
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteLock(Ljava/lang/String;)V
.line 414
new-instance v1, Ljava/io/File;
sget-object v3, Lorg/acdd/framework/Framework;->STORAGE_LOCATION:Ljava/lang/String;
invoke-direct {v1, v3, p0}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 415
invoke-virtual {v1}, Ljava/io/File;->exists()Z
:try_end_f
.catch Ljava/lang/Exception; {:try_start_2 .. :try_end_f} :catch_63
.catchall {:try_start_2 .. :try_end_f} :catchall_c6
move-result v2
.line 416
if-nez v2, :cond_16
.line 436
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
.line 438
:goto_15
return-object v0
.line 418
:cond_16
:try_start_16
invoke-static {v1, p0}, Lorg/acdd/framework/bundlestorage/BundleArchive;->isLegalBundleArchiveFile(Ljava/io/File;Ljava/lang/String;)Z
move-result v3
.line 419
invoke-static {p0}, Lorg/acdd/framework/Framework;->isAllowPluginLoad(Ljava/lang/String;)Z
move-result v4
.line 420
if-eqz v3, :cond_2c
if-eqz v4, :cond_2c
.line 421
const/4 v3, 0x1
const/4 v4, 0x1
invoke-static {v1, p0, v3, v4}, Lorg/acdd/framework/BundleManager;->loadBundle(Ljava/io/File;Ljava/lang/String;IZ)Lorg/osgi/framework/Bundle;
:try_end_27
.catch Ljava/lang/Exception; {:try_start_16 .. :try_end_27} :catch_63
.catchall {:try_start_16 .. :try_end_27} :catchall_c6
move-result-object v0
.line 436
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
goto :goto_15
.line 423
:cond_2c
:try_start_2c
invoke-static {}, Lorg/acdd/log/LoggerFactory;->getInstance()Lorg/acdd/log/Logger;
move-result-object v5
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "[PluginInstall] NewInstall => Load Plugin["
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
const-string v7, "] failed!!!, by:legalBundleFiles:"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
move-result-object v3
const-string v6, ",isAllowPluginLoad:"
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-interface {v5, v3}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;)V
.line 426
const-string v3, "4039"
invoke-static {v3, p0, v1}, Lorg/acdd/framework/Framework;->reportFileCorrupt(Ljava/lang/String;Ljava/lang/String;Ljava/io/File;)V
:try_end_5f
.catch Ljava/lang/Exception; {:try_start_2c .. :try_end_5f} :catch_63
.catchall {:try_start_2c .. :try_end_5f} :catchall_c6
.line 436
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
goto :goto_15
.line 428
:catch_63
move-exception v1
.line 429
:try_start_64
invoke-static {}, Lorg/acdd/log/LoggerFactory;->getInstance()Lorg/acdd/log/Logger;
move-result-object v3
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "[PluginInstall] Installed => Load Plugin["
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, "] failed!!!"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-interface {v3, v4, v1}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 431
new-instance v3, Ljava/lang/UnsupportedOperationException;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "attempting to reload plugin bundle instance failed, bundle : "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
const-string v5, ", bundle file exists : "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
move-result-object v2
const-string v4, " Cur bundle list :"
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
.line 433
invoke-static {}, Lorg/acdd/bundleInfo/BundleInfoList;->getInstance()Lorg/acdd/bundleInfo/BundleInfoList;
move-result-object v4
invoke-virtual {v4}, Lorg/acdd/bundleInfo/BundleInfoList;->getBundleInfoNamesStr()Ljava/lang/String;
move-result-object v4
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v3, v2, v1}, Ljava/lang/UnsupportedOperationException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 434
invoke-static {}, Lorg/acdd/framework/ACDD;->getInstance()Lorg/acdd/framework/ACDD;
move-result-object v1
const-string v2, "4014"
invoke-virtual {v1, v2, v3}, Lorg/acdd/framework/ACDD;->reportCrash(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_c1
.catchall {:try_start_64 .. :try_end_c1} :catchall_c6
.line 436
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
goto/16 :goto_15
:catchall_c6
move-exception v0
invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V
throw v0
.end method
.method protected static warning(Ljava/lang/String;)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/RuntimeException;
}
.end annotation
.prologue
.line 748
const-string v0, "org.acdd.strictStartup"
const/4 v1, 0x0
invoke-static {v0, v1}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;Z)Z
move-result v0
if-eqz v0, :cond_f
.line 749
new-instance v0, Ljava/lang/RuntimeException;
invoke-direct {v0, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.line 751
:cond_f
sget-object v0, Ljava/lang/System;->err:Ljava/io/PrintStream;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "WARNING: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 752
return-void
.end method