From: Tatsuhiro Tsujikawa Date: Thu, 15 Aug 2019 05:52:56 +0000 (+0900) Subject: ngtcp2: deal with stream close X-Git-Tag: curl-7_66_0~84 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=c47ef9115e9f527b2b3758153283af48c3c68b92;p=thirdparty%2Fcurl.git ngtcp2: deal with stream close --- diff --git a/lib/vquic/ngtcp2.c b/lib/vquic/ngtcp2.c index c26e806700..38bea45202 100644 --- a/lib/vquic/ngtcp2.c +++ b/lib/vquic/ngtcp2.c @@ -1217,12 +1217,16 @@ static int cb_h3_stream_close(nghttp3_conn *conn, int64_t stream_id, uint64_t app_error_code, void *user_data, void *stream_user_data) { + struct Curl_easy *data = stream_user_data; + struct HTTP *stream = data->req.protop; (void)conn; (void)stream_id; (void)app_error_code; (void)user_data; - (void)stream_user_data; fprintf(stderr, "cb_h3_stream_close CALLED\n"); + + stream->closed = TRUE; + return 0; } @@ -1481,6 +1485,11 @@ static ssize_t ngh3_stream_recv(struct connectdata *conn, return stream->memlen; } + if(stream->closed) { + *curlcode = CURLE_OK; + return 0; + } + infof(conn->data, "ngh3_stream_recv returns 0 bytes and EAGAIN\n"); *curlcode = CURLE_AGAIN; return -1;