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 475
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 476
    return-void
.end method

.method private static MergeWirteAheads(Ljava/io/File;)V
    .registers 6

    .prologue
    .line 911
    :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 912
    sget-object v1, Lorg/acdd/android/compat/AppBuildConfig;->PROCESSNAME:Ljava/lang/String;

    .line 913
    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/jumbo 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 914
    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 915
    if-eqz v1, :cond_38

    if-eqz v2, :cond_38

    invoke-virtual {v1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v1

    if-eqz v1, :cond_38

    .line 916
    invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->mergeWalsDir(Ljava/io/File;Ljava/io/File;)V
    :try_end_38
    .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_38} :catch_39

    .line 923
    :cond_38
    :goto_38
    return-void

    .line 918
    :catch_39
    move-exception v0

    .line 919
    sget-object v1, Landroid/os/Build;->MODEL:Ljava/lang/String;

    if-eqz v1, :cond_48

    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_38

    .line 920
    :cond_48
    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_38
.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 926
    sget-object v0, Lorg/acdd/framework/Framework;->bundleListeners:Ljava/util/List;

    invoke-interface {v0, p0}, Ljava/util/List;->add(Ljava/lang/Object;)Z

    .line 927
    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 955
    invoke-virtual {p0, p1}, Landroid/util/SparseArray;->get(I)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/util/List;

    .line 956
    if-nez v0, :cond_e

    .line 957
    new-instance v0, Ljava/util/ArrayList;

    const/4 v1, 0x2

    invoke-direct {v0, v1}, Ljava/util/ArrayList;-><init>(I)V

    .line 959
    :cond_e
    invoke-interface {v0, p2}, Ljava/util/List;->add(Ljava/lang/Object;)Z

    .line 960
    invoke-virtual {p0, p1, v0}, Landroid/util/SparseArray;->put(ILjava/lang/Object;)V

    .line 961
    return-void
.end method

.method static clearBundleTrace(Lorg/acdd/framework/BundleImpl;)V
    .registers 4

    .prologue
    const/4 v2, 0x0

    .line 941
    iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->registeredFrameworkListeners:Ljava/util/List;

    if-eqz v0, :cond_e

    .line 942
    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 943
    iput-object v2, p0, Lorg/acdd/framework/BundleImpl;->registeredFrameworkListeners:Ljava/util/List;

    .line 946
    :cond_e
    iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->registeredBundleListeners:Ljava/util/List;

    if-eqz v0, :cond_22

    .line 947
    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 948
    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 949
    iput-object v2, p0, Lorg/acdd/framework/BundleImpl;->registeredBundleListeners:Ljava/util/List;

    .line 952
    :cond_22
    return-void
.end method

