-
Notifications
You must be signed in to change notification settings - Fork 273
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
PHP 8.4 support #2038
base: trunk
Are you sure you want to change the base?
PHP 8.4 support #2038
Conversation
Oh no, new PHP release = a bunch of new functions to add to the asyncify list 😢 |
I ran the tests with longer stack traces, and a big thing I see missing in the asyncify declarations is 🤞 hopefully we won't need to add too many more. I'm fixing my docker setup and planning to rebuild PHP 8.4 with this function added. |
I had trouble getting the builds to run with errors like:
and
To fix them, I had to:
I'll create another PR for those changes. It seems fine to upgrade the versions we use for build. Now there is a remaining build error but much later in the process. This line fails: The code must have changed. Planning to look at that. |
I have a local patch that seems good for this, but now there is an issue due to a change in the Emscripten-generated JS. With Emscripten 3.1.74, our ExitStatus patch conflicts because the output changed from declaring ExitStatus as a function to declaring it as a class. Functions declared anywhere in a scope are available to all statements within a scope, even if the statements precede the function declaration. The same is not true for classes, so I started running into errors that were something like "ExitStatus cannot be referenced before initialized". I think we just need to pinpoint the location of the class declaration in the JS file and insert our overriding definition immediately after that. This is quite a lot of yak-shaving by now, but I'm planning to continue with these upgrades under a separate PR because they'll need to happen sometime and I'm unable to build php-wasm without them. |
What is this PR doing?
Adds PHP 8.4 to Playground.
Also updates the dependencies:
Testing Instructions
/phpinfo.php
, confirm the php version it 8.4/phpinfo.php
, confirm the php version it 8.4PHP=8.4 nx run php-wasm-cli:start -- -i
and confirm the PHP version presented on the screen is 8.4