From c933963fea52cb585ba0d1cc328e030a03cdf455 Mon Sep 17 00:00:00 2001 From: Nitek Date: Wed, 19 May 2021 20:41:43 +0200 Subject: [PATCH] Add writeToPrint to ESP8266HTTPClient --- .../ESP8266HTTPClient/src/ESP8266HTTPClient.cpp | 16 +++++++++++++--- .../ESP8266HTTPClient/src/ESP8266HTTPClient.h | 1 + 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.cpp b/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.cpp index 592a14d0cc..65393e30b1 100644 --- a/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.cpp +++ b/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.cpp @@ -608,8 +608,18 @@ WiFiClient* HTTPClient::getStreamPtr(void) */ int HTTPClient::writeToStream(Stream * stream) { + return writeToPrint(stream); +} - if(!stream) { +/** + * write all message body / payload to Print + * @param print Print * + * @return bytes written ( negative values are error codes ) + */ +int HTTPClient::writeToPrint(Print * print) +{ + + if(!print) { return returnError(HTTPC_ERROR_NO_STREAM); } @@ -626,7 +636,7 @@ int HTTPClient::writeToStream(Stream * stream) if(_transferEncoding == HTTPC_TE_IDENTITY) { // len < 0: transfer all of it, with timeout // len >= 0: max:len, with timeout - ret = _client->sendSize(stream, len); + ret = _client->sendSize(print, len); // do we have an error? if(_client->getLastSendReport() != Stream::Report::Success) { @@ -654,7 +664,7 @@ int HTTPClient::writeToStream(Stream * stream) // data left? if(len > 0) { // read len bytes with timeout - int r = _client->sendSize(stream, len); + int r = _client->sendSize(print, len); if (_client->getLastSendReport() != Stream::Report::Success) // not all data transferred return returnError(StreamReportToHttpClientReport(_client->getLastSendReport())); diff --git a/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.h b/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.h index 4469948812..1ae43944b8 100644 --- a/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.h +++ b/libraries/ESP8266HTTPClient/src/ESP8266HTTPClient.h @@ -213,6 +213,7 @@ class HTTPClient WiFiClient& getStream(void); WiFiClient* getStreamPtr(void); + int writeToPrint(Print* print); int writeToStream(Stream* stream); const String& getString(void); static String errorToString(int error);