.method private static deletePluginsDirectory(Ljava/io/File;)V
    .registers 10

    .prologue
    .line 613
    invoke-virtual {p0}, Ljava/io/File;->listFiles()[Ljava/io/File;

    move-result-object v1

    .line 614
    array-length v2, v1

    const/4 v0, 0x0

    :goto_6
    if-ge v0, v2, :cond_69

    aget-object v3, v1, v0

    .line 615
    invoke-virtual {v3}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v4

    .line 616
    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 617
    invoke-static {v3}, Lorg/acdd/util/ACDDUtils;->deleteDirectory(Ljava/io/File;)V

    .line 618
    invoke-virtual {v3}, Ljava/io/File;->exists()Z

    move-result v4

    if-eqz v4, :cond_66

    .line 619
    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 621
    :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 622
    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 621
    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 614
    :cond_66
    :goto_66
    add-int/lit8 v0, v0, 0x1

    goto :goto_6

    .line 629
    :cond_69
    return-void

    .line 623
    :catch_6a
    move-exception v3

    goto :goto_66
.end method

.method public static getClassNotFoundCallback()Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;
    .registers 1

    .prologue
    .line 964
    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 746
    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 727
    sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    if-nez v0, :cond_5

    .line 731
    :cond_4
    :goto_4
    return p1

    .line 730
    :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 731
    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 735
    sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    if-nez v0, :cond_6

    .line 736
    const/4 v0, 0x0

    .line 738
    :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 742
    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 719
    sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    if-nez v0, :cond_5

    .line 723
    :cond_4
    :goto_4
    return p1

    .line 722
    :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 723
    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 632
    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 654
    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 655
    if-eqz v0, :cond_10

    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v2

    if-nez v2, :cond_16

    .line 656
    :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 658
    :cond_16
    if-nez v0, :cond_1e

    .line 659
    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 661
    :cond_1e
    sget-object v2, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    const-string/jumbo 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 662
    const-string/jumbo 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 663
    const-string/jumbo 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 664
    const-string/jumbo 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_53

    .line 665
    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 666
    sput-boolean v4, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z

    .line 667
    sput-boolean v4, Lorg/acdd/framework/Framework;->DEBUG_CLASSLOADING:Z

    .line 669
    :cond_53
    sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    const-string/jumbo 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 670
    if-eqz v0, :cond_7c

    .line 671
    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 672
    invoke-virtual {v2}, Ljava/util/StringTokenizer;->countTokens()I

    move-result v3

    move v0, v1

    .line 673
    :goto_6a
    if-ge v0, v3, :cond_7c

    .line 674
    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 673
    add-int/lit8 v0, v0, 0x1

    goto :goto_6a

    .line 677
    :cond_7c
    sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    const-string/jumbo 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 678
    const-string/jumbo v1, "org.osgi.framework.os.name"

    .line 679
    const-string/jumbo v0, "os.name"

    invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 680
    if-nez v0, :cond_b6

    .line 681
    const-string/jumbo v0, "undefined"

    .line 683
    :cond_b6
    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 685
    const-string/jumbo v1, "org.osgi.framework.os.version"

    .line 686
    const-string/jumbo v0, "os.version"

    invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 687
    if-nez v0, :cond_ca

    .line 688
    const-string/jumbo v0, "undefined"

    .line 690
    :cond_ca
    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 692
    const-string/jumbo v1, "org.osgi.framework.processor"

    .line 693
    const-string/jumbo v0, "os.arch"

    invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 694
    if-nez v0, :cond_de

    .line 695
    const-string/jumbo v0, "undefined"

    .line 697
    :cond_de
    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 698
    sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    const-string/jumbo 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 699
    sget-object v0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    const-string/jumbo 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 700
    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 702
    const-string/jumbo v1, "org.osgi.framework.language"

    .line 703
    if-nez v0, :cond_106

    .line 704
    const-string v0, "en"

    .line 706
    :cond_106
    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 709
    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 606
    sget-object v0, Lorg/acdd/framework/Framework;->pluginLoadChecker:Lorg/acdd/android/compat/IPluginLoadChecker;

    if-eqz v0, :cond_b

    .line 607
    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 609
    :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 407
    invoke-interface {p0}, Lorg/osgi/framework/Bundle;->getArchive()Lorg/acdd/framework/bundlestorage/Archive;

    move-result-object v0

    .line 408
    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 712
    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/jumbo v2, "org.acdd.storage"

    sget-object v3, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    const-string/jumbo 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 714
    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 715
    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 716
    return-void
.end method

.method private static mergeWalsDir(Ljava/io/File;Ljava/io/File;)V
    .registers 14

    .prologue
    const/4 v2, 0x0

    .line 847
    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 848
    :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 849
    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 850
    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 852
    :try_start_2b
    invoke-virtual {v3}, Ljava/io/File;->exists()Z

    move-result v0

    if-eqz v0, :cond_8e

    .line 853
    invoke-virtual {v3}, Ljava/io/File;->listFiles()[Ljava/io/File;

    move-result-object v4

    .line 854
    if-eqz v4, :cond_8e

    .line 855
    array-length v5, v4

    move v3, v2

    :goto_39
    if-ge v3, v5, :cond_8e

    aget-object v0, v4, v3

    .line 856
    invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z

    move-result v6

    if-eqz v6, :cond_82

    .line 857
    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 858
    invoke-virtual {v6}, Ljava/io/File;->exists()Z

    move-result v7

    if-eqz v7, :cond_7f

    .line 859
    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 865
    if-eqz v7, :cond_82

    .line 866
    array-length v8, v7

    move v0, v2

    :goto_5f
    if-ge v0, v8, :cond_82

    aget-object v9, v7, v0

    .line 867
    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 868
    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 866
    :cond_7c
    add-int/lit8 v0, v0, 0x1

    goto :goto_5f

    .line 873
    :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 855
    :cond_82
    add-int/lit8 v0, v3, 0x1

    move v3, v0

    goto :goto_39

    .line 879
    :catch_86
    move-exception v0

    .line 880
    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 882
    :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 848
    :cond_94
    add-int/lit8 v0, v1, 0x1

    move v1, v0

    goto/16 :goto_e

    .line 886
    :cond_99
    invoke-virtual {p0}, Ljava/io/File;->exists()Z

    move-result v0

    if-eqz v0, :cond_a2

    .line 887
    invoke-virtual {p0}, Ljava/io/File;->delete()Z

    .line 889
    :cond_a2
    return-void
.end method

.method static notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
    .registers 8

    .prologue
    const/4 v1, 0x0

    .line 893
    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 894
    :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 895
    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 896
    array-length v4, v0

    move v2, v1

    :goto_28
    if-ge v2, v4, :cond_32

    aget-object v5, v0, v2

    .line 897
    invoke-interface {v5, v3}, Lorg/osgi/framework/BundleListener;->bundleChanged(Lorg/osgi/framework/BundleEvent;)V

    .line 896
    add-int/lit8 v2, v2, 0x1

    goto :goto_28

    .line 899
    :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 900
    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 901
    array-length v2, v0

    :goto_4b
    if-ge v1, v2, :cond_55

    aget-object v4, v0, v1

    .line 902
    invoke-interface {v4, v3}, Lorg/osgi/framework/BundleListener;->bundleChanged(Lorg/osgi/framework/BundleEvent;)V

    .line 901
    add-int/lit8 v1, v1, 0x1

    goto :goto_4b

    .line 907
    :cond_55
    return-void
.end method

.method static notifyFrameworkListeners(ILorg/osgi/framework/Bundle;Ljava/lang/Throwable;)V
    .registers 8

    .prologue
    .line 930
    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 931
    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 932
    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 933
    array-length v3, v0

    const/4 v1, 0x0

    :goto_1f
    if-ge v1, v3, :cond_29

    aget-object v4, v0, v1

    .line 934
    invoke-interface {v4, v2}, Lorg/osgi/framework/FrameworkListener;->frameworkEvent(Lorg/osgi/framework/FrameworkEvent;)V

    .line 933
    add-int/lit8 v1, v1, 0x1

    goto :goto_1f

    .line 937
    :cond_29
    return-void
.end method

.method private static pluginShouldRemoved(Ljava/lang/String;)Z
    .registers 2

    .prologue
    .line 602
    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 444
    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 473
    return-void
.end method

.method private static restoreProfile()I
    .registers 10

    .prologue
    const/4 v1, 0x0

    .line 791
    :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 792
    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 793
    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v2

    if-eqz v2, :cond_102

    .line 794
    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 795
    invoke-virtual {v2}, Ljava/io/DataInputStream;->readInt()I

    move-result v0

    .line 796
    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 797
    if-eqz v3, :cond_3a

    .line 798
    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 800
    :cond_3a
    invoke-virtual {v2}, Ljava/io/DataInputStream;->close()V

    .line 801
    const-string/jumbo 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_48

    .line 842
    :cond_47
    :goto_47
    return v0

    .line 804
    :cond_48
    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 805
    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 806
    invoke-static {v2}, Lorg/acdd/framework/Framework;->MergeWirteAheads(Ljava/io/File;)V

    .line 807
    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 814
    :goto_69
    array-length v2, v4

    if-ge v3, v2, :cond_47

    .line 815
    aget-object v2, v4, v3

    invoke-virtual {v2}, Ljava/io/File;->isDirectory()Z

    move-result v2

    if-eqz v2, :cond_a1

    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_a1

    .line 816
    aget-object v2, v4, v3

    invoke-virtual {v2}, Ljava/io/File;->getName()Ljava/lang/String;
    :try_end_88
    .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_88} :catch_fb

    move-result-object v5

    .line 818
    :try_start_89
    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 819
    invoke-static {v5}, Lorg/acdd/framework/Framework;->isLegalBundleFiles(Ljava/lang/String;)Z

    move-result v6

    .line 820
    invoke-static {v5}, Lorg/acdd/framework/Framework;->isAllowPluginLoad(Ljava/lang/String;)Z

    move-result v7

    .line 822
    if-eqz v6, :cond_a5

    if-eqz v7, :cond_a5

    .line 823
    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 834
    :cond_a1
    :goto_a1
    add-int/lit8 v2, v3, 0x1

    move v3, v2

    goto :goto_69

    .line 825
    :cond_a5
    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 826
    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_d8
    .catch Ljava/lang/Exception; {:try_start_89 .. :try_end_d8} :catch_d9

    goto :goto_a1

    .line 830
    :catch_d9
    move-exception v2

    .line 831
    :try_start_da
    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_fa
    .catch Ljava/lang/Exception; {:try_start_da .. :try_end_fa} :catch_fb

    goto :goto_a1

    .line 840
    :catch_fb
    move-exception v0

    .line 841
    invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V

    move v0, v1

    .line 842
    goto/16 :goto_47

    .line 838
    :cond_102
    :try_start_102
    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_109
    .catch Ljava/lang/Exception; {:try_start_102 .. :try_end_109} :catch_fb

    .line 839
    const/4 v0, -0x1

    goto/16 :goto_47
.end method

.method static setClassNotFoundCallback(Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;)V
    .registers 1

    .prologue
    .line 968
    sput-object p0, Lorg/acdd/framework/Framework;->classNotFoundCallback:Lorg/acdd/runtime/ClassNotFoundInterceptorCallback;

    .line 969
    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 636
    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 637
    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 638
    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 639
    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 640
    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 641
    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 642
    invoke-static {}, Lorg/acdd/framework/BundleManager;->removeAllBundle()V

    .line 643
    sget-object v0, Lorg/acdd/framework/Framework;->systemBundle:Lorg/acdd/framework/Framework$SystemBundle;

    iput v3, v0, Lorg/acdd/framework/Framework$SystemBundle;->state:I

    .line 644
    if-eqz p0, :cond_45

    .line 646
    :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 651
    :cond_45
    :goto_45
    return-void

    .line 647
    :catch_46
    move-exception v0

    .line 648
    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 488
    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 489
    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 491
    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 492
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    .line 494
    invoke-static {}, Lorg/acdd/framework/Framework;->initialize()V

    .line 495
    invoke-static {}, Lorg/acdd/framework/Framework;->launch()V

    .line 497
    const-string/jumbo v0, "osgi.init"

    invoke-static {v0, v7}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;Z)Z

    move-result v4

    .line 499
    if-eqz v4, :cond_125

    move v0, v1

    .line 506
    :goto_6a
    if-ne v0, v1, :cond_21e

    .line 507
    sput-boolean v7, Lorg/acdd/framework/Framework;->restart:Z

    .line 508
    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 510
    if-eqz v4, :cond_92

    invoke-virtual {v1}, Ljava/io/File;->exists()Z

    move-result v0

    if-eqz v0, :cond_92

    .line 512
    :try_start_7d
    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 513
    invoke-static {v1}, Lorg/acdd/framework/Framework;->deletePluginsDirectory(Ljava/io/File;)V

    .line 514
    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 518
    const/4 v0, 0x0

    invoke-static {v0}, Lorg/acdd/framework/Framework;->setPluginRemoveListener(Lorg/acdd/framework/PluginRemoveListener;)V
    :try_end_92
    .catch Ljava/lang/Throwable; {:try_start_7d .. :try_end_92} :catch_12d

    .line 562
    :cond_92
    :goto_92
    :try_start_92
    invoke-virtual {v1}, Ljava/io/File;->exists()Z

    move-result v0

    if-eqz v0, :cond_1f0

    .line 563
    invoke-static {}, Lorg/acdd/framework/Framework;->restoreProfile()I

    move-result v0

    .line 568
    :goto_9c
    const-string/jumbo v1, "osgi.maxLevel"

    const/4 v4, 0x1

    invoke-static {v1, v4}, Ljava/lang/Integer;->getInteger(Ljava/lang/String;I)Ljava/lang/Integer;

    .line 569
    const-string/jumbo 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_ad
    .catch Ljava/lang/Throwable; {:try_start_92 .. :try_end_ad} :catch_1fd

    move v1, v0

    .line 575
    :goto_ae
    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 577
    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 579
    sget-boolean v0, Lorg/acdd/framework/Framework;->restart:Z

    if-nez v0, :cond_cf

    .line 581
    :try_start_cc
    invoke-static {}, Lorg/acdd/framework/Framework;->storeProfile()V
    :try_end_cf
    .catch Ljava/lang/Throwable; {:try_start_cc .. :try_end_cf} :catch_206

    .line 587
    :cond_cf
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v0

    sub-long v2, v0, v2

    .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 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_210

    const-string/jumbo v0, "restarted"

    :goto_f0
    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 590
    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 591
    sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;

    invoke-virtual {v0}, Ljava/io/PrintStream;->flush()V

    .line 594
    :try_start_117
    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 595
    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_124
    .catch Ljava/lang/Throwable; {:try_start_117 .. :try_end_124} :catch_215

    .line 599
    return-void

    .line 502
    :cond_125
    invoke-static {}, Lorg/acdd/framework/Framework;->restoreProfile()I

    move-result v0

    .line 503
    sput-boolean v5, Lorg/acdd/framework/Framework;->restart:Z

    goto/16 :goto_6a

    .line 519
    :catch_12d
    move-exception v0

    .line 520
    new-instance v4, Ljava/lang/StringBuilder;

    invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V

    .line 522
    :try_start_133
    const-string v5, "ACDD : purge storage failed #1"

    invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 523
    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 524
    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 526
    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 528
    const-string v0, " Attempting to rename"

    invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 529
    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_182
    .catch Ljava/lang/Throwable; {:try_start_133 .. :try_end_182} :catch_199

    .line 532
    :try_start_182
    invoke-virtual {v5}, Ljava/io/File;->exists()Z

    move-result v0

    if-eqz v0, :cond_18b

    invoke-static {v5}, Lorg/acdd/util/ACDDUtils;->deleteDirectory(Ljava/io/File;)V
    :try_end_18b
    .catch Ljava/lang/Throwable; {:try_start_182 .. :try_end_18b} :catch_1cd

    .line 537
    :cond_18b
    :goto_18b
    :try_start_18b
    const-string v0, " rename result : "

    invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 538
    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_197
    .catch Ljava/lang/Throwable; {:try_start_18b .. :try_end_197} :catch_199

    goto/16 :goto_92

    .line 539
    :catch_199
    move-exception v0

    .line 541
    :try_start_19a
    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 542
    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 544
    invoke-virtual {v2}, Ljava/io/File;->exists()Z

    move-result v1

    if-eqz v1, :cond_1dc

    .line 545
    const-string v1, " existed."

    invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 551
    :goto_1c0
    invoke-static {v2}, Lorg/acdd/util/ACDDUtils;->deleteDirectory(Ljava/io/File;)V
    :try_end_1c3
    .catch Ljava/lang/Throwable; {:try_start_19a .. :try_end_1c3} :catch_1e5

    .line 556
    :goto_1c3
    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 533
    :catch_1cd
    move-exception v0

    .line 534
    :try_start_1ce
    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_1db
    .catch Ljava/lang/Throwable; {:try_start_1ce .. :try_end_1db} :catch_199

    goto :goto_18b

    .line 547
    :cond_1dc
    :try_start_1dc
    invoke-virtual {v2}, Ljava/io/File;->mkdir()Z

    .line 548
    const-string v1, " was create successfully."

    invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    :try_end_1e4
    .catch Ljava/lang/Throwable; {:try_start_1dc .. :try_end_1e4} :catch_1e5

    goto :goto_1c0

    .line 552
    :catch_1e5
    move-exception v1

    .line 553
    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_1c3

    .line 565
    :cond_1f0
    :try_start_1f0
    invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z

    .line 566
    const-string/jumbo v0, "osgi.startlevel.framework"

    const/4 v1, 0x1

    invoke-static {v0, v1}, Lorg/acdd/framework/Framework;->getProperty(Ljava/lang/String;I)I
    :try_end_1fa
    .catch Ljava/lang/Throwable; {:try_start_1f0 .. :try_end_1fa} :catch_1fd

    move-result v0

    goto/16 :goto_9c

    .line 570
    :catch_1fd
    move-exception v0

    .line 571
    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 582
    :catch_206
    move-exception v0

    .line 583
    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 589
    :cond_210
    const-string/jumbo v0, "started"

    goto/16 :goto_f0

    .line 596
    :catch_215
    move-exception v0

    .line 597
    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_21e
    move v1, v0

    goto/16 :goto_ae
