-
Notifications
You must be signed in to change notification settings - Fork 17.8k
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
question: should syscall/js be importable on other non-wasm platforms? #31158
Comments
The From what I understand, you are basically looking to write "isomorphic" wasm code without using build tags to control whether the code runs on server or client. Things might change with the wasi spec coming into the picture (#31105). But for now, I think using build tags are the way to go. You might want to write a wrapper package which goes the normal path for js,wasm and returns zero values for other targets. Then use that package in your code. I will defer to @neelance if he has any further thoughts. |
Thanks for the feedback - got it on syscall packages, makes sense.
Yes, or at least that would be the simplest developer experience if it is possible to achieve. I thought about a wrapper package and it's certainly an option, but I'm concerned it will feel crufty and unnecessary for the most common case. (And developers will look at it and rightly ask, why can't I just use In any case, thanks for the suggestion. I'll definitely weigh the pros and cons and see what makes sense. (UPDATE: actually, I think if I provide my own copy of Assuming WASI moves forward and provides a more standardized interface for external access to things, I guess it's possible that could potentially lead to a package that would exist both in browser and on-server... But it means building and running server code with GOOS=wasi - which, while I won't count it out, I know for sure a lot of people won't want to mess around with. Which basically just points back to what you've already said, figure out a way to use build tags. |
I think @agnivade already explained it quite well. The abstraction you are looking for should happen on a different level (virtual DOM) and with build tags you can make sure that the code which uses |
Okay cool. Thanks to the both of you for taking the time to answer. I agree, I'll be able to handle this in my package using build tags. I'll go ahead and close this issue. |
What version of Go are you using (
go version
)?Does this issue reproduce with the latest release?
Yes
What did you do?
Trying to write code that compiles in WebAssembly and in other architectures that imports
syscall/js
is not possible (package only exists in wasm).While I certainly understand the reason the package isn't there on other platforms, while writing Vugu (github.com/vugu/vugu) I've encountered an issue which is that that of writing UI components that run in wasm, but also are executable on the server to render a page server-side. Of course the code in question is not executed on the server-side, but the component may be written with various references to types and funcs in
js
.Obviously it is possible to use build constraints to make a program that optionally includes the right code for different platforms, but this is not necessarily trivial or a good developer experience (at least in this case, in my opinion).
Is there a specific reason that on Linux for example I shouldn't be able to
import syscall/js
and have the same types, but everything otherwise fails or returns zero values?I realize it's a bit of a strange request, but there is at least some smaller scale precedent in things like
os.Getegid()
- it returns -1 on Windows rather than the function just not being present.It wouldn't be difficult to do or maintain, but I don't know if there is already some rule or philosophy as to why this approach isn't good.
What do you think? Should I be able to declare a variable of type
js.Value
in my code on another platform and have it compile? (Even if it will always be a zero value)The text was updated successfully, but these errors were encountered: