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