.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 479
    if-nez p0, :cond_7

    .line 480
    new-instance p0, Ljava/util/Properties;

    invoke-direct {p0}, Ljava/util/Properties;-><init>()V

    .line 482
    :cond_7
    sput-object p0, Lorg/acdd/framework/Framework;->properties:Ljava/util/Properties;

    .line 483
    invoke-static {}, Lorg/acdd/framework/Framework;->startup()V

    .line 484
    return-void
.end method

.method private static storeMetadata()V
    .registers 6

    .prologue
    .line 769
    :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 770
    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v1

    if-nez v1, :cond_12

    .line 771
    invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z

    .line 773
    :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 774
    sget v0, Lorg/acdd/framework/Framework;->startlevel:I

    invoke-virtual {v1, v0}, Ljava/io/DataOutputStream;->writeInt(I)V

    .line 775
    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 776
    if-nez v0, :cond_31

    .line 777
    const-string v0, ""

    .line 779
    :cond_31
    invoke-virtual {v1, v0}, Ljava/io/DataOutputStream;->writeUTF(Ljava/lang/String;)V

    .line 780
    invoke-virtual {v1}, Ljava/io/DataOutputStream;->flush()V

    .line 781
    invoke-virtual {v1}, Ljava/io/DataOutputStream;->close()V
    :try_end_3a
    .catch Ljava/io/IOException; {:try_start_0 .. :try_end_3a} :catch_3b

    .line 787
    :goto_3a
    return-void

    .line 783
    :catch_3b
    move-exception v5

    .line 784
    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 785
    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 757
    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 758
    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 759
    instance-of v4, v1, Lorg/acdd/framework/BundleImpl;

    if-eqz v4, :cond_20

    .line 760
    check-cast v1, Lorg/acdd/framework/BundleImpl;

    invoke-virtual {v1}, Lorg/acdd/framework/BundleImpl;->updateMetadata()V

    .line 758
    :cond_20
    add-int/lit8 v1, v2, 0x1

    move v2, v1

    goto :goto_13

    .line 763
    :cond_24
    invoke-static {}, Lorg/acdd/framework/Framework;->storeMetadata()V

    .line 764
    return-void
