AbstractClientStream.smali
.class public abstract Lio/grpc/internal/AbstractClientStream;
.super Lio/grpc/internal/AbstractStream;
.source "AbstractClientStream.java"
# interfaces
.implements Lio/grpc/internal/ClientStream;
# annotations
.annotation system Ldalvik/annotation/Signature;
value = {
"<IdT:",
"Ljava/lang/Object;",
">",
"Lio/grpc/internal/AbstractStream<",
"TIdT;>;",
"Lio/grpc/internal/ClientStream;"
}
.end annotation
# static fields
.field private static final log:Ljava/util/logging/Logger;
# instance fields
.field private volatile cancelled:Z
.field private closeListenerTask:Ljava/lang/Runnable;
.field private listener:Lio/grpc/internal/ClientStreamListener;
.field private listenerClosed:Z
.field private status:Lio/grpc/Status;
.field private trailers:Lio/grpc/Metadata;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 1
const-class v0, Lio/grpc/internal/AbstractClientStream;
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, Lio/grpc/internal/AbstractClientStream;->log:Ljava/util/logging/Logger;
return-void
.end method
.method protected constructor <init>(Lio/grpc/internal/WritableBufferAllocator;I)V
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lio/grpc/internal/AbstractStream;-><init>(Lio/grpc/internal/WritableBufferAllocator;I)V
return-void
.end method
.method static synthetic access$000(Lio/grpc/internal/AbstractClientStream;Lio/grpc/Status;Lio/grpc/Metadata;)V
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lio/grpc/internal/AbstractClientStream;->closeListener(Lio/grpc/Status;Lio/grpc/Metadata;)V
return-void
.end method
.method private closeListener(Lio/grpc/Status;Lio/grpc/Metadata;)V
.registers 6
.line 1
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
const/4 v1, 0x1
if-eqz v0, :cond_7
const/4 v0, 0x1
goto :goto_8
:cond_7
const/4 v0, 0x0
:goto_8
const-string v2, "stream not started"
invoke-static {v0, v2}, Lcom/google/common/base/r;->b(ZLjava/lang/Object;)V
.line 2
iget-boolean v0, p0, Lio/grpc/internal/AbstractClientStream;->listenerClosed:Z
if-nez v0, :cond_1b
.line 3
iput-boolean v1, p0, Lio/grpc/internal/AbstractClientStream;->listenerClosed:Z
.line 4
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->closeDeframer()V
.line 5
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
invoke-interface {v0, p1, p2}, Lio/grpc/internal/ClientStreamListener;->closed(Lio/grpc/Status;Lio/grpc/Metadata;)V
:cond_1b
return-void
.end method
.method private newCloseListenerTask(Lio/grpc/Status;Lio/grpc/Metadata;)Ljava/lang/Runnable;
.registers 4
.line 1
new-instance v0, Lio/grpc/internal/AbstractClientStream$1;
invoke-direct {v0, p0, p1, p2}, Lio/grpc/internal/AbstractClientStream$1;-><init>(Lio/grpc/internal/AbstractClientStream;Lio/grpc/Status;Lio/grpc/Metadata;)V
return-object v0
.end method
.method private runCloseListenerTask()V
.registers 2
.line 1
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->closeListenerTask:Ljava/lang/Runnable;
if-eqz v0, :cond_a
.line 2
invoke-interface {v0}, Ljava/lang/Runnable;->run()V
const/4 v0, 0x0
.line 3
iput-object v0, p0, Lio/grpc/internal/AbstractClientStream;->closeListenerTask:Ljava/lang/Runnable;
:cond_a
return-void
.end method
# virtual methods
.method public final cancel(Lio/grpc/Status;)V
.registers 5
.line 1
invoke-virtual {p1}, Lio/grpc/Status;->isOk()Z
move-result v0
const/4 v1, 0x1
xor-int/2addr v0, v1
const-string v2, "Should not cancel with OK status"
invoke-static {v0, v2}, Lcom/google/common/base/r;->a(ZLjava/lang/Object;)V
.line 2
iput-boolean v1, p0, Lio/grpc/internal/AbstractClientStream;->cancelled:Z
.line 3
invoke-virtual {p0, p1}, Lio/grpc/internal/AbstractClientStream;->sendCancel(Lio/grpc/Status;)V
.line 4
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->dispose()V
return-void
.end method
.method protected final deframeFailed(Ljava/lang/Throwable;)V
.registers 4
.line 1
sget-object v0, Lio/grpc/Status;->INTERNAL:Lio/grpc/Status;
const-string v1, "Exception deframing message"
invoke-virtual {v0, v1}, Lio/grpc/Status;->withDescription(Ljava/lang/String;)Lio/grpc/Status;
move-result-object v0
invoke-virtual {v0, p1}, Lio/grpc/Status;->withCause(Ljava/lang/Throwable;)Lio/grpc/Status;
move-result-object p1
invoke-virtual {p0, p1}, Lio/grpc/internal/AbstractClientStream;->cancel(Lio/grpc/Status;)V
return-void
.end method
.method public final halfClose()V
.registers 3
.line 1
sget-object v0, Lio/grpc/internal/AbstractStream$Phase;->STATUS:Lio/grpc/internal/AbstractStream$Phase;
invoke-virtual {p0, v0}, Lio/grpc/internal/AbstractStream;->outboundPhase(Lio/grpc/internal/AbstractStream$Phase;)Lio/grpc/internal/AbstractStream$Phase;
move-result-object v0
sget-object v1, Lio/grpc/internal/AbstractStream$Phase;->STATUS:Lio/grpc/internal/AbstractStream$Phase;
if-eq v0, v1, :cond_d
.line 2
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->closeFramer()V
:cond_d
return-void
.end method
.method protected inboundDataReceived(Lio/grpc/internal/ReadableBuffer;)V
.registers 6
const-string v0, "frame"
.line 1
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const/4 v0, 0x0
const/4 v1, 0x1
.line 2
:try_start_7
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->inboundPhase()Lio/grpc/internal/AbstractStream$Phase;
move-result-object v2
sget-object v3, Lio/grpc/internal/AbstractStream$Phase;->STATUS:Lio/grpc/internal/AbstractStream$Phase;
:try_end_d
.catchall {:try_start_7 .. :try_end_d} :catchall_3c
if-ne v2, v3, :cond_13
.line 3
invoke-interface {p1}, Lio/grpc/internal/ReadableBuffer;->close()V
return-void
.line 4
:cond_13
:try_start_13
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->inboundPhase()Lio/grpc/internal/AbstractStream$Phase;
move-result-object v2
sget-object v3, Lio/grpc/internal/AbstractStream$Phase;->HEADERS:Lio/grpc/internal/AbstractStream$Phase;
if-ne v2, v3, :cond_2f
.line 5
sget-object v0, Lio/grpc/Status;->INTERNAL:Lio/grpc/Status;
const-string v2, "headers not received before payload"
.line 6
invoke-virtual {v0, v2}, Lio/grpc/Status;->withDescription(Ljava/lang/String;)Lio/grpc/Status;
move-result-object v0
new-instance v2, Lio/grpc/Metadata;
invoke-direct {v2}, Lio/grpc/Metadata;-><init>()V
.line 7
invoke-virtual {p0, v0, v2}, Lio/grpc/internal/AbstractClientStream;->inboundTransportError(Lio/grpc/Status;Lio/grpc/Metadata;)V
:try_end_2b
.catchall {:try_start_13 .. :try_end_2b} :catchall_3c
.line 8
invoke-interface {p1}, Lio/grpc/internal/ReadableBuffer;->close()V
return-void
.line 9
:cond_2f
:try_start_2f
sget-object v2, Lio/grpc/internal/AbstractStream$Phase;->MESSAGE:Lio/grpc/internal/AbstractStream$Phase;
invoke-virtual {p0, v2}, Lio/grpc/internal/AbstractStream;->inboundPhase(Lio/grpc/internal/AbstractStream$Phase;)Lio/grpc/internal/AbstractStream$Phase;
:try_end_34
.catchall {:try_start_2f .. :try_end_34} :catchall_3c
.line 10
:try_start_34
invoke-virtual {p0, p1, v0}, Lio/grpc/internal/AbstractStream;->deframe(Lio/grpc/internal/ReadableBuffer;Z)V
:try_end_37
.catchall {:try_start_34 .. :try_end_37} :catchall_38
return-void
:catchall_38
move-exception v1
move-object v0, v1
const/4 v1, 0x0
goto :goto_3d
:catchall_3c
move-exception v0
:goto_3d
if-eqz v1, :cond_42
.line 11
invoke-interface {p1}, Lio/grpc/internal/ReadableBuffer;->close()V
:cond_42
throw v0
.end method
.method protected inboundDeliveryPaused()V
.registers 1
.line 1
invoke-direct {p0}, Lio/grpc/internal/AbstractClientStream;->runCloseListenerTask()V
return-void
.end method
.method protected inboundHeadersReceived(Lio/grpc/Metadata;)V
.registers 8
.line 1
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
const/4 v1, 0x1
const/4 v2, 0x0
if-eqz v0, :cond_8
const/4 v0, 0x1
goto :goto_9
:cond_8
const/4 v0, 0x0
:goto_9
const-string v3, "stream not started"
invoke-static {v0, v3}, Lcom/google/common/base/r;->b(ZLjava/lang/Object;)V
.line 2
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->inboundPhase()Lio/grpc/internal/AbstractStream$Phase;
move-result-object v0
sget-object v3, Lio/grpc/internal/AbstractStream$Phase;->STATUS:Lio/grpc/internal/AbstractStream$Phase;
if-ne v0, v3, :cond_2a
.line 3
sget-object v0, Lio/grpc/internal/AbstractClientStream;->log:Ljava/util/logging/Logger;
sget-object v3, Ljava/util/logging/Level;->INFO:Ljava/util/logging/Level;
const/4 v4, 0x2
new-array v4, v4, [Ljava/lang/Object;
.line 4
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->id()Ljava/lang/Object;
move-result-object v5
aput-object v5, v4, v2
aput-object p1, v4, v1
const-string v1, "Received headers on closed stream {0} {1}"
.line 5
invoke-virtual {v0, v3, v1, v4}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
.line 6
:cond_2a
sget-object v0, Lio/grpc/internal/AbstractStream$Phase;->MESSAGE:Lio/grpc/internal/AbstractStream$Phase;
invoke-virtual {p0, v0}, Lio/grpc/internal/AbstractStream;->inboundPhase(Lio/grpc/internal/AbstractStream$Phase;)Lio/grpc/internal/AbstractStream$Phase;
.line 7
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
invoke-interface {v0, p1}, Lio/grpc/internal/ClientStreamListener;->headersRead(Lio/grpc/Metadata;)V
return-void
.end method
.method protected inboundTrailersReceived(Lio/grpc/Metadata;Lio/grpc/Status;)V
.registers 9
const-string v0, "trailers"
.line 1
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 2
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->inboundPhase()Lio/grpc/internal/AbstractStream$Phase;
move-result-object v0
sget-object v1, Lio/grpc/internal/AbstractStream$Phase;->STATUS:Lio/grpc/internal/AbstractStream$Phase;
const/4 v2, 0x1
if-ne v0, v1, :cond_26
.line 3
sget-object v0, Lio/grpc/internal/AbstractClientStream;->log:Ljava/util/logging/Logger;
sget-object v1, Ljava/util/logging/Level;->INFO:Ljava/util/logging/Level;
const/4 v3, 0x3
new-array v3, v3, [Ljava/lang/Object;
const/4 v4, 0x0
.line 4
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->id()Ljava/lang/Object;
move-result-object v5
aput-object v5, v3, v4
aput-object p2, v3, v2
const/4 v4, 0x2
aput-object p1, v3, v4
const-string v4, "Received trailers on closed stream {0}\n {1}\n {2}"
.line 5
invoke-virtual {v0, v1, v4, v3}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
.line 6
:cond_26
iput-object p2, p0, Lio/grpc/internal/AbstractClientStream;->status:Lio/grpc/Status;
.line 7
iput-object p1, p0, Lio/grpc/internal/AbstractClientStream;->trailers:Lio/grpc/Metadata;
.line 8
invoke-static {}, Lio/grpc/internal/ReadableBuffers;->empty()Lio/grpc/internal/ReadableBuffer;
move-result-object p1
invoke-virtual {p0, p1, v2}, Lio/grpc/internal/AbstractStream;->deframe(Lio/grpc/internal/ReadableBuffer;Z)V
return-void
.end method
.method protected inboundTransportError(Lio/grpc/Status;Lio/grpc/Metadata;)V
.registers 7
const-string v0, "metadata"
.line 1
invoke-static {p2, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 2
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->inboundPhase()Lio/grpc/internal/AbstractStream$Phase;
move-result-object v0
sget-object v1, Lio/grpc/internal/AbstractStream$Phase;->STATUS:Lio/grpc/internal/AbstractStream$Phase;
const/4 v2, 0x0
if-ne v0, v1, :cond_24
.line 3
sget-object p2, Lio/grpc/internal/AbstractClientStream;->log:Ljava/util/logging/Logger;
sget-object v0, Ljava/util/logging/Level;->INFO:Ljava/util/logging/Level;
const/4 v1, 0x2
new-array v1, v1, [Ljava/lang/Object;
.line 4
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->id()Ljava/lang/Object;
move-result-object v3
aput-object v3, v1, v2
const/4 v2, 0x1
aput-object p1, v1, v2
const-string p1, "Received transport error on closed stream {0} {1}"
.line 5
invoke-virtual {p2, v0, p1, v1}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 6
:cond_24
invoke-virtual {p0, p1, v2, p2}, Lio/grpc/internal/AbstractClientStream;->transportReportStatus(Lio/grpc/Status;ZLio/grpc/Metadata;)V
return-void
.end method
.method protected final internalSendFrame(Lio/grpc/internal/WritableBuffer;ZZ)V
.registers 6
if-nez p1, :cond_7
if-eqz p2, :cond_5
goto :goto_7
:cond_5
const/4 v0, 0x0
goto :goto_8
:cond_7
:goto_7
const/4 v0, 0x1
:goto_8
const-string v1, "null frame before EOS"
.line 1
invoke-static {v0, v1}, Lcom/google/common/base/r;->a(ZLjava/lang/Object;)V
.line 2
invoke-virtual {p0, p1, p2, p3}, Lio/grpc/internal/AbstractClientStream;->sendFrame(Lio/grpc/internal/WritableBuffer;ZZ)V
return-void
.end method
.method public isClosed()Z
.registers 2
.line 1
invoke-super {p0}, Lio/grpc/internal/AbstractStream;->isClosed()Z
move-result v0
if-nez v0, :cond_d
iget-boolean v0, p0, Lio/grpc/internal/AbstractClientStream;->listenerClosed:Z
if-eqz v0, :cond_b
goto :goto_d
:cond_b
const/4 v0, 0x0
goto :goto_e
:cond_d
:goto_d
const/4 v0, 0x1
:goto_e
return v0
.end method
.method public final isReady()Z
.registers 2
.line 1
iget-boolean v0, p0, Lio/grpc/internal/AbstractClientStream;->cancelled:Z
if-nez v0, :cond_c
invoke-super {p0}, Lio/grpc/internal/AbstractStream;->isReady()Z
move-result v0
if-eqz v0, :cond_c
const/4 v0, 0x1
goto :goto_d
:cond_c
const/4 v0, 0x0
:goto_d
return v0
.end method
.method protected final listener()Lio/grpc/internal/ClientStreamListener;
.registers 2
.line 2
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
return-object v0
.end method
.method protected bridge synthetic listener()Lio/grpc/internal/StreamListener;
.registers 2
.line 1
invoke-virtual {p0}, Lio/grpc/internal/AbstractClientStream;->listener()Lio/grpc/internal/ClientStreamListener;
move-result-object v0
return-object v0
.end method
.method protected receiveMessage(Ljava/io/InputStream;)V
.registers 4
.line 1
iget-boolean v0, p0, Lio/grpc/internal/AbstractClientStream;->listenerClosed:Z
if-nez v0, :cond_15
.line 2
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
if-eqz v0, :cond_a
const/4 v0, 0x1
goto :goto_b
:cond_a
const/4 v0, 0x0
:goto_b
const-string v1, "stream not started"
invoke-static {v0, v1}, Lcom/google/common/base/r;->b(ZLjava/lang/Object;)V
.line 3
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
invoke-interface {v0, p1}, Lio/grpc/internal/StreamListener;->messageRead(Ljava/io/InputStream;)V
:cond_15
return-void
.end method
.method protected remoteEndClosed()V
.registers 4
.line 1
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->status:Lio/grpc/Status;
iget-object v1, p0, Lio/grpc/internal/AbstractClientStream;->trailers:Lio/grpc/Metadata;
const/4 v2, 0x1
invoke-virtual {p0, v0, v2, v1}, Lio/grpc/internal/AbstractClientStream;->transportReportStatus(Lio/grpc/Status;ZLio/grpc/Metadata;)V
return-void
.end method
.method protected abstract sendCancel(Lio/grpc/Status;)V
.end method
.method protected abstract sendFrame(Lio/grpc/internal/WritableBuffer;ZZ)V
.end method
.method public start(Lio/grpc/internal/ClientStreamListener;)V
.registers 4
.line 1
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
if-nez v0, :cond_6
const/4 v0, 0x1
goto :goto_7
:cond_6
const/4 v0, 0x0
:goto_7
const-string v1, "stream already started"
invoke-static {v0, v1}, Lcom/google/common/base/r;->b(ZLjava/lang/Object;)V
const-string v0, "listener"
.line 2
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
check-cast p1, Lio/grpc/internal/ClientStreamListener;
iput-object p1, p0, Lio/grpc/internal/AbstractClientStream;->listener:Lio/grpc/internal/ClientStreamListener;
return-void
.end method
.method protected toStringHelper()Lcom/google/common/base/k$a;
.registers 4
.line 1
invoke-super {p0}, Lio/grpc/internal/AbstractStream;->toStringHelper()Lcom/google/common/base/k$a;
move-result-object v0
.line 2
iget-object v1, p0, Lio/grpc/internal/AbstractClientStream;->status:Lio/grpc/Status;
if-eqz v1, :cond_d
const-string v2, "status"
.line 3
invoke-virtual {v0, v2, v1}, Lcom/google/common/base/k$a;->a(Ljava/lang/String;Ljava/lang/Object;)Lcom/google/common/base/k$a;
:cond_d
return-object v0
.end method
.method public transportReportStatus(Lio/grpc/Status;ZLio/grpc/Metadata;)V
.registers 6
const-string v0, "newStatus"
.line 1
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 2
iget-object v0, p0, Lio/grpc/internal/AbstractClientStream;->closeListenerTask:Ljava/lang/Runnable;
if-eqz v0, :cond_d
if-nez p2, :cond_d
const/4 v0, 0x1
goto :goto_e
:cond_d
const/4 v0, 0x0
.line 3
:goto_e
iget-boolean v1, p0, Lio/grpc/internal/AbstractClientStream;->listenerClosed:Z
if-nez v1, :cond_32
if-eqz v0, :cond_15
goto :goto_32
.line 4
:cond_15
sget-object v0, Lio/grpc/internal/AbstractStream$Phase;->STATUS:Lio/grpc/internal/AbstractStream$Phase;
invoke-virtual {p0, v0}, Lio/grpc/internal/AbstractStream;->inboundPhase(Lio/grpc/internal/AbstractStream$Phase;)Lio/grpc/internal/AbstractStream$Phase;
.line 5
iput-object p1, p0, Lio/grpc/internal/AbstractClientStream;->status:Lio/grpc/Status;
const/4 v0, 0x0
.line 6
iput-object v0, p0, Lio/grpc/internal/AbstractClientStream;->closeListenerTask:Ljava/lang/Runnable;
.line 7
invoke-virtual {p0}, Lio/grpc/internal/AbstractStream;->isDeframerStalled()Z
move-result v0
if-nez p2, :cond_2f
if-eqz v0, :cond_28
goto :goto_2f
.line 8
:cond_28
invoke-direct {p0, p1, p3}, Lio/grpc/internal/AbstractClientStream;->newCloseListenerTask(Lio/grpc/Status;Lio/grpc/Metadata;)Ljava/lang/Runnable;
move-result-object p1
iput-object p1, p0, Lio/grpc/internal/AbstractClientStream;->closeListenerTask:Ljava/lang/Runnable;
goto :goto_32
.line 9
:cond_2f
:goto_2f
invoke-direct {p0, p1, p3}, Lio/grpc/internal/AbstractClientStream;->closeListener(Lio/grpc/Status;Lio/grpc/Metadata;)V
:cond_32
:goto_32
return-void
.end method