s.smali
.class public Lcom/subgraph/orchid/circuits/s;
.super Ljava/lang/Object;
.source "StreamImpl.java"
# interfaces
.implements Lcom/subgraph/orchid/aa;
.implements Lcom/subgraph/orchid/c/c;
# static fields
.field private static final logger:Ljava/util/logging/Logger;
# instance fields
.field final bBF:Lcom/subgraph/orchid/circuits/f;
.field bCA:I
.field bCb:Z
.field final bCy:Ljava/lang/Object;
.field bCz:I
.field private final bDc:Z
.field final bDd:Lcom/subgraph/orchid/f;
.field final bDe:Lcom/subgraph/orchid/circuits/v;
.field private final bDf:Lcom/subgraph/orchid/circuits/w;
.field bDg:Z
.field bDh:I
.field bDi:Z
.field final bDj:Ljava/lang/Object;
.field private bDk:Ljava/lang/String;
.field final bzk:I
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 21
const-class v0, Lcom/subgraph/orchid/circuits/s;
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/circuits/s;->logger:Ljava/util/logging/Logger;
return-void
.end method
.method constructor <init>(Lcom/subgraph/orchid/circuits/f;Lcom/subgraph/orchid/f;IZ)V
.registers 7
.prologue
const/16 v1, 0x1f4
.line 47
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 40
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDj:Ljava/lang/Object;
.line 41
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bCy:Ljava/lang/Object;
.line 45
const-string v0, ""
iput-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDk:Ljava/lang/String;
.line 48
iput-object p1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
.line 49
iput-object p2, p0, Lcom/subgraph/orchid/circuits/s;->bDd:Lcom/subgraph/orchid/f;
.line 50
iput p3, p0, Lcom/subgraph/orchid/circuits/s;->bzk:I
.line 51
iput-boolean p4, p0, Lcom/subgraph/orchid/circuits/s;->bDc:Z
.line 52
new-instance v0, Lcom/subgraph/orchid/circuits/v;
invoke-direct {v0, p0}, Lcom/subgraph/orchid/circuits/v;-><init>(Lcom/subgraph/orchid/aa;)V
iput-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDe:Lcom/subgraph/orchid/circuits/v;
.line 53
new-instance v0, Lcom/subgraph/orchid/circuits/w;
invoke-direct {v0, p0}, Lcom/subgraph/orchid/circuits/w;-><init>(Lcom/subgraph/orchid/circuits/s;)V
iput-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDf:Lcom/subgraph/orchid/circuits/w;
.line 54
iput v1, p0, Lcom/subgraph/orchid/circuits/s;->bCz:I
.line 55
iput v1, p0, Lcom/subgraph/orchid/circuits/s;->bCA:I
.line 56
return-void
.end method
.method private N(J)V
.registers 10
.prologue
.line 153
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
.line 154
const-wide/16 v0, 0x0
.line 155
iget-object v4, p0, Lcom/subgraph/orchid/circuits/s;->bDj:Ljava/lang/Object;
monitor-enter v4
.line 156
:goto_9
:try_start_9
iget-boolean v5, p0, Lcom/subgraph/orchid/circuits/s;->bDi:Z
if-nez v5, :cond_33
.line 158
iget-boolean v5, p0, Lcom/subgraph/orchid/circuits/s;->bDg:Z
if-eqz v5, :cond_1c
.line 159
new-instance v0, Lcom/subgraph/orchid/StreamConnectFailedException;
iget v1, p0, Lcom/subgraph/orchid/circuits/s;->bDh:I
invoke-direct {v0, v1}, Lcom/subgraph/orchid/StreamConnectFailedException;-><init>(I)V
throw v0
.line 170
:catchall_19
move-exception v0
monitor-exit v4
:try_end_1b
.catchall {:try_start_9 .. :try_end_1b} :catchall_19
throw v0
.line 162
:cond_1c
cmp-long v5, v0, p1
if-ltz v5, :cond_26
.line 163
:try_start_20
new-instance v0, Ljava/util/concurrent/TimeoutException;
invoke-direct {v0}, Ljava/util/concurrent/TimeoutException;-><init>()V
throw v0
.line 166
:cond_26
iget-object v5, p0, Lcom/subgraph/orchid/circuits/s;->bDj:Ljava/lang/Object;
sub-long v0, p1, v0
invoke-virtual {v5, v0, v1}, Ljava/lang/Object;->wait(J)V
.line 168
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
sub-long/2addr v0, v2
goto :goto_9
.line 170
:cond_33
monitor-exit v4
:try_end_34
.catchall {:try_start_20 .. :try_end_34} :catchall_19
return-void
.end method
# virtual methods
.method public final IB()V
.registers 2
.prologue
.line 186
const/4 v0, 0x0
invoke-virtual {p0, v0}, Lcom/subgraph/orchid/circuits/s;->bg(Z)V
.line 187
return-void
.end method
.method public final JV()Lcom/subgraph/orchid/c;
.registers 2
.prologue
.line 109
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
return-object v0
.end method
.method public final JW()Lcom/subgraph/orchid/f;
.registers 2
.prologue
.line 113
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDd:Lcom/subgraph/orchid/f;
return-object v0
.end method
.method public final Lg()V
.registers 6
.prologue
.line 138
const-string v0, "[Directory]"
iput-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDk:Ljava/lang/String;
.line 139
new-instance v0, Lcom/subgraph/orchid/circuits/a/b;
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v1}, Lcom/subgraph/orchid/circuits/f;->It()Lcom/subgraph/orchid/f;
move-result-object v1
iget-object v2, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v2}, Lcom/subgraph/orchid/circuits/f;->Ii()I
move-result v2
iget v3, p0, Lcom/subgraph/orchid/circuits/s;->bzk:I
const/16 v4, 0xd
invoke-direct {v0, v1, v2, v3, v4}, Lcom/subgraph/orchid/circuits/a/b;-><init>(Lcom/subgraph/orchid/f;III)V
.line 140
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v1, v0}, Lcom/subgraph/orchid/circuits/f;->e(Lcom/subgraph/orchid/t;)V
.line 141
const-wide/16 v0, 0x2710
invoke-direct {p0, v0, v1}, Lcom/subgraph/orchid/circuits/s;->N(J)V
.line 142
return-void
.end method
.method public final a(Lcom/subgraph/orchid/c/d;Ljava/io/PrintWriter;I)V
.registers 8
.prologue
.line 209
const-string v0, " "
invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->print(Ljava/lang/String;)V
.line 210
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "[Stream stream_id="
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v1, p0, Lcom/subgraph/orchid/circuits/s;->bzk:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " cid="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v1}, Lcom/subgraph/orchid/circuits/f;->Ii()I
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->print(Ljava/lang/String;)V
.line 211
iget-boolean v0, p0, Lcom/subgraph/orchid/circuits/s;->bDi:Z
if-eqz v0, :cond_6d
.line 212
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, " sent="
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bDf:Lcom/subgraph/orchid/circuits/w;
.line 1033
iget-wide v2, v1, Lcom/subgraph/orchid/circuits/w;->bDx:J
.line 212
invoke-virtual {v0, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " recv="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bDe:Lcom/subgraph/orchid/circuits/v;
invoke-virtual {v1}, Lcom/subgraph/orchid/circuits/v;->Lh()J
move-result-wide v2
invoke-virtual {v0, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->print(Ljava/lang/String;)V
.line 216
:goto_53
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, " target="
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bDk:Ljava/lang/String;
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
invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->print(Ljava/lang/String;)V
.line 217
const-string v0, "]"
invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->println(Ljava/lang/String;)V
.line 218
return-void
.line 214
:cond_6d
const-string v0, " (waiting connect)"
invoke-virtual {p2, v0}, Ljava/io/PrintWriter;->print(Ljava/lang/String;)V
goto :goto_53
.end method
.method final b(Ljava/lang/String;IJ)V
.registers 10
.prologue
.line 145
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, ":"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDk:Ljava/lang/String;
.line 146
new-instance v0, Lcom/subgraph/orchid/circuits/a/b;
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v1}, Lcom/subgraph/orchid/circuits/f;->It()Lcom/subgraph/orchid/f;
move-result-object v1
iget-object v2, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v2}, Lcom/subgraph/orchid/circuits/f;->Ii()I
move-result v2
iget v3, p0, Lcom/subgraph/orchid/circuits/s;->bzk:I
const/4 v4, 0x1
invoke-direct {v0, v1, v2, v3, v4}, Lcom/subgraph/orchid/circuits/a/b;-><init>(Lcom/subgraph/orchid/f;III)V
.line 147
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ":"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, p2}, 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-interface {v0, v1}, Lcom/subgraph/orchid/t;->gm(Ljava/lang/String;)V
.line 148
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v1, v0}, Lcom/subgraph/orchid/circuits/f;->e(Lcom/subgraph/orchid/t;)V
.line 149
invoke-direct {p0, p3, p4}, Lcom/subgraph/orchid/circuits/s;->N(J)V
.line 150
return-void
.end method
.method public final bg(Z)V
.registers 5
.prologue
.line 190
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bCy:Ljava/lang/Object;
monitor-enter v1
.line 191
:goto_3
:try_start_3
iget v0, p0, Lcom/subgraph/orchid/circuits/s;->bCz:I
:try_end_5
.catchall {:try_start_3 .. :try_end_5} :catchall_16
if-nez v0, :cond_19
.line 193
:try_start_7
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bCy:Ljava/lang/Object;
invoke-virtual {v0}, Ljava/lang/Object;->wait()V
:try_end_c
.catch Ljava/lang/InterruptedException; {:try_start_7 .. :try_end_c} :catch_d
.catchall {:try_start_7 .. :try_end_c} :catchall_16
goto :goto_3
.line 195
:catch_d
move-exception v0
:try_start_e
new-instance v0, Lcom/subgraph/orchid/TorException;
const-string v2, "Thread interrupted while waiting for stream package window"
invoke-direct {v0, v2}, Lcom/subgraph/orchid/TorException;-><init>(Ljava/lang/String;)V
throw v0
.line 200
:catchall_16
move-exception v0
monitor-exit v1
:try_end_18
.catchall {:try_start_e .. :try_end_18} :catchall_16
throw v0
.line 198
:cond_19
if-eqz p1, :cond_21
.line 199
:try_start_1b
iget v0, p0, Lcom/subgraph/orchid/circuits/s;->bCz:I
add-int/lit8 v0, v0, -0x1
iput v0, p0, Lcom/subgraph/orchid/circuits/s;->bCz:I
.line 200
:cond_21
monitor-exit v1
:try_end_22
.catchall {:try_start_1b .. :try_end_22} :catchall_16
.line 201
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDd:Lcom/subgraph/orchid/f;
invoke-interface {v0}, Lcom/subgraph/orchid/f;->IB()V
.line 202
return-void
.end method
.method public final close()V
.registers 6
.prologue
.line 117
iget-boolean v0, p0, Lcom/subgraph/orchid/circuits/s;->bCb:Z
if-eqz v0, :cond_5
.line 135
:cond_4
:goto_4
return-void
.line 120
:cond_5
sget-object v0, Lcom/subgraph/orchid/circuits/s;->logger:Ljava/util/logging/Logger;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Closing stream "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p0}, 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
.line 122
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/subgraph/orchid/circuits/s;->bCb:Z
.line 123
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDe:Lcom/subgraph/orchid/circuits/v;
invoke-virtual {v0}, Lcom/subgraph/orchid/circuits/v;->close()V
.line 124
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDf:Lcom/subgraph/orchid/circuits/w;
invoke-virtual {v0}, Lcom/subgraph/orchid/circuits/w;->close()V
.line 125
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v0, p0}, Lcom/subgraph/orchid/circuits/f;->a(Lcom/subgraph/orchid/circuits/s;)V
.line 126
iget-boolean v0, p0, Lcom/subgraph/orchid/circuits/s;->bDc:Z
if-eqz v0, :cond_34
.line 127
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v0}, Lcom/subgraph/orchid/circuits/f;->Iu()V
.line 130
:cond_34
iget-boolean v0, p0, Lcom/subgraph/orchid/circuits/s;->bDg:Z
if-nez v0, :cond_4
.line 131
new-instance v0, Lcom/subgraph/orchid/circuits/a/b;
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v1}, Lcom/subgraph/orchid/circuits/f;->It()Lcom/subgraph/orchid/f;
move-result-object v1
iget-object v2, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v2}, Lcom/subgraph/orchid/circuits/f;->Ii()I
move-result v2
iget v3, p0, Lcom/subgraph/orchid/circuits/s;->bzk:I
const/4 v4, 0x3
invoke-direct {v0, v1, v2, v3, v4}, Lcom/subgraph/orchid/circuits/a/b;-><init>(Lcom/subgraph/orchid/f;III)V
.line 132
const/4 v1, 0x6
invoke-interface {v0, v1}, Lcom/subgraph/orchid/t;->eA(I)V
.line 133
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v1, v0}, Lcom/subgraph/orchid/circuits/f;->e(Lcom/subgraph/orchid/t;)V
goto :goto_4
.end method
.method public final getInputStream()Ljava/io/InputStream;
.registers 2
.prologue
.line 174
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDe:Lcom/subgraph/orchid/circuits/v;
return-object v0
.end method
.method public final getOutputStream()Ljava/io/OutputStream;
.registers 2
.prologue
.line 178
iget-object v0, p0, Lcom/subgraph/orchid/circuits/s;->bDf:Lcom/subgraph/orchid/circuits/w;
return-object v0
.end method
.method public final getStreamId()I
.registers 2
.prologue
.line 105
iget v0, p0, Lcom/subgraph/orchid/circuits/s;->bzk:I
return v0
.end method
.method public toString()Ljava/lang/String;
.registers 3
.prologue
.line 205
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "[Stream stream_id="
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v1, p0, Lcom/subgraph/orchid/circuits/s;->bzk:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " circuit="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bBF:Lcom/subgraph/orchid/circuits/f;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " target="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
iget-object v1, p0, Lcom/subgraph/orchid/circuits/s;->bDk:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "]"
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
return-object v0
.end method