.end method

.method public static tryLoadBundleInstance(Ljava/lang/String;)Lorg/osgi/framework/Bundle;
    .registers 9

    .prologue
    const/4 v0, 0x0

    .line 412
    const/4 v2, 0x0

    .line 414
    :try_start_2
    invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteLock(Ljava/lang/String;)V

    .line 415
    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 417
    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 418
    if-nez v2, :cond_16

    .line 438
    invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V

    .line 440
    :goto_15
    return-object v0

    .line 420
    :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 421
    invoke-static {p0}, Lorg/acdd/framework/Framework;->isAllowPluginLoad(Ljava/lang/String;)Z

    move-result v4

    .line 422
    if-eqz v3, :cond_2c

    if-eqz v4, :cond_2c

    .line 423
    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 438
    invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V

    goto :goto_15

    .line 425
    :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 428
    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 438
    invoke-static {p0}, Lorg/acdd/util/BundleLock;->WriteUnLock(Ljava/lang/String;)V

    goto :goto_15

    .line 430
    :catch_63
    move-exception v1

    .line 431
    :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 433
    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 435
    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 436
    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 438
    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 750
    const-string/jumbo 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_10

    .line 751
    new-instance v0, Ljava/lang/RuntimeException;

    invoke-direct {v0, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V

    throw v0

    .line 753
    :cond_10
    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 754
    return-void
.end method