a.smali

.class public abstract Lcom/subgraph/orchid/directory/a;
.super Ljava/lang/Object;
.source "DescriptorCache.java"


# annotations
.annotation system Ldalvik/annotation/Signature;
    value = {
        "<T::",
        "Lcom/subgraph/orchid/Descriptor;",
        ">",
        "Ljava/lang/Object;"
    }
.end annotation


# static fields
.field private static final logger:Ljava/util/logging/Logger;


# instance fields
.field private final bGZ:Lcom/subgraph/orchid/directory/b;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Lcom/subgraph/orchid/directory/b",
            "<TT;>;"
        }
    .end annotation
.end field

.field private final bHa:Lcom/subgraph/orchid/DirectoryStore;

.field private final bHb:Ljava/util/concurrent/ScheduledExecutorService;

.field private final bHc:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

.field private final bHd:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

.field private bHe:I

.field private bHf:I

.field private bHg:I

.field private bHh:Z


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .prologue
    .line 21
    const-class v0, Lcom/subgraph/orchid/directory/a;

    invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;

    move-result-object v0

    invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;

    move-result-object v0

    sput-object v0, Lcom/subgraph/orchid/directory/a;->logger:Ljava/util/logging/Logger;

    return-void
.end method

.method constructor <init>(Lcom/subgraph/orchid/DirectoryStore;Lcom/subgraph/orchid/DirectoryStore$CacheFile;Lcom/subgraph/orchid/DirectoryStore$CacheFile;)V
    .registers 11

    .prologue
    .line 44
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 26
    const-string v0, "DescriptorCache rebuild worker"

    .line 27
    invoke-static {v0}, Lcom/subgraph/orchid/ab;->gt(Ljava/lang/String;)Ljava/util/concurrent/ScheduledExecutorService;

    move-result-object v0

    iput-object v0, p0, Lcom/subgraph/orchid/directory/a;->bHb:Ljava/util/concurrent/ScheduledExecutorService;

    .line 45
    new-instance v0, Lcom/subgraph/orchid/directory/b;

    invoke-direct {v0}, Lcom/subgraph/orchid/directory/b;-><init>()V

    iput-object v0, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    .line 46
    iput-object p1, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    .line 47
    iput-object p2, p0, Lcom/subgraph/orchid/directory/a;->bHc:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

    .line 48
    iput-object p3, p0, Lcom/subgraph/orchid/directory/a;->bHd:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

    .line 1166
    iget-object v0, p0, Lcom/subgraph/orchid/directory/a;->bHb:Ljava/util/concurrent/ScheduledExecutorService;

    new-instance v1, Lcom/subgraph/orchid/directory/a$1;

    invoke-direct {v1, p0}, Lcom/subgraph/orchid/directory/a$1;-><init>(Lcom/subgraph/orchid/directory/a;)V

    const-wide/16 v2, 0x5

    const-wide/16 v4, 0x1e

    sget-object v6, Ljava/util/concurrent/TimeUnit;->MINUTES:Ljava/util/concurrent/TimeUnit;

    invoke-interface/range {v0 .. v6}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;

    .line 50
    return-void
.end method

