-
Notifications
You must be signed in to change notification settings - Fork 9
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
Hypothetical patterns for asynchronous IO reads #28
Comments
@dtex – thanks for putting together these excellent notes. It is helpful to be able to see different options side-by-side. I completely agree with you that the That leaves the callback pattern and variadic read. They are mostly the same, if I understand correctly, apart from the method name. On the call Wednesday, we talked a bit about I think the potential for confusion is reduced because on the call we also agreed that a given I²C instance must be either synchronous or asynchronous.
I don't have experience that gives me an intuition of how the order of the arguments in the callbacks simplifies "promisifying" of an API. It is a small point here, but I'd like to understand. Would you mind explaining? As we talked about Wednesday, the design space here is bigger than I put together some notes to try to address the full space (thank you to @andycarle for reviewing and providing feedback). It is more-or-less an expansion of your variadic read. The constructor is explicitly passed a flag to enable asynchronous operation. That's necessary for compatibility, but it also has the benefit of making explicit that the instance is asynchronous (or synchronous) which may help a bit with the confusion concern. |
We had a very good discussion about this during the monthly TC53 call yesterday. I've updated the notes to reflect the outcome of that conversation. It feels like we're near a solution to integrate into the 2nd Edition draft and begin implementation work around. |
This is a continuation of conversations had in:
On the call I offered to model some hypothetical API calls to a currently non-existent ECMA-419 asynchronous read API. To be clear, these are examples of I2C reads from the user's perspective. The inner workings of the read implementation are left to the implementor. We're using callbacks since not all target platforms will support promises, and error first call backs can easily be "promisified" in other host environments.
Existing ECMA-419 implementation
Synchronous
read(option[, stop])
This pattern makes perfect sense for embedded systems, or anywhere reads are fast enough not to be a problem while blocking.
Possible async patterns
Callback param
readAsync(option[, stop], cb)
This seems like the most practical option. By adding a distinct, optional method for asynchronous reads the absence of the method should throw in an unambiguous way. All of the other options listed below could result in implementations that do not throw an error but also do not behave as expected.
Variadic read
read(option[, stop][, cb])
I believe that variadic functions make implementation, documentation, and support more difficult. I do not think we should use them here.
Leveraging onReadable
read(option[, stop])
First read returns, when read is complete onReadable fires. This requires user code to manage state:
Because of the burden put on the user, I do not think this is a good pattern.
Adding an onread property
read(option[, stop])
Read only triggers, when read is complete onReadable fires. This requires user code to manage state:
Because of the burden put on the user, I do not think this is a good pattern
The text was updated successfully, but these errors were encountered: