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