-
Notifications
You must be signed in to change notification settings - Fork 25
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
Modify spec to use Promise.resolve on result of call to suspending function. #57
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Avoiding the use of teh ? macro in performing PromiseResolve
Just to confirm, this PR would close issue #56. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm % SuspendError question.
document/js-api/index.bs
Outdated
1. Let |awaitResult| be the result of performing [$Completion$]([$Await$](|promise|)). | ||
1. Note: This will suspend both this algorithm, and the WebAssembly function being invoked by the [=evaluate a Promising function=] algorithm. On return, |ret| will be either a normal completion or a throw completion. | ||
1. If the entry for |async_context| in |map| is not [=paused=] then: | ||
1. Perform [=throw a JavaScript exception=] with a {{RuntimeError}}. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This line changed from a SuspendError
to RuntimeError
. Was this intentional?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh no .. that's the result of github claiming a code conflict... I will fix.
Spec now adjusted to reflect that calling Suspending imports will always suspend. |
WebAssembly#57 updated the spec. Updating tests to reflect the change.
…e value The JSPI proposal was updated recently to always suspend if suspending import was called by wrapping result with Promise.resolve WebAssembly/js-promise-integration#57
Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <[email protected]> Reviewed-by: Rezvan Mahdavi Hezaveh <[email protected]> Commit-Queue: Ilya Rezvov <[email protected]> Cr-Commit-Position: refs/heads/main@{#1422652}
Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <[email protected]> Reviewed-by: Rezvan Mahdavi Hezaveh <[email protected]> Commit-Queue: Ilya Rezvov <[email protected]> Cr-Commit-Position: refs/heads/main@{#1422652}
Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <[email protected]> Reviewed-by: Rezvan Mahdavi Hezaveh <[email protected]> Commit-Queue: Ilya Rezvov <[email protected]> Cr-Commit-Position: refs/heads/main@{#1422652}
…sts for JSPI, a=testonly Automatic update from web-platform-tests [wasm][jspi] Fix wpt and reenable WPT tests for JSPI Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <[email protected]> Reviewed-by: Rezvan Mahdavi Hezaveh <[email protected]> Commit-Queue: Ilya Rezvov <[email protected]> Cr-Commit-Position: refs/heads/main@{#1422652} -- wpt-commits: 1ed7956f44f916907b3157e13cc5f5bf10b18c57 wpt-pr: 50839
…sts for JSPI, a=testonly Automatic update from web-platform-tests [wasm][jspi] Fix wpt and reenable WPT tests for JSPI Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <[email protected]> Reviewed-by: Rezvan Mahdavi Hezaveh <[email protected]> Commit-Queue: Ilya Rezvov <[email protected]> Cr-Commit-Position: refs/heads/main@{#1422652} -- wpt-commits: 1ed7956f44f916907b3157e13cc5f5bf10b18c57 wpt-pr: 50839
…sts for JSPI, a=testonly Automatic update from web-platform-tests [wasm][jspi] Fix wpt and reenable WPT tests for JSPI Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <sygchromium.org> Reviewed-by: Rezvan Mahdavi Hezaveh <rezvanchromium.org> Commit-Queue: Ilya Rezvov <irezvovchromium.org> Cr-Commit-Position: refs/heads/main{#1422652} -- wpt-commits: 1ed7956f44f916907b3157e13cc5f5bf10b18c57 wpt-pr: 50839 UltraBlame original commit: 7b952e8c0041a350b0431969534d125b38f929a0
…sts for JSPI, a=testonly Automatic update from web-platform-tests [wasm][jspi] Fix wpt and reenable WPT tests for JSPI Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <sygchromium.org> Reviewed-by: Rezvan Mahdavi Hezaveh <rezvanchromium.org> Commit-Queue: Ilya Rezvov <irezvovchromium.org> Cr-Commit-Position: refs/heads/main{#1422652} -- wpt-commits: 1ed7956f44f916907b3157e13cc5f5bf10b18c57 wpt-pr: 50839 UltraBlame original commit: 7b952e8c0041a350b0431969534d125b38f929a0
…sts for JSPI, a=testonly Automatic update from web-platform-tests [wasm][jspi] Fix wpt and reenable WPT tests for JSPI Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <sygchromium.org> Reviewed-by: Rezvan Mahdavi Hezaveh <rezvanchromium.org> Commit-Queue: Ilya Rezvov <irezvovchromium.org> Cr-Commit-Position: refs/heads/main{#1422652} -- wpt-commits: 1ed7956f44f916907b3157e13cc5f5bf10b18c57 wpt-pr: 50839 UltraBlame original commit: 7b952e8c0041a350b0431969534d125b38f929a0
…sts for JSPI, a=testonly Automatic update from web-platform-tests [wasm][jspi] Fix wpt and reenable WPT tests for JSPI Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <[email protected]> Reviewed-by: Rezvan Mahdavi Hezaveh <[email protected]> Commit-Queue: Ilya Rezvov <[email protected]> Cr-Commit-Position: refs/heads/main@{#1422652} -- wpt-commits: 1ed7956f44f916907b3157e13cc5f5bf10b18c57 wpt-pr: 50839
…sts for JSPI, a=testonly Automatic update from web-platform-tests [wasm][jspi] Fix wpt and reenable WPT tests for JSPI Update JSPI wpt test according to recent changes in spec landed in WebAssembly/js-promise-integration#57 Bug: 397449611 Change-Id: Iea277d945df24c00fce1565dae415ecb3e0092a7 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6282812 Reviewed-by: Shu-yu Guo <[email protected]> Reviewed-by: Rezvan Mahdavi Hezaveh <[email protected]> Commit-Queue: Ilya Rezvov <[email protected]> Cr-Commit-Position: refs/heads/main@{#1422652} -- wpt-commits: 1ed7956f44f916907b3157e13cc5f5bf10b18c57 wpt-pr: 50839
This modifies the specification:
All calls to functions that are marked as Suspending will be processed using Promise.resolve.
Note that, if the callee throws, then that throw is NOT converted to a Promise. In part, this is because we cannot reliably invoke Promise.reject in all cases (e.g., stack overflow errors).