Hey all; I just found some terminology used in wasi:http
which seems to deviate from the terminology used in the specifications. By itself it's a pretty minor thing, but assuming it's something we'd want to change it leads to a much broader question: How do we want to navigate API changes within a WASI release family (e.g. WASI 0.2.x
)?
https://github.com/WebAssembly/wasi-http/issues/107
At the bottom of that issue I've laid out a rough flow I think we could adopt for changes like these. Ensuring we can adopt changes as we go, but ensure we do not violate our backwards-compatibility guarantees for WASI 0.2.x either. This would depend on having some WIT-native mechanism to mark APIs as deprecated, which I'm not sure has come up before?
This seems like a pretty broad issue as it comes to the evolution of our WASI worlds, and so I wanted to broach that topic with this issue as a motivating example. I'm sure this will come up more often in the future, so I figured it would be worth raising sooner. Keen to hear what folks think!
hey Yosh! I think what you laid out there makes sense for this kind of case. For another, somewhat broader kind, I recently filed an issue for the component model about introducing support for aliases. Would be interested in hearing your take on that!
@Till Schneidereit oh yeah that makes sense to me - it sounds like having something like that could indeed be used to implement the solution for the issue I filed
Do we have a sense yet for what we'd like the notation to look for this? I assume aliasing would be one use case, but generally notations might even be broader than that?
(not to expand the scope further haha - but that seems like it might be the first thing missing which we'd need a solution to?)
I agree that this would ideally want to be part of a larger annotations solution, yes. IMO it'd make sense to do something informed by existing annotations syntax—be it Rust's, TypeScripts, or whatever. I haven't really dug into the syntax design myself though
Last updated: Jan 24 2025 at 00:11 UTC