BundleImpl.smali
.class public final Lorg/acdd/framework/BundleImpl;
.super Ljava/lang/Object;
.source "BundleImpl.java"
# interfaces
.implements Lorg/osgi/framework/Bundle;
# static fields
.field private static final log:Lorg/acdd/log/Logger;
# instance fields
.field archive:Lorg/acdd/framework/bundlestorage/Archive;
.field private final bundleDir:Ljava/io/File;
.field private classloader:Lorg/acdd/framework/BundleClassLoader;
.field currentStartlevel:I
.field private headers:Ljava/util/Hashtable;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Hashtable",
"<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field location:Ljava/lang/String;
.field persistently:Z
.field registeredBundleListeners:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Lorg/osgi/framework/BundleListener;",
">;"
}
.end annotation
.end field
.field registeredFrameworkListeners:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Lorg/osgi/framework/FrameworkListener;",
">;"
}
.end annotation
.end field
.field state:I
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 77
invoke-static {}, Lorg/acdd/log/LoggerFactory;->getInstance()Lorg/acdd/log/Logger;
move-result-object v0
sput-object v0, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
.line 78
return-void
.end method
.method constructor <init>(Ljava/io/File;)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
.prologue
const/4 v1, 0x0
.line 115
const/4 v0, 0x0
invoke-direct {p0, p1, v0, v1, v1}, Lorg/acdd/framework/BundleImpl;-><init>(Ljava/io/File;Ljava/lang/String;IZ)V
.line 116
return-void
.end method
.method constructor <init>(Ljava/io/File;Ljava/lang/String;IZ)V
.registers 16
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
.prologue
.line 118
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 68
new-instance v0, Ljava/util/Hashtable;
invoke-direct {v0}, Ljava/util/Hashtable;-><init>()V
iput-object v0, p0, Lorg/acdd/framework/BundleImpl;->headers:Ljava/util/Hashtable;
.line 73
const/4 v0, 0x0
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 119
const/4 v4, 0x0
.line 120
const/4 v1, 0x0
.line 122
:try_start_f
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
:try_end_12
.catch Ljava/lang/Exception; {:try_start_f .. :try_end_12} :catch_107
move-result-wide v6
.line 124
const/4 v2, 0x0
.line 126
:try_start_14
new-instance v0, Ljava/io/File;
const-string v3, "meta"
invoke-direct {v0, p1, v3}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 127
invoke-virtual {v0}, Ljava/io/File;->exists()Z
:try_end_1e
.catch Ljava/lang/Exception; {:try_start_14 .. :try_end_1e} :catch_9e
.catchall {:try_start_14 .. :try_end_1e} :catchall_bc
move-result v3
.line 129
:try_start_1f
new-instance v1, Ljava/io/DataInputStream;
new-instance v5, Ljava/io/FileInputStream;
invoke-direct {v5, v0}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
invoke-direct {v1, v5}, Ljava/io/DataInputStream;-><init>(Ljava/io/InputStream;)V
:try_end_29
.catch Ljava/lang/Exception; {:try_start_1f .. :try_end_29} :catch_117
.catchall {:try_start_1f .. :try_end_29} :catchall_10f
.line 130
:try_start_29
invoke-virtual {v1}, Ljava/io/DataInputStream;->readUTF()Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
.line 131
invoke-virtual {v1}, Ljava/io/DataInputStream;->readInt()I
move-result v0
iput v0, p0, Lorg/acdd/framework/BundleImpl;->currentStartlevel:I
.line 132
invoke-virtual {v1}, Ljava/io/DataInputStream;->readBoolean()Z
move-result v0
iput-boolean v0, p0, Lorg/acdd/framework/BundleImpl;->persistently:Z
:try_end_3b
.catch Ljava/lang/Exception; {:try_start_29 .. :try_end_3b} :catch_11b
.catchall {:try_start_29 .. :try_end_3b} :catchall_112
.line 142
if-eqz v1, :cond_122
.line 144
:try_start_3d
invoke-virtual {v1}, Ljava/io/DataInputStream;->close()V
:try_end_40
.catch Ljava/io/IOException; {:try_start_3d .. :try_end_40} :catch_9b
.catch Ljava/lang/Exception; {:try_start_3d .. :try_end_40} :catch_c5
move v1, v4
.line 150
:goto_41
:try_start_41
iput-object p1, p0, Lorg/acdd/framework/BundleImpl;->bundleDir:Ljava/io/File;
.line 151
const/4 v0, 0x2
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 153
new-instance v0, Lorg/acdd/framework/bundlestorage/BundleArchive;
iget-object v2, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
invoke-direct {v0, v2, p1}, Lorg/acdd/framework/bundlestorage/BundleArchive;-><init>(Ljava/lang/String;Ljava/io/File;)V
iput-object v0, p0, Lorg/acdd/framework/BundleImpl;->archive:Lorg/acdd/framework/bundlestorage/Archive;
.line 154
const-string v0, "bundle.apk"
const-string v2, "apk"
invoke-virtual {v0, v2}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_e9
invoke-static {p2}, Lorg/acdd/android/proxy/StubProxyManager;->isBundleManifestCached(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_e9
.line 160
:goto_5f
const/4 v0, 0x0
invoke-direct {p0, v0}, Lorg/acdd/framework/BundleImpl;->resolveBundle(Z)V
.line 161
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
invoke-static {v0, p0}, Lorg/acdd/framework/BundleManager;->putBundle(Ljava/lang/String;Lorg/osgi/framework/Bundle;)V
.line 162
const/4 v0, 0x1
invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
.line 163
sget-boolean v0, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z
if-eqz v0, :cond_9a
sget-object v0, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
invoke-interface {v0}, Lorg/acdd/log/Logger;->isWarnEnabled()Z
move-result v0
if-eqz v0, :cond_9a
.line 164
sget-object v0, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
const-string v2, "[PluginTimer] Framework: Bundle %s loaded %d ms"
const/4 v4, 0x2
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v8
aput-object v8, v4, v5
const/4 v5, 0x1
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v8
sub-long v6, v8, v6
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v6
aput-object v6, v4, v5
invoke-static {v2, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
invoke-interface {v0, v2}, Lorg/acdd/log/Logger;->warn(Ljava/lang/String;)V
:try_end_9a
.catch Ljava/lang/Exception; {:try_start_41 .. :try_end_9a} :catch_103
.line 172
:cond_9a
return-void
.line 145
:catch_9b
move-exception v0
move v1, v4
.line 146
goto :goto_41
.line 133
:catch_9e
move-exception v0
move-object v10, v2
move v2, v1
move-object v1, v10
.line 134
:goto_a2
:try_start_a2
sget-object v3, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
const-string v5, "load plugin meta failed!!!"
invoke-interface {v3, v5, v0}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 136
iput-object p2, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
.line 137
iput p3, p0, Lorg/acdd/framework/BundleImpl;->currentStartlevel:I
.line 138
iput-boolean p4, p0, Lorg/acdd/framework/BundleImpl;->persistently:Z
:try_end_af
.catchall {:try_start_a2 .. :try_end_af} :catchall_114
.line 140
const/4 v3, 0x1
.line 142
if-eqz v1, :cond_11e
.line 144
:try_start_b2
invoke-virtual {v1}, Ljava/io/DataInputStream;->close()V
:try_end_b5
.catch Ljava/io/IOException; {:try_start_b2 .. :try_end_b5} :catch_b8
.catch Ljava/lang/Exception; {:try_start_b2 .. :try_end_b5} :catch_10b
move v1, v3
move v3, v2
.line 146
goto :goto_41
.line 145
:catch_b8
move-exception v0
move v1, v3
move v3, v2
.line 146
goto :goto_41
.line 142
:catchall_bc
move-exception v0
move v3, v1
move-object v1, v2
:goto_bf
if-eqz v1, :cond_c4
.line 144
:try_start_c1
invoke-virtual {v1}, Ljava/io/DataInputStream;->close()V
:try_end_c4
.catch Ljava/io/IOException; {:try_start_c1 .. :try_end_c4} :catch_105
.catch Ljava/lang/Exception; {:try_start_c1 .. :try_end_c4} :catch_c5
.line 146
:cond_c4
:goto_c4
:try_start_c4
throw v0
:try_end_c5
.catch Ljava/lang/Exception; {:try_start_c4 .. :try_end_c5} :catch_c5
.line 166
:catch_c5
move-exception v0
move v1, v4
.line 167
:goto_c7
new-instance v2, Lorg/osgi/framework/BundleException;
const-string v4, "Could not load bundle %s, is use default config : %s, meta file exists : %s"
const/4 v5, 0x3
new-array v5, v5, [Ljava/lang/Object;
const/4 v6, 0x0
iget-object v7, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
aput-object v7, v5, v6
const/4 v6, 0x1
.line 169
invoke-static {v1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v1
aput-object v1, v5, v6
const/4 v1, 0x2
invoke-static {v3}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v3
aput-object v3, v5, v1
.line 167
invoke-static {v4, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-direct {v2, v1, v0}, Lorg/osgi/framework/BundleException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v2
.line 158
:cond_e9
:try_start_e9
const-string v0, "Plugin_Tag"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "BundleImpl [putBundleManifest] not start, because file not end with apk, location is "
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, p2}, 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-static {v0, v2}, Lcom/cm/plugincluster/common/proxy/CMLogUtilsProxy;->e(Ljava/lang/String;Ljava/lang/String;)V
:try_end_101
.catch Ljava/lang/Exception; {:try_start_e9 .. :try_end_101} :catch_103
goto/16 :goto_5f
.line 166
:catch_103
move-exception v0
goto :goto_c7
.line 145
:catch_105
move-exception v1
goto :goto_c4
.line 166
:catch_107
move-exception v0
move v3, v1
move v1, v4
goto :goto_c7
:catch_10b
move-exception v0
move v1, v3
move v3, v2
goto :goto_c7
.line 142
:catchall_10f
move-exception v0
move-object v1, v2
goto :goto_bf
:catchall_112
move-exception v0
goto :goto_bf
:catchall_114
move-exception v0
move v3, v2
goto :goto_bf
.line 133
:catch_117
move-exception v0
move-object v1, v2
move v2, v3
goto :goto_a2
:catch_11b
move-exception v0
move v2, v3
goto :goto_a2
:cond_11e
move v1, v3
move v3, v2
goto/16 :goto_41
:cond_122
move v1, v4
goto/16 :goto_41
.end method
.method constructor <init>(Ljava/io/File;Ljava/lang/String;Ljava/io/InputStream;Z)V
.registers 11
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
.prologue
const/4 v1, 0x0
const/4 v5, 0x0
.line 81
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 68
new-instance v0, Ljava/util/Hashtable;
invoke-direct {v0}, Ljava/util/Hashtable;-><init>()V
iput-object v0, p0, Lorg/acdd/framework/BundleImpl;->headers:Ljava/util/Hashtable;
.line 73
iput v5, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 82
iput-boolean v5, p0, Lorg/acdd/framework/BundleImpl;->persistently:Z
.line 84
iput-object v1, p0, Lorg/acdd/framework/BundleImpl;->registeredFrameworkListeners:Ljava/util/List;
.line 85
iput-object v1, p0, Lorg/acdd/framework/BundleImpl;->registeredBundleListeners:Ljava/util/List;
.line 86
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
.line 87
iput-object p2, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
.line 89
sget v2, Lorg/acdd/framework/Framework;->startlevel:I
iput v2, p0, Lorg/acdd/framework/BundleImpl;->currentStartlevel:I
.line 90
iput-object p1, p0, Lorg/acdd/framework/BundleImpl;->bundleDir:Ljava/io/File;
.line 91
if-eqz p3, :cond_29
.line 92
new-instance v2, Lorg/acdd/framework/bundlestorage/BundleArchive;
invoke-direct {v2, p2, p1, p3}, Lorg/acdd/framework/bundlestorage/BundleArchive;-><init>(Ljava/lang/String;Ljava/io/File;Ljava/io/InputStream;)V
iput-object v2, p0, Lorg/acdd/framework/BundleImpl;->archive:Lorg/acdd/framework/bundlestorage/Archive;
.line 94
:cond_29
const/4 v2, 0x2
iput v2, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 95
const-string v2, "bundle.apk"
const-string v3, "apk"
invoke-virtual {v2, v3}, Ljava/lang/String;->endsWith(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_8a
invoke-static {p2}, Lorg/acdd/android/proxy/StubProxyManager;->isBundleManifestCached(Ljava/lang/String;)Z
move-result v2
if-nez v2, :cond_8a
.line 101
:goto_3c
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->updateMetadata()V
.line 102
if-eqz p4, :cond_4b
.line 103
invoke-static {p2, p0}, Lorg/acdd/framework/BundleManager;->putBundle(Ljava/lang/String;Lorg/osgi/framework/Bundle;)V
.line 104
invoke-direct {p0, v5}, Lorg/acdd/framework/BundleImpl;->resolveBundle(Z)V
.line 105
const/4 v2, 0x1
invoke-static {v2, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
.line 108
:cond_4b
sget-boolean v2, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z
if-eqz v2, :cond_89
sget-object v2, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
invoke-interface {v2}, Lorg/acdd/log/Logger;->isWarnEnabled()Z
move-result v2
if-eqz v2, :cond_89
.line 109
sget-object v2, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "[PluginTimer] Framework: Bundle "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string v4, " created. "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
.line 110
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v4
sub-long v0, v4, v0
invoke-virtual {v3, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " ms"
invoke-virtual {v0, v1}, 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
.line 109
invoke-interface {v2, v0}, Lorg/acdd/log/Logger;->warn(Ljava/lang/String;)V
.line 112
:cond_89
return-void
.line 99
:cond_8a
const-string v2, "Plugin_Tag"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "BundleImpl [putBundleManifest] not start, because file not end with apk, location is "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, p2}, 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-static {v2, v3}, Lcom/cm/plugincluster/common/proxy/CMLogUtilsProxy;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_3c
.end method
.method private declared-synchronized resolveBundle(Z)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
const/4 v1, 0x4
.line 176
monitor-enter p0
:try_start_2
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
if-eq v0, v1, :cond_20
.line 177
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
if-nez v0, :cond_11
.line 178
new-instance v0, Lorg/acdd/framework/BundleClassLoader;
invoke-direct {v0, p0}, Lorg/acdd/framework/BundleClassLoader;-><init>(Lorg/acdd/framework/BundleImpl;)V
iput-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
.line 180
:cond_11
if-eqz p1, :cond_22
.line 181
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
const/4 v1, 0x1
invoke-virtual {v0, v1}, Lorg/acdd/framework/BundleClassLoader;->resolveBundle(Z)Z
.line 182
const/4 v0, 0x4
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 186
:cond_1c
:goto_1c
const/4 v0, 0x0
invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
:try_end_20
.catchall {:try_start_2 .. :try_end_20} :catchall_2f
.line 188
:cond_20
monitor-exit p0
return-void
.line 183
:cond_22
:try_start_22
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
const/4 v1, 0x0
invoke-virtual {v0, v1}, Lorg/acdd/framework/BundleClassLoader;->resolveBundle(Z)Z
move-result v0
if-eqz v0, :cond_1c
.line 184
const/4 v0, 0x4
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
:try_end_2e
.catchall {:try_start_22 .. :try_end_2e} :catchall_2f
goto :goto_1c
.line 176
:catchall_2f
move-exception v0
monitor-exit p0
throw v0
.end method
# virtual methods
.method public getArchive()Lorg/acdd/framework/bundlestorage/Archive;
.registers 2
.prologue
.line 207
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->archive:Lorg/acdd/framework/bundlestorage/Archive;
return-object v0
.end method
.method public getArchiveLastKey()Ljava/lang/String;
.registers 2
.prologue
.line 215
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->archive:Lorg/acdd/framework/bundlestorage/Archive;
check-cast v0, Lorg/acdd/framework/bundlestorage/BundleArchive;
invoke-virtual {v0}, Lorg/acdd/framework/bundlestorage/BundleArchive;->getRevisionLastKey()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getBundleDir()Ljava/lang/String;
.registers 2
.prologue
.line 211
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->bundleDir:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getBundleId()J
.registers 3
.prologue
.line 192
const-wide/16 v0, 0x0
return-wide v0
.end method
.method public getClassLoader()Ljava/lang/ClassLoader;
.registers 2
.prologue
.line 222
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
return-object v0
.end method
.method public getHeaders()Ljava/util/Dictionary;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Dictionary",
"<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.prologue
.line 197
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->headers:Ljava/util/Hashtable;
return-object v0
.end method
.method public getLocation()Ljava/lang/String;
.registers 2
.prologue
.line 202
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
return-object v0
.end method
.method public getResource(Ljava/lang/String;)Ljava/net/URL;
.registers 5
.prologue
.line 228
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
const/4 v1, 0x1
if-eq v0, v1, :cond_c
.line 229
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
invoke-virtual {v0, p1}, Lorg/acdd/framework/BundleClassLoader;->getResource(Ljava/lang/String;)Ljava/net/URL;
move-result-object v0
return-object v0
.line 231
:cond_c
new-instance v0, Ljava/lang/IllegalStateException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, " has been uninstalled"
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public getState()I
.registers 2
.prologue
.line 237
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
return v0
.end method
.method public hasPermission(Ljava/lang/Object;)Z
.registers 5
.prologue
const/4 v1, 0x1
.line 242
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
if-eq v0, v1, :cond_6
.line 243
return v1
.line 245
:cond_6
new-instance v0, Ljava/lang/IllegalStateException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, "has been unregistered."
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public declared-synchronized optDexFile()V
.registers 2
.prologue
.line 410
monitor-enter p0
:try_start_1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->getArchive()Lorg/acdd/framework/bundlestorage/Archive;
move-result-object v0
invoke-interface {v0}, Lorg/acdd/framework/bundlestorage/Archive;->optDexFile()V
:try_end_8
.catchall {:try_start_1 .. :try_end_8} :catchall_a
.line 411
monitor-exit p0
return-void
.line 410
:catchall_a
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized purge()V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
.line 415
monitor-enter p0
:try_start_1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->getArchive()Lorg/acdd/framework/bundlestorage/Archive;
move-result-object v0
invoke-interface {v0}, Lorg/acdd/framework/bundlestorage/Archive;->purge()V
:try_end_8
.catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_8} :catch_a
.catchall {:try_start_1 .. :try_end_8} :catchall_28
.line 419
monitor-exit p0
return-void
.line 416
:catch_a
move-exception v0
.line 417
:try_start_b
new-instance v1, Lorg/osgi/framework/BundleException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Could not purge bundle "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()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-direct {v1, v2, v0}, Lorg/osgi/framework/BundleException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
:try_end_28
.catchall {:try_start_b .. :try_end_28} :catchall_28
.line 415
:catchall_28
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized refresh()V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
const/4 v1, 0x0
const/4 v0, 0x1
.line 378
monitor-enter p0
:try_start_3
iget v2, p0, Lorg/acdd/framework/BundleImpl;->state:I
if-ne v2, v0, :cond_27
.line 379
new-instance v0, Ljava/lang/IllegalStateException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Cannot refresh uninstalled bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 380
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_24
.catchall {:try_start_3 .. :try_end_24} :catchall_24
.line 378
:catchall_24
move-exception v0
monitor-exit p0
throw v0
.line 383
:cond_27
:try_start_27
iget v2, p0, Lorg/acdd/framework/BundleImpl;->state:I
const/16 v3, 0x20
if-ne v2, v3, :cond_84
.line 384
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->stopBundle()V
:try_end_30
.catchall {:try_start_27 .. :try_end_30} :catchall_24
.line 388
:goto_30
:try_start_30
new-instance v1, Lorg/acdd/framework/bundlestorage/BundleArchive;
iget-object v2, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
iget-object v3, p0, Lorg/acdd/framework/BundleImpl;->bundleDir:Ljava/io/File;
invoke-direct {v1, v2, v3}, Lorg/acdd/framework/bundlestorage/BundleArchive;-><init>(Ljava/lang/String;Ljava/io/File;)V
iput-object v1, p0, Lorg/acdd/framework/BundleImpl;->archive:Lorg/acdd/framework/bundlestorage/Archive;
.line 389
new-instance v1, Lorg/acdd/framework/BundleClassLoader;
invoke-direct {v1, p0}, Lorg/acdd/framework/BundleClassLoader;-><init>(Lorg/acdd/framework/BundleImpl;)V
.line 391
iget-object v2, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
const/4 v3, 0x1
invoke-virtual {v2, v3}, Lorg/acdd/framework/BundleClassLoader;->cleanup(Z)V
.line 392
iput-object v1, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
.line 393
iget-object v1, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
const/4 v2, 0x0
invoke-virtual {v1, v2}, Lorg/acdd/framework/BundleClassLoader;->resolveBundle(Z)Z
move-result v1
if-eqz v1, :cond_60
.line 394
const/4 v1, 0x4
iput v1, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 398
:goto_54
const/16 v1, 0x8
invoke-static {v1, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
.line 399
if-eqz v0, :cond_5e
.line 400
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->startBundle()V
:try_end_5e
.catch Lorg/osgi/framework/BundleException; {:try_start_30 .. :try_end_5e} :catch_64
.catch Ljava/lang/Throwable; {:try_start_30 .. :try_end_5e} :catch_66
.catchall {:try_start_30 .. :try_end_5e} :catchall_24
.line 407
:cond_5e
monitor-exit p0
return-void
.line 396
:cond_60
const/4 v1, 0x2
:try_start_61
iput v1, p0, Lorg/acdd/framework/BundleImpl;->state:I
:try_end_63
.catch Lorg/osgi/framework/BundleException; {:try_start_61 .. :try_end_63} :catch_64
.catch Ljava/lang/Throwable; {:try_start_61 .. :try_end_63} :catch_66
.catchall {:try_start_61 .. :try_end_63} :catchall_24
goto :goto_54
.line 402
:catch_64
move-exception v0
.line 403
:try_start_65
throw v0
.line 404
:catch_66
move-exception v0
.line 405
new-instance v1, Lorg/osgi/framework/BundleException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Could not refresh bundle "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()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-direct {v1, v2, v0}, Lorg/osgi/framework/BundleException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
:try_end_84
.catchall {:try_start_65 .. :try_end_84} :catchall_24
:cond_84
move v0, v1
goto :goto_30
.end method
.method public declared-synchronized start()V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
.line 251
monitor-enter p0
const/4 v0, 0x1
:try_start_2
iput-boolean v0, p0, Lorg/acdd/framework/BundleImpl;->persistently:Z
.line 252
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->updateMetadata()V
.line 253
iget v0, p0, Lorg/acdd/framework/BundleImpl;->currentStartlevel:I
sget v1, Lorg/acdd/framework/Framework;->startlevel:I
if-gt v0, v1, :cond_10
.line 254
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->startBundle()V
:try_end_10
.catchall {:try_start_2 .. :try_end_10} :catchall_12
.line 256
:cond_10
monitor-exit p0
return-void
.line 251
:catchall_12
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized startBundle()V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
const/16 v3, 0x20
const/4 v2, 0x2
const/4 v1, 0x1
.line 259
monitor-enter p0
:try_start_5
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
if-ne v0, v1, :cond_29
.line 260
new-instance v0, Ljava/lang/IllegalStateException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Cannot start uninstalled bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 261
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_26
.catchall {:try_start_5 .. :try_end_26} :catchall_26
.line 259
:catchall_26
move-exception v0
monitor-exit p0
throw v0
.line 262
:cond_29
:try_start_29
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
if-eq v0, v3, :cond_6f
.line 263
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
if-ne v0, v2, :cond_35
.line 264
const/4 v0, 0x1
invoke-direct {p0, v0}, Lorg/acdd/framework/BundleImpl;->resolveBundle(Z)V
.line 266
:cond_35
const/16 v0, 0x8
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
:try_end_39
.catchall {:try_start_29 .. :try_end_39} :catchall_26
.line 269
const/16 v0, 0x20
:try_start_3b
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 270
const/4 v0, 0x2
invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
.line 271
sget-boolean v0, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z
if-eqz v0, :cond_6f
sget-object v0, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
invoke-interface {v0}, Lorg/acdd/log/Logger;->isInfoEnabled()Z
move-result v0
if-eqz v0, :cond_6f
.line 272
sget-object v0, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Framework: Bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, " started."
invoke-virtual {v1, v2}, 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-interface {v0, v1}, Lorg/acdd/log/Logger;->info(Ljava/lang/String;)V
:try_end_6f
.catch Ljava/lang/Throwable; {:try_start_3b .. :try_end_6f} :catch_71
.catchall {:try_start_3b .. :try_end_6f} :catchall_26
.line 282
:cond_6f
:goto_6f
monitor-exit p0
return-void
.line 274
:catch_71
move-exception v0
.line 276
:try_start_72
invoke-static {p0}, Lorg/acdd/framework/Framework;->clearBundleTrace(Lorg/acdd/framework/BundleImpl;)V
.line 277
const/4 v1, 0x4
iput v1, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 278
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Error starting bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, 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
.line 279
sget-object v2, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
invoke-interface {v2, v1, v0}, Lorg/acdd/log/Logger;->error(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_94
.catchall {:try_start_72 .. :try_end_94} :catchall_26
goto :goto_6f
.end method
.method public declared-synchronized stop()V
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
.line 286
monitor-enter p0
const/4 v0, 0x0
:try_start_2
iput-boolean v0, p0, Lorg/acdd/framework/BundleImpl;->persistently:Z
.line 287
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->updateMetadata()V
.line 288
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->stopBundle()V
:try_end_a
.catchall {:try_start_2 .. :try_end_a} :catchall_c
.line 289
monitor-exit p0
return-void
.line 286
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized stopBundle()V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
.line 292
monitor-enter p0
:try_start_1
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
const/4 v1, 0x1
if-ne v0, v1, :cond_26
.line 293
new-instance v0, Ljava/lang/IllegalStateException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Cannot stop uninstalled bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 294
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_23
.catchall {:try_start_1 .. :try_end_23} :catchall_23
.line 292
:catchall_23
move-exception v0
monitor-exit p0
throw v0
.line 295
:cond_26
:try_start_26
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
const/16 v1, 0x20
if-ne v0, v1, :cond_68
.line 296
const/16 v0, 0x10
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
:try_end_30
.catchall {:try_start_26 .. :try_end_30} :catchall_23
.line 298
:try_start_30
sget-boolean v0, Lorg/acdd/framework/Framework;->DEBUG_BUNDLES:Z
if-eqz v0, :cond_5e
sget-object v0, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
invoke-interface {v0}, Lorg/acdd/log/Logger;->isInfoEnabled()Z
move-result v0
if-eqz v0, :cond_5e
.line 299
sget-object v0, Lorg/acdd/framework/BundleImpl;->log:Lorg/acdd/log/Logger;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Framework: Bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, " stopped."
invoke-virtual {v1, v2}, 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-interface {v0, v1}, Lorg/acdd/log/Logger;->info(Ljava/lang/String;)V
.line 301
:cond_5e
invoke-static {p0}, Lorg/acdd/framework/Framework;->clearBundleTrace(Lorg/acdd/framework/BundleImpl;)V
.line 302
const/4 v0, 0x4
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 303
const/4 v0, 0x4
invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
:try_end_68
.catch Ljava/lang/Throwable; {:try_start_30 .. :try_end_68} :catch_6a
.catchall {:try_start_30 .. :try_end_68} :catchall_23
.line 313
:cond_68
:goto_68
monitor-exit p0
return-void
.line 305
:catch_6a
move-exception v0
.line 307
:try_start_6b
invoke-static {p0}, Lorg/acdd/framework/Framework;->clearBundleTrace(Lorg/acdd/framework/BundleImpl;)V
.line 308
const/4 v0, 0x4
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 309
const/4 v0, 0x4
invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
:try_end_75
.catchall {:try_start_6b .. :try_end_75} :catchall_23
goto :goto_68
.end method
.method public toString()Ljava/lang/String;
.registers 2
.prologue
.line 452
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
return-object v0
.end method
.method public declared-synchronized uninstall()V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
const/4 v1, 0x1
.line 317
monitor-enter p0
:try_start_2
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
if-ne v0, v1, :cond_2c
.line 318
new-instance v0, Ljava/lang/IllegalStateException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, " is already uninstalled."
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_29
.catchall {:try_start_2 .. :try_end_29} :catchall_29
.line 317
:catchall_29
move-exception v0
monitor-exit p0
throw v0
.line 320
:cond_2c
:try_start_2c
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
:try_end_2e
.catchall {:try_start_2c .. :try_end_2e} :catchall_29
const/16 v1, 0x20
if-ne v0, v1, :cond_35
.line 322
:try_start_32
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->stopBundle()V
:try_end_35
.catch Ljava/lang/Throwable; {:try_start_32 .. :try_end_35} :catch_59
.catchall {:try_start_32 .. :try_end_35} :catchall_29
.line 327
:cond_35
:goto_35
const/4 v0, 0x1
:try_start_36
iput v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
.line 328
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lorg/acdd/framework/BundleImpl;->bundleDir:Ljava/io/File;
const-string v2, "meta"
invoke-direct {v0, v1, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/io/File;->delete()Z
.line 329
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
const/4 v1, 0x1
invoke-virtual {v0, v1}, Lorg/acdd/framework/BundleClassLoader;->cleanup(Z)V
.line 330
const/4 v0, 0x0
iput-object v0, p0, Lorg/acdd/framework/BundleImpl;->classloader:Lorg/acdd/framework/BundleClassLoader;
.line 331
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
invoke-static {v0}, Lorg/acdd/framework/BundleManager;->removeBundle(Ljava/lang/String;)V
.line 332
const/16 v0, 0x10
invoke-static {v0, p0}, Lorg/acdd/framework/Framework;->notifyBundleListeners(ILorg/osgi/framework/Bundle;)V
:try_end_57
.catchall {:try_start_36 .. :try_end_57} :catchall_29
.line 334
monitor-exit p0
return-void
.line 323
:catch_59
move-exception v0
.line 324
const/4 v1, 0x2
:try_start_5b
invoke-static {v1, p0, v0}, Lorg/acdd/framework/Framework;->notifyFrameworkListeners(ILorg/osgi/framework/Bundle;Ljava/lang/Throwable;)V
:try_end_5e
.catchall {:try_start_5b .. :try_end_5e} :catchall_29
goto :goto_35
.end method
.method public declared-synchronized update(Ljava/io/InputStream;)Lorg/acdd/framework/bundlestorage/BundleArchiveRevision;
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Lorg/osgi/framework/BundleException;
}
.end annotation
.prologue
.line 353
monitor-enter p0
:try_start_1
iget v0, p0, Lorg/acdd/framework/BundleImpl;->state:I
const/4 v1, 0x1
if-ne v0, v1, :cond_26
.line 354
new-instance v0, Ljava/lang/IllegalStateException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Cannot update uninstalled bundle "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:try_end_23
.catchall {:try_start_1 .. :try_end_23} :catchall_23
.line 353
:catchall_23
move-exception v0
monitor-exit p0
throw v0
.line 357
:cond_26
:try_start_26
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->archive:Lorg/acdd/framework/bundlestorage/Archive;
iget-object v1, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
iget-object v2, p0, Lorg/acdd/framework/BundleImpl;->bundleDir:Ljava/io/File;
invoke-interface {v0, v1, v2, p1}, Lorg/acdd/framework/bundlestorage/Archive;->newRevision(Ljava/lang/String;Ljava/io/File;Ljava/io/InputStream;)Lorg/acdd/framework/bundlestorage/BundleArchiveRevision;
:try_end_2f
.catch Ljava/lang/Throwable; {:try_start_26 .. :try_end_2f} :catch_32
.catchall {:try_start_26 .. :try_end_2f} :catchall_23
move-result-object v0
monitor-exit p0
return-object v0
.line 358
:catch_32
move-exception v0
.line 359
:try_start_33
new-instance v1, Lorg/osgi/framework/BundleException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Could not update bundle "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {p0}, Lorg/acdd/framework/BundleImpl;->toString()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-direct {v1, v2, v0}, Lorg/osgi/framework/BundleException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
:try_end_50
.catchall {:try_start_33 .. :try_end_50} :catchall_23
.end method
.method updateMetadata()V
.registers 5
.prologue
.line 422
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lorg/acdd/framework/BundleImpl;->bundleDir:Ljava/io/File;
const-string v2, "meta"
invoke-direct {v0, v1, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 423
const/4 v1, 0x0
.line 425
:try_start_a
invoke-virtual {v0}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v2
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_1b
.line 426
invoke-virtual {v0}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v2
invoke-virtual {v2}, Ljava/io/File;->mkdirs()Z
.line 428
:cond_1b
new-instance v3, Ljava/io/FileOutputStream;
invoke-direct {v3, v0}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
.line 429
new-instance v2, Ljava/io/DataOutputStream;
invoke-direct {v2, v3}, Ljava/io/DataOutputStream;-><init>(Ljava/io/OutputStream;)V
:try_end_25
.catch Ljava/io/IOException; {:try_start_a .. :try_end_25} :catch_49
.catchall {:try_start_a .. :try_end_25} :catchall_58
.line 430
:try_start_25
iget-object v0, p0, Lorg/acdd/framework/BundleImpl;->location:Ljava/lang/String;
invoke-virtual {v2, v0}, Ljava/io/DataOutputStream;->writeUTF(Ljava/lang/String;)V
.line 431
iget v0, p0, Lorg/acdd/framework/BundleImpl;->currentStartlevel:I
invoke-virtual {v2, v0}, Ljava/io/DataOutputStream;->writeInt(I)V
.line 432
iget-boolean v0, p0, Lorg/acdd/framework/BundleImpl;->persistently:Z
invoke-virtual {v2, v0}, Ljava/io/DataOutputStream;->writeBoolean(Z)V
.line 433
invoke-virtual {v2}, Ljava/io/DataOutputStream;->flush()V
.line 434
invoke-virtual {v3}, Ljava/io/FileOutputStream;->getFD()Ljava/io/FileDescriptor;
move-result-object v0
invoke-virtual {v0}, Ljava/io/FileDescriptor;->sync()V
:try_end_3e
.catch Ljava/io/IOException; {:try_start_25 .. :try_end_3e} :catch_67
.catchall {:try_start_25 .. :try_end_3e} :catchall_64
.line 440
if-eqz v2, :cond_43
.line 442
:try_start_40
invoke-virtual {v2}, Ljava/io/DataOutputStream;->close()V
:try_end_43
.catch Ljava/io/IOException; {:try_start_40 .. :try_end_43} :catch_44
.line 448
:cond_43
:goto_43
return-void
.line 443
:catch_44
move-exception v0
.line 444
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_43
.line 435
:catch_49
move-exception v0
.line 436
:goto_4a
:try_start_4a
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
:try_end_4d
.catchall {:try_start_4a .. :try_end_4d} :catchall_58
.line 440
if-eqz v1, :cond_43
.line 442
:try_start_4f
invoke-virtual {v1}, Ljava/io/DataOutputStream;->close()V
:try_end_52
.catch Ljava/io/IOException; {:try_start_4f .. :try_end_52} :catch_53
goto :goto_43
.line 443
:catch_53
move-exception v0
.line 444
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_43
.line 440
:catchall_58
move-exception v0
:goto_59
if-eqz v1, :cond_5e
.line 442
:try_start_5b
invoke-virtual {v1}, Ljava/io/DataOutputStream;->close()V
:try_end_5e
.catch Ljava/io/IOException; {:try_start_5b .. :try_end_5e} :catch_5f
.line 445
:cond_5e
:goto_5e
throw v0
.line 443
:catch_5f
move-exception v1
.line 444
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
goto :goto_5e
.line 440
:catchall_64
move-exception v0
move-object v1, v2
goto :goto_59
.line 435
:catch_67
move-exception v0
move-object v1, v2
goto :goto_4a
.end method