.method private declared-synchronized Mu()V
    .registers 2

    .prologue
    .line 96
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    invoke-virtual {v0}, Lcom/subgraph/orchid/directory/b;->clear()V

    .line 97
    const/4 v0, 0x0

    iput v0, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    .line 98
    const/4 v0, 0x0

    iput v0, p0, Lcom/subgraph/orchid/directory/a;->bHg:I

    .line 99
    const/4 v0, 0x0

    iput v0, p0, Lcom/subgraph/orchid/directory/a;->bHe:I
    :try_end_f
    .catchall {:try_start_1 .. :try_end_f} :catchall_11

    .line 100
    monitor-exit p0

    return-void

    .line 96
    :catchall_11
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method private declared-synchronized Mv()V
    .registers 6

    .prologue
    const/4 v1, 0x0

    .line 103
    monitor-enter p0

    :try_start_2
    invoke-direct {p0}, Lcom/subgraph/orchid/directory/a;->Mu()V

    .line 104
    invoke-direct {p0}, Lcom/subgraph/orchid/directory/a;->Mw()[Ljava/nio/ByteBuffer;

    move-result-object v2

    .line 105
    const/4 v0, 0x0

    aget-object v0, v2, v0

    .line 2122
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->limit()I

    move-result v3

    iput v3, p0, Lcom/subgraph/orchid/directory/a;->bHg:I

    .line 2123
    iget v3, p0, Lcom/subgraph/orchid/directory/a;->bHg:I

    if-eqz v3, :cond_46

    .line 2126
    invoke-virtual {p0, v0}, Lcom/subgraph/orchid/directory/a;->e(Ljava/nio/ByteBuffer;)Lcom/subgraph/orchid/directory/a/d;

    move-result-object v0

    .line 2127
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/d;->Lr()Lcom/subgraph/orchid/directory/a/g;

    move-result-object v0

    .line 2128
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->NR()Z

    move-result v3

    if-eqz v3, :cond_46

    .line 2129
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->NQ()Ljava/util/List;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v3

    :goto_2c
    invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_46

    invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/subgraph/orchid/Descriptor;

    .line 2130
    sget-object v4, Lcom/subgraph/orchid/Descriptor$CacheLocation;->CACHED_CACHEFILE:Lcom/subgraph/orchid/Descriptor$CacheLocation;

    invoke-interface {v0, v4}, Lcom/subgraph/orchid/Descriptor;->a(Lcom/subgraph/orchid/Descriptor$CacheLocation;)V

    .line 2131
    iget-object v4, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    invoke-virtual {v4, v0}, Lcom/subgraph/orchid/directory/b;->a(Lcom/subgraph/orchid/Descriptor;)Z
    :try_end_42
    .catchall {:try_start_2 .. :try_end_42} :catchall_43

    goto :goto_2c

    .line 103
    :catchall_43
    move-exception v0

    monitor-exit p0

    throw v0

    .line 106
    :cond_46
    const/4 v0, 0x1

    :try_start_47
    aget-object v0, v2, v0

    .line 2138
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->limit()I

    move-result v2

    iput v2, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    .line 2139
    iget v2, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    if-eqz v2, :cond_c4

    .line 2142
    invoke-virtual {p0, v0}, Lcom/subgraph/orchid/directory/a;->e(Ljava/nio/ByteBuffer;)Lcom/subgraph/orchid/directory/a/d;

    move-result-object v0

    .line 2143
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/d;->Lr()Lcom/subgraph/orchid/directory/a/g;

    move-result-object v0

    .line 2144
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->NR()Z

    move-result v2

    if-eqz v2, :cond_cd

    .line 2146
    sget-object v2, Lcom/subgraph/orchid/directory/a;->logger:Ljava/util/logging/Logger;

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "Loaded "

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

    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->NQ()Ljava/util/List;

    move-result-object v4

    invoke-interface {v4}, Ljava/util/List;->size()I

    move-result v4

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

    move-result-object v3

    const-string v4, " descriptors from journal"

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

    move-result-object v3

    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v2, v3}, Ljava/util/logging/Logger;->fine(Ljava/lang/String;)V

    .line 2147
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->NQ()Ljava/util/List;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v2

    :goto_8b
    invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_a8

    invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/subgraph/orchid/Descriptor;

    .line 2148
    sget-object v3, Lcom/subgraph/orchid/Descriptor$CacheLocation;->CACHED_JOURNAL:Lcom/subgraph/orchid/Descriptor$CacheLocation;

    invoke-interface {v0, v3}, Lcom/subgraph/orchid/Descriptor;->a(Lcom/subgraph/orchid/Descriptor$CacheLocation;)V

    .line 2149
    iget-object v3, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    invoke-virtual {v3, v0}, Lcom/subgraph/orchid/directory/b;->a(Lcom/subgraph/orchid/Descriptor;)Z

    move-result v0

    if-nez v0, :cond_10b

    .line 2150
    add-int/lit8 v0, v1, 0x1

    :goto_a6
    move v1, v0

    .line 2152
    goto :goto_8b

    .line 2153
    :cond_a8
    if-lez v1, :cond_c4

    .line 2154
    sget-object v0, Lcom/subgraph/orchid/directory/a;->logger:Ljava/util/logging/Logger;

    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "Found "

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

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

    move-result-object v1

    const-string v2, " duplicate descriptors in journal file"

    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-virtual {v0, v1}, Ljava/util/logging/Logger;->info(Ljava/lang/String;)V

    .line 107
    :cond_c4
    :goto_c4
    iget-boolean v0, p0, Lcom/subgraph/orchid/directory/a;->bHh:Z

    if-nez v0, :cond_cb

    .line 108
    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/subgraph/orchid/directory/a;->bHh:Z
    :try_end_cb
    .catchall {:try_start_47 .. :try_end_cb} :catchall_43

    .line 110
    :cond_cb
    monitor-exit p0

    return-void

    .line 2156
    :cond_cd
    :try_start_cd
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->isInvalid()Z

    move-result v1

    if-eqz v1, :cond_ec

    .line 2157
    sget-object v1, Lcom/subgraph/orchid/directory/a;->logger:Ljava/util/logging/Logger;

    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "Invalid descriptor data parsing from journal file : "

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

    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->getMessage()Ljava/lang/String;

    move-result-object v0

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

    move-result-object v0

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

    move-result-object v0

    invoke-virtual {v1, v0}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V

    goto :goto_c4

    .line 2158
    :cond_ec
    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->isError()Z

    move-result v1

    if-eqz v1, :cond_c4

    .line 2159
    sget-object v1, Lcom/subgraph/orchid/directory/a;->logger:Ljava/util/logging/Logger;

    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "Error parsing descriptors from journal file : "

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

    invoke-interface {v0}, Lcom/subgraph/orchid/directory/a/g;->getMessage()Ljava/lang/String;

    move-result-object v0

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

    move-result-object v0

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

    move-result-object v0

    invoke-virtual {v1, v0}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V
    :try_end_10a
    .catchall {:try_start_cd .. :try_end_10a} :catchall_43

    goto :goto_c4

    :cond_10b
    move v0, v1

    goto :goto_a6
