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