-
Notifications
You must be signed in to change notification settings - Fork 36
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
Proposal to Create SIG-TypeScript-Compilation #28
Conversation
nominate Marcin Kolny as RC
Hello, The TSC discussed this SIG proposal at our most recent meeting. We have the
We would like to see verbiage enshrining these requirements in the SIG's On behalf of the TSC, |
Thank you @fitzgen and TSC for the valuable comments! Just one question regarding to the words "ship in production" below, what is the exact definition?
|
Thanks for your patience.
The features should be behind an experimental flag (e.g. On behalf of the TSC, |
@fitzgen Thank you for the explanation! I fully understand the motivation behind however I are not sure phase 4 is appropriate level as requirement. Looking at the proposals from WebAssembly and WASI and many level 3 and below proposals are implemented already, I doubt the suggested rules have been followed in the BA practices:
Additionally, the primary goal of SIG is for discussion and possibly creating some proposal. It doesn't mean necessary developing tools or runtime. I see such requirements are better for the projects under BA, rather than SIG. |
Would it be sufficient to simply state that any new APIs would be added via WASI proposal process? I don't have a lot of experience within BA, but what is the scope of SIGs as opposed to proposals? From personal experience, other projects define SIGs as coordination venues rather than concrete proposals (CG's subgroups are a similar idea).
I am confused by WebAssembly standards process reference, does this requirement derive from it? To my best knowledge decisions about flags and warning are left to the implementer, at the very least I can't find anything about it in CG docs (WASI process seem to now refer to CG process). |
That's a good point. The exact required level of standardization and stability might vary based on which standards body is involved, and the nature of the proposals. The TSC is happy to provide guidance on whether a lower level of stability is sufficient for specific proposals. Taking a step back, the TSC, as well as the board, which we consulted last week, feel strongly that this SIG should work towards results that follow two key principles:
These principles directly follow from the BA's operational principles, and in particular the "How We Want to Work With Others" section. Note that these principles are not specific just to this proposed SIG; we are applying them equally to all work under the BA umbrella, including other recently proposed SIGs.
You're right that some of the above is about implementations. The SIG should however work in a way that makes it easy for any concrete implementations to follow these principles. Additionally, the SIG should ensure that all contributors to these projects are fully aware of these requirements.
We explicitly don't want to further any ecosystem fragmentation. As such, we want to ensure that any work resulting from this SIG's activities targets more than just a single runtime. The best way to ensure this is to get consensus to not enable any required features by default until they're sufficiently far along in a standardization process such that they can be implemented by multiple WebAssembly runtimes. Additionally, WASI isn't the only body to coordinate with for this work. Depending on the direction the SIG ends up taking, the WebAssembly CG itself as well as other standards bodies might become involved. Plus, if any changes to TypeScript as a language are required, close coordination with the TypeScript team will become necessary. We (Till, Nick, and Bailey) on the TSC can assist in coordinating with the relevant groups. On behalf of the TSC, |
@ricochet Thank you and TSC for positive response. I have a submitted a change for added paragraphs according to the discussion: The SIG is not intended to fork the TypeScript language. This can be achieved by only supporting a strict subset of the language, or by ensuring that all language extensions (e.g. additions to the type system or standard library) are coordinated with the TypeScript core team and have a path to being upstreamed. This SIG follows BA's common guideline as the TSC suggested: Any APIs or new instructions that a runtime exposes to Wasm must go through a standardization process, and achieve consensus in that process, and be sufficiently stable before they can be enabled by default in any runtime under the Bytecode Alliance's umbrella. Please see if it works out all the concerns. |
@ricochet I just wanted to make sure that a reference to W3C process doesn't lead to an implication that W3C has requirements about when and how features are released by implementations 😄 That said, setting rules of engagement here is completely up to BA and there is not need to mimic W3C in any way. |
The TSC has accepted this proposed SIG! Thank you for your patience and help with tweaking the charter. If you need a We will create a Google Groups mailing list for you soon and share details once they are ready. Please do the following two things:
Thanks again! On behalf of the TSC, |
SIG-TypeScript-Compilation's primary goal is to describe and refine a suitable solution for compiling TypeScript program to WebAssembly based on the Wasm GC proposal and executing it in both browser and standalone Wasm runtime. The scope of this SIG is limited to discussions about compiling TS to WebAssembly, the necessary runtime API (potentially defined as WASI) for supporting TS language features such as Any type, and exploration of how WebAssembly can grow to provide better support of dynamic languages natively.