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