You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
If the module you run happens to have a main function then it appears to want to return the result of executing that function. However, if the module your run doesn't have a main function it will return the result of calling the interpret function. This function returns true if successful and false otherwise. So the return value is either a result of executing a wasm function or something that indicates if the module executed successfully which makes it hard to use as a programmer. If I want to make something that does something if the execution fails then I can't use this function reliably because if the module has a main method then it won't tell me if it failed or not. If the module doesn't have a main method then it does work.
So it basically sometimes returns success of the application (based on the exit code) and sometimes success as in it was able to fully execute everything without any issues. An application can return exit code 1 but that doesn't mean there was an issue executing the module, it means there was an error and the application safely took care of it.
On a further note m->stack[0].value.uint32 is also not really correct for all functions. If I invoke a function that has a local for example and the execution fails then it will return the value of the local instead of the value that was actually returned from the function. So m->stack[m->sp].value.uint32 would be more correct.
Proposed solution
Just return what invoke returns so this function consistently just returns a boolean that indicates success in terms of execution. If you want to get the returned value of the main method then the caller can just look what is on the stack after running run_module.
The run_module method in WARDuino.cpp is a bit strange to use.
If the module you run happens to have a main function then it appears to want to return the result of executing that function. However, if the module your run doesn't have a main function it will return the result of calling the interpret function. This function returns true if successful and false otherwise. So the return value is either a result of executing a wasm function or something that indicates if the module executed successfully which makes it hard to use as a programmer. If I want to make something that does something if the execution fails then I can't use this function reliably because if the module has a main method then it won't tell me if it failed or not. If the module doesn't have a main method then it does work.
So it basically sometimes returns success of the application (based on the exit code) and sometimes success as in it was able to fully execute everything without any issues. An application can return exit code 1 but that doesn't mean there was an issue executing the module, it means there was an error and the application safely took care of it.
On a further note
m->stack[0].value.uint32
is also not really correct for all functions. If I invoke a function that has a local for example and the execution fails then it will return the value of the local instead of the value that was actually returned from the function. Som->stack[m->sp].value.uint32
would be more correct.Proposed solution
Just return what invoke returns so this function consistently just returns a boolean that indicates success in terms of execution. If you want to get the returned value of the main method then the caller can just look what is on the stack after running
run_module
.The text was updated successfully, but these errors were encountered: