-
Notifications
You must be signed in to change notification settings - Fork 13.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
default implementation for buffered Stream.read only reads every second byte #8452
Comments
Nice catch ! |
That was also my first guess, that it is probably overloaded everywhere, in favour of a faster version. |
Like this? |
Yes. Doing this adds a reference to the issue (look to the right column on this page) and automatically closes the issue (this post) when the PR is merged. |
The current Stream::read (uint8_t* buffer, size_t maxLen) provides a standard implementation for writing a stream to a buffer.
It uses the virtual int method Stream::read() to read the stream byte by byte until no more bytes are available.
However, it calls read() twice in each loop. This results in only every 2nd byte actually being read into the destination buffer, as the read() method will always return the next byte in the stream.
At least that is my understanding of how the read() method of streams is supposed to work.
The lines of code involved:
Arduino/cores/esp8266/Stream.cpp
Lines 267 to 279 in 9fcf14f
The text was updated successfully, but these errors were encountered: