Skip to content
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

Merged
merged 4 commits into from
Jan 27, 2025

Conversation

fgmccabe
Copy link
Collaborator

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).

Copy link
Contributor

@syg syg left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should close #56, right? Please change the commit message to say it closes #56.

Avoiding the use of teh ? macro in performing PromiseResolve
@fgmccabe
Copy link
Collaborator Author

Just to confirm, this PR would close issue #56.

Copy link
Contributor

@syg syg left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm % SuspendError question.

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}}.
Copy link
Contributor

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?

Copy link
Collaborator Author

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.

@fgmccabe fgmccabe merged commit afea1c3 into main Jan 27, 2025
5 of 6 checks passed
@fgmccabe
Copy link
Collaborator Author

Spec now adjusted to reflect that calling Suspending imports will always suspend.

@bakkot bakkot mentioned this pull request Feb 1, 2025
SPY added a commit to SPY/js-promise-integration that referenced this pull request Feb 5, 2025
WebAssembly#57 updated the spec. Updating tests to reflect the change.
SPY added a commit to SPY/wpt that referenced this pull request Feb 5, 2025
…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
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Feb 20, 2025
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}
aarongable pushed a commit to chromium/chromium that referenced this pull request Feb 20, 2025
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}
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Feb 20, 2025
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}
moz-v2v-gh pushed a commit to mozilla/gecko-dev that referenced this pull request Feb 28, 2025
…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
i3roly pushed a commit to i3roly/firefox-dynasty that referenced this pull request Feb 28, 2025
…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
gecko-dev-updater pushed a commit to marco-c/gecko-dev-wordified that referenced this pull request Mar 1, 2025
…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
gecko-dev-updater pushed a commit to marco-c/gecko-dev-comments-removed that referenced this pull request Mar 1, 2025
…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
gecko-dev-updater pushed a commit to marco-c/gecko-dev-wordified-and-comments-removed that referenced this pull request Mar 1, 2025
…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
jamienicol pushed a commit to jamienicol/gecko that referenced this pull request Mar 5, 2025
…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
glandium pushed a commit to mozilla-firefox/firefox that referenced this pull request Apr 1, 2025
…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
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants