c.smali

.class final Lcom/subgraph/orchid/circuits/b/c;
.super Ljava/lang/Object;
.source "Bridges.java"

# interfaces
.implements Ljava/lang/Runnable;


# instance fields
.field private final bDL:Lcom/subgraph/orchid/circuits/b/a;

.field private synthetic bDM:Lcom/subgraph/orchid/circuits/b/b;


# direct methods
.method constructor <init>(Lcom/subgraph/orchid/circuits/b/b;Lcom/subgraph/orchid/circuits/b/a;)V
    .registers 3

    .prologue
    .line 27
    iput-object p1, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

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

    .line 28
    iput-object p2, p0, Lcom/subgraph/orchid/circuits/b/c;->bDL:Lcom/subgraph/orchid/circuits/b/a;

    .line 29
    return-void
.end method

.method private Lo()V
    .registers 3

    .prologue
    .line 57
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->d(Lcom/subgraph/orchid/circuits/b/b;)Ljava/util/concurrent/atomic/AtomicInteger;

    move-result-object v0

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicInteger;->decrementAndGet()I

    move-result v0

    if-nez v0, :cond_2b

    .line 58
    # getter for: Lcom/subgraph/orchid/circuits/b/b;->logger:Ljava/util/logging/Logger;
    invoke-static {}, Lcom/subgraph/orchid/circuits/b/b;->access$000()Ljava/util/logging/Logger;

    move-result-object v0

    const-string v1, "Initial descriptor fetch complete"

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

    .line 59
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->b(Lcom/subgraph/orchid/circuits/b/b;)Ljava/lang/Object;

    move-result-object v1

    monitor-enter v1

    .line 60
    :try_start_1c
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->e(Lcom/subgraph/orchid/circuits/b/b;)Z

    .line 61
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->b(Lcom/subgraph/orchid/circuits/b/b;)Ljava/lang/Object;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/Object;->notifyAll()V

    .line 62
    monitor-exit v1

    .line 64
    :cond_2b
    return-void

    .line 62
    :catchall_2c
    move-exception v0

    monitor-exit v1
    :try_end_2e
    .catchall {:try_start_1c .. :try_end_2e} :catchall_2c

    throw v0
.end method


# virtual methods
.method public final run()V
    .registers 5

    .prologue
    .line 33
    .line 1040
    :try_start_0
    # getter for: Lcom/subgraph/orchid/circuits/b/b;->logger:Ljava/util/logging/Logger;
    invoke-static {}, Lcom/subgraph/orchid/circuits/b/b;->access$000()Ljava/util/logging/Logger;

    move-result-object v0

    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "Downloading descriptor for bridge: "

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

    iget-object v2, p0, Lcom/subgraph/orchid/circuits/b/c;->bDL:Lcom/subgraph/orchid/circuits/b/a;

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)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;->fine(Ljava/lang/String;)V
    :try_end_18
    .catchall {:try_start_0 .. :try_end_18} :catchall_87

    .line 1042
    :try_start_18
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->a(Lcom/subgraph/orchid/circuits/b/b;)Lcom/subgraph/orchid/l;

    move-result-object v0

    iget-object v1, p0, Lcom/subgraph/orchid/circuits/b/c;->bDL:Lcom/subgraph/orchid/circuits/b/a;

    invoke-interface {v0, v1}, Lcom/subgraph/orchid/l;->b(Lcom/subgraph/orchid/v;)Lcom/subgraph/orchid/w;

    move-result-object v0

    .line 1043
    if-eqz v0, :cond_64

    .line 1044
    # getter for: Lcom/subgraph/orchid/circuits/b/b;->logger:Ljava/util/logging/Logger;
    invoke-static {}, Lcom/subgraph/orchid/circuits/b/b;->access$000()Ljava/util/logging/Logger;

    move-result-object v1

    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "Descriptor received for bridge "

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

    iget-object v3, p0, Lcom/subgraph/orchid/circuits/b/c;->bDL:Lcom/subgraph/orchid/circuits/b/a;

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

    move-result-object v2

    const-string v3, ". Adding to list of usable bridges"

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

    move-result-object v2

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

    move-result-object v2

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

    .line 1045
    iget-object v1, p0, Lcom/subgraph/orchid/circuits/b/c;->bDL:Lcom/subgraph/orchid/circuits/b/a;

    .line 2041
    iput-object v0, v1, Lcom/subgraph/orchid/circuits/b/a;->bDE:Lcom/subgraph/orchid/Descriptor;

    .line 1046
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->b(Lcom/subgraph/orchid/circuits/b/b;)Ljava/lang/Object;

    move-result-object v1

    monitor-enter v1
    :try_end_4f
    .catch Lcom/subgraph/orchid/directory/downloader/DirectoryRequestFailedException; {:try_start_18 .. :try_end_4f} :catch_6b
    .catchall {:try_start_18 .. :try_end_4f} :catchall_87

    .line 1047
    :try_start_4f
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->c(Lcom/subgraph/orchid/circuits/b/b;)Ljava/util/Set;

    move-result-object v0

    iget-object v2, p0, Lcom/subgraph/orchid/circuits/b/c;->bDL:Lcom/subgraph/orchid/circuits/b/a;

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

    .line 1048
    iget-object v0, p0, Lcom/subgraph/orchid/circuits/b/c;->bDM:Lcom/subgraph/orchid/circuits/b/b;

    invoke-static {v0}, Lcom/subgraph/orchid/circuits/b/b;->b(Lcom/subgraph/orchid/circuits/b/b;)Ljava/lang/Object;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/Object;->notifyAll()V

    .line 1049
    monitor-exit v1
    :try_end_64
    .catchall {:try_start_4f .. :try_end_64} :catchall_68

    .line 35
    :cond_64
    :goto_64
    invoke-direct {p0}, Lcom/subgraph/orchid/circuits/b/c;->Lo()V

    .line 36
    return-void

    .line 1049
    :catchall_68
    move-exception v0

    :try_start_69
    monitor-exit v1
    :try_end_6a
    .catchall {:try_start_69 .. :try_end_6a} :catchall_68

    :try_start_6a
    throw v0
    :try_end_6b
    .catch Lcom/subgraph/orchid/directory/downloader/DirectoryRequestFailedException; {:try_start_6a .. :try_end_6b} :catch_6b
    .catchall {:try_start_6a .. :try_end_6b} :catchall_87

    .line 1051
    :catch_6b
    move-exception v0

    .line 1052
    :try_start_6c
    # getter for: Lcom/subgraph/orchid/circuits/b/b;->logger:Ljava/util/logging/Logger;
    invoke-static {}, Lcom/subgraph/orchid/circuits/b/b;->access$000()Ljava/util/logging/Logger;

    move-result-object v1

    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "Failed to download descriptor for bridge: "

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

    invoke-virtual {v0}, Lcom/subgraph/orchid/directory/downloader/DirectoryRequestFailedException;->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_86
    .catchall {:try_start_6c .. :try_end_86} :catchall_87

    goto :goto_64

    .line 35
    :catchall_87
    move-exception v0

    invoke-direct {p0}, Lcom/subgraph/orchid/circuits/b/c;->Lo()V

    throw v0
.end method