1 /// Auto-generated bindings for a pre-instantiated version of a 2 /// component which implements the world `the-world`. 3 /// 4 /// This structure is created through [`TheWorldPre::new`] which 5 /// takes a [`InstancePre`](wasmtime::component::InstancePre) that 6 /// has been created through a [`Linker`](wasmtime::component::Linker). 7 /// 8 /// For more information see [`TheWorld`] as well. 9 pub struct TheWorldPre<T: 'static> { 10 instance_pre: wasmtime::component::InstancePre<T>, 11 indices: TheWorldIndices, 12 } 13 impl<T: 'static> Clone for TheWorldPre<T> { clone(&self) -> Self14 fn clone(&self) -> Self { 15 Self { 16 instance_pre: self.instance_pre.clone(), 17 indices: self.indices.clone(), 18 } 19 } 20 } 21 impl<_T: 'static> TheWorldPre<_T> { 22 /// Creates a new copy of `TheWorldPre` bindings which can then 23 /// be used to instantiate into a particular store. 24 /// 25 /// This method may fail if the component behind `instance_pre` 26 /// does not have the required exports. new( instance_pre: wasmtime::component::InstancePre<_T>, ) -> wasmtime::Result<Self>27 pub fn new( 28 instance_pre: wasmtime::component::InstancePre<_T>, 29 ) -> wasmtime::Result<Self> { 30 let indices = TheWorldIndices::new(&instance_pre)?; 31 Ok(Self { instance_pre, indices }) 32 } engine(&self) -> &wasmtime::Engine33 pub fn engine(&self) -> &wasmtime::Engine { 34 self.instance_pre.engine() 35 } instance_pre(&self) -> &wasmtime::component::InstancePre<_T>36 pub fn instance_pre(&self) -> &wasmtime::component::InstancePre<_T> { 37 &self.instance_pre 38 } 39 /// Instantiates a new instance of [`TheWorld`] within the 40 /// `store` provided. 41 /// 42 /// This function will use `self` as the pre-instantiated 43 /// instance to perform instantiation. Afterwards the preloaded 44 /// indices in `self` are used to lookup all exports on the 45 /// resulting instance. instantiate( &self, mut store: impl wasmtime::AsContextMut<Data = _T>, ) -> wasmtime::Result<TheWorld>46 pub fn instantiate( 47 &self, 48 mut store: impl wasmtime::AsContextMut<Data = _T>, 49 ) -> wasmtime::Result<TheWorld> { 50 let mut store = store.as_context_mut(); 51 let instance = self.instance_pre.instantiate(&mut store)?; 52 self.indices.load(&mut store, &instance) 53 } 54 } 55 impl<_T: Send + 'static> TheWorldPre<_T> { 56 /// Same as [`Self::instantiate`], except with `async`. instantiate_async( &self, mut store: impl wasmtime::AsContextMut<Data = _T>, ) -> wasmtime::Result<TheWorld>57 pub async fn instantiate_async( 58 &self, 59 mut store: impl wasmtime::AsContextMut<Data = _T>, 60 ) -> wasmtime::Result<TheWorld> { 61 let mut store = store.as_context_mut(); 62 let instance = self.instance_pre.instantiate_async(&mut store).await?; 63 self.indices.load(&mut store, &instance) 64 } 65 } 66 /// Auto-generated bindings for index of the exports of 67 /// `the-world`. 68 /// 69 /// This is an implementation detail of [`TheWorldPre`] and can 70 /// be constructed if needed as well. 71 /// 72 /// For more information see [`TheWorld`] as well. 73 #[derive(Clone)] 74 pub struct TheWorldIndices { 75 interface0: exports::foo::foo::chars::GuestIndices, 76 } 77 /// Auto-generated bindings for an instance a component which 78 /// implements the world `the-world`. 79 /// 80 /// This structure can be created through a number of means 81 /// depending on your requirements and what you have on hand: 82 /// 83 /// * The most convenient way is to use 84 /// [`TheWorld::instantiate`] which only needs a 85 /// [`Store`], [`Component`], and [`Linker`]. 86 /// 87 /// * Alternatively you can create a [`TheWorldPre`] ahead of 88 /// time with a [`Component`] to front-load string lookups 89 /// of exports once instead of per-instantiation. This 90 /// method then uses [`TheWorldPre::instantiate`] to 91 /// create a [`TheWorld`]. 92 /// 93 /// * If you've instantiated the instance yourself already 94 /// then you can use [`TheWorld::new`]. 95 /// 96 /// These methods are all equivalent to one another and move 97 /// around the tradeoff of what work is performed when. 98 /// 99 /// [`Store`]: wasmtime::Store 100 /// [`Component`]: wasmtime::component::Component 101 /// [`Linker`]: wasmtime::component::Linker 102 pub struct TheWorld { 103 interface0: exports::foo::foo::chars::Guest, 104 } 105 const _: () = { 106 impl TheWorldIndices { 107 /// Creates a new copy of `TheWorldIndices` bindings which can then 108 /// be used to instantiate into a particular store. 109 /// 110 /// This method may fail if the component does not have the 111 /// required exports. new<_T>( _instance_pre: &wasmtime::component::InstancePre<_T>, ) -> wasmtime::Result<Self>112 pub fn new<_T>( 113 _instance_pre: &wasmtime::component::InstancePre<_T>, 114 ) -> wasmtime::Result<Self> { 115 let _component = _instance_pre.component(); 116 let _instance_type = _instance_pre.instance_type(); 117 let interface0 = exports::foo::foo::chars::GuestIndices::new(_instance_pre)?; 118 Ok(TheWorldIndices { interface0 }) 119 } 120 /// Uses the indices stored in `self` to load an instance 121 /// of [`TheWorld`] from the instance provided. 122 /// 123 /// Note that at this time this method will additionally 124 /// perform type-checks of all exports. load( &self, mut store: impl wasmtime::AsContextMut, instance: &wasmtime::component::Instance, ) -> wasmtime::Result<TheWorld>125 pub fn load( 126 &self, 127 mut store: impl wasmtime::AsContextMut, 128 instance: &wasmtime::component::Instance, 129 ) -> wasmtime::Result<TheWorld> { 130 let _ = &mut store; 131 let _instance = instance; 132 let interface0 = self.interface0.load(&mut store, &_instance)?; 133 Ok(TheWorld { interface0 }) 134 } 135 } 136 impl TheWorld { 137 /// Convenience wrapper around [`TheWorldPre::new`] and 138 /// [`TheWorldPre::instantiate`]. instantiate<_T>( store: impl wasmtime::AsContextMut<Data = _T>, component: &wasmtime::component::Component, linker: &wasmtime::component::Linker<_T>, ) -> wasmtime::Result<TheWorld>139 pub fn instantiate<_T>( 140 store: impl wasmtime::AsContextMut<Data = _T>, 141 component: &wasmtime::component::Component, 142 linker: &wasmtime::component::Linker<_T>, 143 ) -> wasmtime::Result<TheWorld> { 144 let pre = linker.instantiate_pre(component)?; 145 TheWorldPre::new(pre)?.instantiate(store) 146 } 147 /// Convenience wrapper around [`TheWorldIndices::new`] and 148 /// [`TheWorldIndices::load`]. new( mut store: impl wasmtime::AsContextMut, instance: &wasmtime::component::Instance, ) -> wasmtime::Result<TheWorld>149 pub fn new( 150 mut store: impl wasmtime::AsContextMut, 151 instance: &wasmtime::component::Instance, 152 ) -> wasmtime::Result<TheWorld> { 153 let indices = TheWorldIndices::new(&instance.instance_pre(&store))?; 154 indices.load(&mut store, instance) 155 } 156 /// Convenience wrapper around [`TheWorldPre::new`] and 157 /// [`TheWorldPre::instantiate_async`]. instantiate_async<_T>( store: impl wasmtime::AsContextMut<Data = _T>, component: &wasmtime::component::Component, linker: &wasmtime::component::Linker<_T>, ) -> wasmtime::Result<TheWorld> where _T: Send,158 pub async fn instantiate_async<_T>( 159 store: impl wasmtime::AsContextMut<Data = _T>, 160 component: &wasmtime::component::Component, 161 linker: &wasmtime::component::Linker<_T>, 162 ) -> wasmtime::Result<TheWorld> 163 where 164 _T: Send, 165 { 166 let pre = linker.instantiate_pre(component)?; 167 TheWorldPre::new(pre)?.instantiate_async(store).await 168 } add_to_linker<T, D>( linker: &mut wasmtime::component::Linker<T>, host_getter: fn(&mut T) -> D::Data<'_>, ) -> wasmtime::Result<()> where D: foo::foo::chars::HostWithStore, for<'a> D::Data<'a>: foo::foo::chars::Host, T: 'static,169 pub fn add_to_linker<T, D>( 170 linker: &mut wasmtime::component::Linker<T>, 171 host_getter: fn(&mut T) -> D::Data<'_>, 172 ) -> wasmtime::Result<()> 173 where 174 D: foo::foo::chars::HostWithStore, 175 for<'a> D::Data<'a>: foo::foo::chars::Host, 176 T: 'static, 177 { 178 foo::foo::chars::add_to_linker::<T, D>(linker, host_getter)?; 179 Ok(()) 180 } foo_foo_chars(&self) -> &exports::foo::foo::chars::Guest181 pub fn foo_foo_chars(&self) -> &exports::foo::foo::chars::Guest { 182 &self.interface0 183 } 184 } 185 }; 186 pub mod foo { 187 pub mod foo { 188 #[allow(clippy::all)] 189 pub mod chars { 190 #[allow(unused_imports)] 191 use wasmtime::component::__internal::Box; 192 pub trait HostWithStore: wasmtime::component::HasData {} 193 impl<_T: ?Sized> HostWithStore for _T 194 where 195 _T: wasmtime::component::HasData, 196 {} 197 pub trait Host { 198 /// A function that accepts a character take_char(&mut self, x: char) -> ()199 fn take_char(&mut self, x: char) -> (); 200 /// A function that returns a character return_char(&mut self) -> char201 fn return_char(&mut self) -> char; 202 } 203 impl<_T: Host + ?Sized> Host for &mut _T { 204 /// A function that accepts a character take_char(&mut self, x: char) -> ()205 fn take_char(&mut self, x: char) -> () { 206 Host::take_char(*self, x) 207 } 208 /// A function that returns a character return_char(&mut self) -> char209 fn return_char(&mut self) -> char { 210 Host::return_char(*self) 211 } 212 } add_to_linker<T, D>( linker: &mut wasmtime::component::Linker<T>, host_getter: fn(&mut T) -> D::Data<'_>, ) -> wasmtime::Result<()> where D: HostWithStore, for<'a> D::Data<'a>: Host, T: 'static,213 pub fn add_to_linker<T, D>( 214 linker: &mut wasmtime::component::Linker<T>, 215 host_getter: fn(&mut T) -> D::Data<'_>, 216 ) -> wasmtime::Result<()> 217 where 218 D: HostWithStore, 219 for<'a> D::Data<'a>: Host, 220 T: 'static, 221 { 222 let mut inst = linker.instance("foo:foo/chars")?; 223 inst.func_wrap( 224 "take-char", 225 move | 226 mut caller: wasmtime::StoreContextMut<'_, T>, 227 (arg0,): (char,)| 228 { 229 let host = &mut host_getter(caller.data_mut()); 230 let r = Host::take_char(host, arg0); 231 Ok(r) 232 }, 233 )?; 234 inst.func_wrap( 235 "return-char", 236 move |mut caller: wasmtime::StoreContextMut<'_, T>, (): ()| { 237 let host = &mut host_getter(caller.data_mut()); 238 let r = Host::return_char(host); 239 Ok((r,)) 240 }, 241 )?; 242 Ok(()) 243 } 244 } 245 } 246 } 247 pub mod exports { 248 pub mod foo { 249 pub mod foo { 250 #[allow(clippy::all)] 251 pub mod chars { 252 #[allow(unused_imports)] 253 use wasmtime::component::__internal::Box; 254 #[derive(Clone)] 255 pub struct Guest { 256 take_char: wasmtime::component::Func, 257 return_char: wasmtime::component::Func, 258 } 259 #[derive(Clone)] 260 pub struct GuestIndices { 261 take_char: wasmtime::component::ComponentExportIndex, 262 return_char: wasmtime::component::ComponentExportIndex, 263 } 264 impl GuestIndices { 265 /// Constructor for [`GuestIndices`] which takes a 266 /// [`Component`](wasmtime::component::Component) as input and can be executed 267 /// before instantiation. 268 /// 269 /// This constructor can be used to front-load string lookups to find exports 270 /// within a component. new<_T>( _instance_pre: &wasmtime::component::InstancePre<_T>, ) -> wasmtime::Result<GuestIndices>271 pub fn new<_T>( 272 _instance_pre: &wasmtime::component::InstancePre<_T>, 273 ) -> wasmtime::Result<GuestIndices> { 274 let instance = _instance_pre 275 .component() 276 .get_export_index(None, "foo:foo/chars") 277 .ok_or_else(|| { 278 wasmtime::format_err!( 279 "no exported instance named `foo:foo/chars`" 280 ) 281 })?; 282 let mut lookup = move |name| { 283 _instance_pre 284 .component() 285 .get_export_index(Some(&instance), name) 286 .ok_or_else(|| { 287 wasmtime::format_err!( 288 "instance export `foo:foo/chars` does \ 289 not have export `{name}`" 290 ) 291 }) 292 }; 293 let _ = &mut lookup; 294 let take_char = lookup("take-char")?; 295 let return_char = lookup("return-char")?; 296 Ok(GuestIndices { 297 take_char, 298 return_char, 299 }) 300 } load( &self, mut store: impl wasmtime::AsContextMut, instance: &wasmtime::component::Instance, ) -> wasmtime::Result<Guest>301 pub fn load( 302 &self, 303 mut store: impl wasmtime::AsContextMut, 304 instance: &wasmtime::component::Instance, 305 ) -> wasmtime::Result<Guest> { 306 let _instance = instance; 307 let _instance_pre = _instance.instance_pre(&store); 308 let _instance_type = _instance_pre.instance_type(); 309 let mut store = store.as_context_mut(); 310 let _ = &mut store; 311 let take_char = *_instance 312 .get_typed_func::<(char,), ()>(&mut store, &self.take_char)? 313 .func(); 314 let return_char = *_instance 315 .get_typed_func::< 316 (), 317 (char,), 318 >(&mut store, &self.return_char)? 319 .func(); 320 Ok(Guest { take_char, return_char }) 321 } 322 } 323 impl Guest { 324 /// A function that accepts a character call_take_char<S: wasmtime::AsContextMut>( &self, mut store: S, arg0: char, ) -> wasmtime::Result<()>325 pub fn call_take_char<S: wasmtime::AsContextMut>( 326 &self, 327 mut store: S, 328 arg0: char, 329 ) -> wasmtime::Result<()> { 330 let callee = unsafe { 331 wasmtime::component::TypedFunc::< 332 (char,), 333 (), 334 >::new_unchecked(self.take_char) 335 }; 336 let () = callee.call(store.as_context_mut(), (arg0,))?; 337 Ok(()) 338 } 339 /// A function that returns a character call_return_char<S: wasmtime::AsContextMut>( &self, mut store: S, ) -> wasmtime::Result<char>340 pub fn call_return_char<S: wasmtime::AsContextMut>( 341 &self, 342 mut store: S, 343 ) -> wasmtime::Result<char> { 344 let callee = unsafe { 345 wasmtime::component::TypedFunc::< 346 (), 347 (char,), 348 >::new_unchecked(self.return_char) 349 }; 350 let (ret0,) = callee.call(store.as_context_mut(), ())?; 351 Ok(ret0) 352 } 353 } 354 } 355 } 356 } 357 } 358