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