.end method

.method private Mw()[Ljava/nio/ByteBuffer;
    .registers 6

    .prologue
    .line 113
    iget-object v1, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    monitor-enter v1

    .line 114
    const/4 v0, 0x2

    :try_start_4
    new-array v0, v0, [Ljava/nio/ByteBuffer;

    .line 115
    const/4 v2, 0x0

    iget-object v3, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    iget-object v4, p0, Lcom/subgraph/orchid/directory/a;->bHc:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

    invoke-interface {v3, v4}, Lcom/subgraph/orchid/DirectoryStore;->a(Lcom/subgraph/orchid/DirectoryStore$CacheFile;)Ljava/nio/ByteBuffer;

    move-result-object v3

    aput-object v3, v0, v2

    .line 116
    const/4 v2, 0x1

    iget-object v3, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    iget-object v4, p0, Lcom/subgraph/orchid/directory/a;->bHd:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

    invoke-interface {v3, v4}, Lcom/subgraph/orchid/DirectoryStore;->a(Lcom/subgraph/orchid/DirectoryStore$CacheFile;)Ljava/nio/ByteBuffer;

    move-result-object v3

    aput-object v3, v0, v2

    .line 117
    monitor-exit v1

    return-object v0

    .line 118
    :catchall_1e
    move-exception v0

    monitor-exit v1
    :try_end_20
    .catchall {:try_start_4 .. :try_end_20} :catchall_1e

    throw v0
.end method

.method private declared-synchronized Mx()V
    .registers 5

    .prologue
    const/4 v0, 0x1

    .line 174
    monitor-enter p0

    :try_start_2
    iget-boolean v1, p0, Lcom/subgraph/orchid/directory/a;->bHh:Z
    :try_end_4
    .catchall {:try_start_2 .. :try_end_4} :catchall_42

    if-nez v1, :cond_8

    .line 184
    :cond_6
    :goto_6
    monitor-exit p0

    return-void

    .line 178
    :cond_8
    :try_start_8
    iget v1, p0, Lcom/subgraph/orchid/directory/a;->bHe:I

    iget-object v2, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    invoke-virtual {v2}, Lcom/subgraph/orchid/directory/b;->Mz()I

    move-result v2

    add-int/2addr v1, v2

    iput v1, p0, Lcom/subgraph/orchid/directory/a;->bHe:I

    .line 2187
    iget v1, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    const/16 v2, 0x4000

    if-lt v1, v2, :cond_4d

    .line 2190
    iget v1, p0, Lcom/subgraph/orchid/directory/a;->bHe:I

    iget v2, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    iget v3, p0, Lcom/subgraph/orchid/directory/a;->bHg:I

    add-int/2addr v2, v3

    div-int/lit8 v2, v2, 0x3

    if-le v1, v2, :cond_45

    .line 180
    :cond_24
    :goto_24
    if-eqz v0, :cond_6

    .line 2200
    iget-object v1, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    monitor-enter v1
    :try_end_29
    .catchall {:try_start_8 .. :try_end_29} :catchall_42

    .line 2201
    :try_start_29
    iget-object v0, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    iget-object v2, p0, Lcom/subgraph/orchid/directory/a;->bHc:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

    iget-object v3, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    invoke-virtual {v3}, Lcom/subgraph/orchid/directory/b;->My()Ljava/util/List;

    move-result-object v3

    invoke-interface {v0, v2, v3}, Lcom/subgraph/orchid/DirectoryStore;->a(Lcom/subgraph/orchid/DirectoryStore$CacheFile;Ljava/util/List;)V

    .line 2202
    iget-object v0, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    iget-object v2, p0, Lcom/subgraph/orchid/directory/a;->bHd:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

    invoke-interface {v0, v2}, Lcom/subgraph/orchid/DirectoryStore;->b(Lcom/subgraph/orchid/DirectoryStore$CacheFile;)V

    .line 2203
    monitor-exit v1
    :try_end_3e
    .catchall {:try_start_29 .. :try_end_3e} :catchall_4f

    .line 2204
    :try_start_3e
    invoke-direct {p0}, Lcom/subgraph/orchid/directory/a;->Mv()V
    :try_end_41
    .catchall {:try_start_3e .. :try_end_41} :catchall_42

    goto :goto_6

    .line 174
    :catchall_42
    move-exception v0

    monitor-exit p0

    throw v0

    .line 2193
    :cond_45
    :try_start_45
    iget v1, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    iget v2, p0, Lcom/subgraph/orchid/directory/a;->bHg:I

    div-int/lit8 v2, v2, 0x2
    :try_end_4b
    .catchall {:try_start_45 .. :try_end_4b} :catchall_42

    if-gt v1, v2, :cond_24

    .line 2196
    :cond_4d
    const/4 v0, 0x0

    goto :goto_24

    .line 2203
    :catchall_4f
    move-exception v0

    :try_start_50
    monitor-exit v1
    :try_end_51
    .catchall {:try_start_50 .. :try_end_51} :catchall_4f

    :try_start_51
    throw v0
    :try_end_52
    .catchall {:try_start_51 .. :try_end_52} :catchall_42
.end method

.method static synthetic a(Lcom/subgraph/orchid/directory/a;)V
    .registers 1

    .prologue
    .line 20
    invoke-direct {p0}, Lcom/subgraph/orchid/directory/a;->Mx()V

    return-void
.end method


# virtual methods
.method public final declared-synchronized Mt()V
    .registers 2

    .prologue
    .line 53
    monitor-enter p0

    :try_start_1
    iget-boolean v0, p0, Lcom/subgraph/orchid/directory/a;->bHh:Z
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_b

    if-eqz v0, :cond_7

    .line 57
    :goto_5
    monitor-exit p0

    return-void

    .line 56
    :cond_7
    :try_start_7
    invoke-direct {p0}, Lcom/subgraph/orchid/directory/a;->Mv()V
    :try_end_a
    .catchall {:try_start_7 .. :try_end_a} :catchall_b

    goto :goto_5

    .line 53
    :catchall_b
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public final declared-synchronized ak(Ljava/util/List;)V
    .registers 8
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/List",
            "<TT;>;)V"
        }
    .end annotation

    .prologue
    .line 68
    monitor-enter p0

    :try_start_1
    new-instance v2, Ljava/util/ArrayList;

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

    .line 69
    const/4 v1, 0x0

    .line 70
    invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v3

    :goto_b
    invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_3b

    invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/subgraph/orchid/Descriptor;

    .line 71
    iget-object v4, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    invoke-virtual {v4, v0}, Lcom/subgraph/orchid/directory/b;->a(Lcom/subgraph/orchid/Descriptor;)Z

    move-result v4

    if-eqz v4, :cond_37

    .line 72
    invoke-interface {v0}, Lcom/subgraph/orchid/Descriptor;->IU()Lcom/subgraph/orchid/Descriptor$CacheLocation;

    move-result-object v4

    sget-object v5, Lcom/subgraph/orchid/Descriptor$CacheLocation;->NOT_CACHED:Lcom/subgraph/orchid/Descriptor$CacheLocation;

    if-ne v4, v5, :cond_60

    .line 73
    iget v4, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    invoke-interface {v0}, Lcom/subgraph/orchid/Descriptor;->getBodyLength()I

    move-result v5

    add-int/2addr v4, v5

    iput v4, p0, Lcom/subgraph/orchid/directory/a;->bHf:I

    .line 74
    invoke-interface {v2, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
    :try_end_33
    .catchall {:try_start_1 .. :try_end_33} :catchall_34

    goto :goto_b

    .line 68
    :catchall_34
    move-exception v0

    monitor-exit p0

    throw v0

    .line 77
    :cond_37
    add-int/lit8 v0, v1, 0x1

    :goto_39
    move v1, v0

    .line 79
    goto :goto_b

    .line 81
    :cond_3b
    :try_start_3b
    invoke-interface {v2}, Ljava/util/List;->isEmpty()Z

    move-result v0

    if-nez v0, :cond_48

    .line 82
    iget-object v0, p0, Lcom/subgraph/orchid/directory/a;->bHa:Lcom/subgraph/orchid/DirectoryStore;

    iget-object v3, p0, Lcom/subgraph/orchid/directory/a;->bHd:Lcom/subgraph/orchid/DirectoryStore$CacheFile;

    invoke-interface {v0, v3, v2}, Lcom/subgraph/orchid/DirectoryStore;->b(Lcom/subgraph/orchid/DirectoryStore$CacheFile;Ljava/util/List;)V

    .line 84
    :cond_48
    if-lez v1, :cond_5e

    .line 85
    sget-object v0, Lcom/subgraph/orchid/directory/a;->logger:Ljava/util/logging/Logger;

    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "Duplicate descriptors added to journal, count = "

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

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

    move-result-object v1

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

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->info(Ljava/lang/String;)V
    :try_end_5e
    .catchall {:try_start_3b .. :try_end_5e} :catchall_34

    .line 87
    :cond_5e
    monitor-exit p0

    return-void

    :cond_60
    move v0, v1

    goto :goto_39
.end method

.method protected abstract e(Ljava/nio/ByteBuffer;)Lcom/subgraph/orchid/directory/a/d;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/nio/ByteBuffer;",
            ")",
            "Lcom/subgraph/orchid/directory/a/d",
            "<TT;>;"
        }
    .end annotation
.end method

.method public final f(Lcom/subgraph/orchid/d/c;)Lcom/subgraph/orchid/Descriptor;
    .registers 3
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Lcom/subgraph/orchid/d/c;",
            ")TT;"
        }
    .end annotation

    .prologue
    .line 64
    iget-object v0, p0, Lcom/subgraph/orchid/directory/a;->bGZ:Lcom/subgraph/orchid/directory/b;

    invoke-virtual {v0, p1}, Lcom/subgraph/orchid/directory/b;->g(Lcom/subgraph/orchid/d/c;)Lcom/subgraph/orchid/Descriptor;

    move-result-object v0

    return-object v0
.end method

.method public final shutdown()V
    .registers 2

    .prologue
    .line 60
    iget-object v0, p0, Lcom/subgraph/orchid/directory/a;->bHb:Ljava/util/concurrent/ScheduledExecutorService;

    invoke-interface {v0}, Ljava/util/concurrent/ScheduledExecutorService;->shutdownNow()Ljava/util/List;

    .line 61
    return-void
.end method