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-05 09:38:25 +0100
commit4f95ce8dfecbd0c15ffa27ddc90ff46bb5fbfa62 (patch)
tree2d66084991e19c100b4309f93d423d13a6933684
parentbcce220367fd4c95c4008a36e9b5020b6e3d6a63 (diff)
downloadcurl-4f95ce8dfecbd0c15ffa27ddc90ff46bb5fbfa62.tar.gz
c-hyper: make CURLE_GOT_NOTHING work
Test 30 Closes #6407
-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 3a81db95f..9ee17e3f8 100644
--- a/lib/c-hyper.c
+++ b/lib/c-hyper.c
@@ -318,8 +318,12 @@ CURLcode Curl_hyper_stream(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;