summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2021-01-04 16:55:30 +0100
committerDaniel Stenberg <daniel@haxx.se>2021-01-04 16:56:15 +0100
commit9be71208d2fbf2a322f234499288b695cc142e55 (patch)
treeff82fdf0f44a55e112776c4232e14a14c7757611
parentaa8de5d6ee457456ce665282d1bf5d74648683dc (diff)
downloadcurl-bagder/hyper-GOT_NOTHING.tar.gz
c-hyper: make CURLE_GOT_NOTHING workbagder/hyper-GOT_NOTHING
Test 30
-rw-r--r--lib/c-hyper.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/lib/c-hyper.c b/lib/c-hyper.c
index b6eb7466d..95299e0b8 100644
--- a/lib/c-hyper.c
+++ b/lib/c-hyper.c
@@ -318,8 +318,12 @@ static CURLcode hyperstream(struct Curl_easy *data,
else {
uint8_t errbuf[256];
size_t errlen = hyper_error_print(hypererr, errbuf, sizeof(errbuf));
- failf(data, "Hyper: %.*s", (int)errlen, errbuf);
- result = CURLE_RECV_ERROR; /* not a very good return code */
+ hyper_code code = hyper_error_code(hypererr);
+ failf(data, "Hyper: [%d] %.*s", (int)code, (int)errlen, errbuf);
+ if((code == HYPERE_UNEXPECTED_EOF) && !data->req.bytecount)
+ result = CURLE_GOT_NOTHING;
+ else
+ result = CURLE_RECV_ERROR;
}
*done = TRUE;
hyper_error_free(hypererr);
@@ -885,7 +889,8 @@ CURLcode Curl_http(struct connectdata *conn, bool *done)
if(hypererr) {
uint8_t errbuf[256];
size_t errlen = hyper_error_print(hypererr, errbuf, sizeof(errbuf));
- failf(data, "Hyper: %.*s", (int)errlen, errbuf);
+ hyper_code code = hyper_error_code(hypererr);
+ failf(data, "Hyper: [%d] %.*s", (int)code, (int)errlen, errbuf);
hyper_error_free(hypererr);
}
return CURLE_OUT_OF_MEMORY;