-
Notifications
You must be signed in to change notification settings - Fork 59
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
Promises #58
Promises #58
Conversation
I think |
My reasoning is that a Promise is like data structures - ie: non essential more advanced feature, so even "Promises in the standard library will allow providing asynchronous alternatives to various sys APIs, on par with standard libraries such as the one of node.js. Library authors and programmers in general will also benefit from being able to easily create asynchronous APIs." Makes sense to start an async package for future related tools. |
I am working on that at this very moment ( As for the |
Yer yer just adding the idea into the mix. |
I don't like to follow JS here. We had plenty of problems with JS promises. Maybe we need to try and design something specific for the rich Haxe type system. E.g. what about new Promise<Void>((resolve,reject) -> {
//how to pass Void value to resolve?
resolve(); //Error: Not enough arguments, expected value:Void
})
.then(() -> trace('wat')); And I don't like to be forced to return a promise from promise.then(result -> {
trace(result); //Error: Missing return : Promise<U>
}); Also, would be great to have an error strictly typed. But then, what if some unexpected exception is thrown - how would it be handled by a promise if the exception type does not match the error type? |
Please consider Promise and Future of tink_core. No need to reinvent the wheel. Also tink_core is really good, well thought. |
Isn't that what tink_core did though? :) But, in all seriousness – the reasons I chose to propose an A+ promise-like interface for the Haxe standard library:
From what I can see tink_core promises are built on top of tink_core futures and tink_core "surprises", etc etc. However well thought-out these classes are, they are not designed to be taken individually. @RealyUniqueName I agree there are some problems with typing tink_core promises solve this issue with a workaround of a |
My 2 cents about the async api in std: Please use callbacks. Reasons:
|
I also think simple callbacks is a good option for standard library. They can be easily mapped to whatever async operation abstraction the user prefers (which can also depend on the target and interop requirements). That said I think we should put some thought into whether these callbacks can already be used as "continuations" for our current coroutine design. It would be great if they could, without any further wrapping! |
Was there already discussion about operation cancellation? I find the "cancellation token" approach quite nice for this. |
Well then, after further thought and discussions here and on Slack, I do agree that callbacks are the way to go for the APIs in the standard library. A promisified version of the API may be added as part of a promise implementation later, since it is a question of wrapping the callbacks into promises. Target-consistent promises would still be a useful addition to the standard library. Maybe almost A+ is not the way to go if we actually want to get rid of some of the A+ problems. I'll close this for now. |
Stepping-stone for reworking the system APIs.
Rendered version