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::anon::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::anon::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::anon::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::anon::HostWithStore + Send, for<'a> D::Data<'a>: foo::foo::anon::Host + Send, T: 'static + Send,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::anon::HostWithStore + Send, 175 for<'a> D::Data<'a>: foo::foo::anon::Host + Send, 176 T: 'static + Send, 177 { 178 foo::foo::anon::add_to_linker::<T, D>(linker, host_getter)?; 179 Ok(()) 180 } foo_foo_anon(&self) -> &exports::foo::foo::anon::Guest181 pub fn foo_foo_anon(&self) -> &exports::foo::foo::anon::Guest { 182 &self.interface0 183 } 184 } 185 }; 186 pub mod foo { 187 pub mod foo { 188 #[allow(clippy::all)] 189 pub mod anon { 190 #[allow(unused_imports)] 191 use wasmtime::component::__internal::Box; 192 #[derive(wasmtime::component::ComponentType)] 193 #[derive(wasmtime::component::Lift)] 194 #[derive(wasmtime::component::Lower)] 195 #[component(enum)] 196 #[derive(Clone, Copy, Eq, PartialEq)] 197 #[repr(u8)] 198 pub enum Error { 199 #[component(name = "success")] 200 Success, 201 #[component(name = "failure")] 202 Failure, 203 } 204 impl Error { name(&self) -> &'static str205 pub fn name(&self) -> &'static str { 206 match self { 207 Error::Success => "success", 208 Error::Failure => "failure", 209 } 210 } message(&self) -> &'static str211 pub fn message(&self) -> &'static str { 212 match self { 213 Error::Success => "", 214 Error::Failure => "", 215 } 216 } 217 } 218 impl core::fmt::Debug for Error { fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result219 fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { 220 f.debug_struct("Error") 221 .field("code", &(*self as i32)) 222 .field("name", &self.name()) 223 .field("message", &self.message()) 224 .finish() 225 } 226 } 227 impl core::fmt::Display for Error { fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result228 fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { 229 write!(f, "{} (error {})", self.name(), * self as i32) 230 } 231 } 232 impl core::error::Error for Error {} 233 const _: () = { 234 assert!(1 == < Error as wasmtime::component::ComponentType >::SIZE32); 235 assert!(1 == < Error as wasmtime::component::ComponentType >::ALIGN32); 236 }; 237 pub trait HostWithStore: wasmtime::component::HasData + Send { option_test<T: Send>( accessor: &wasmtime::component::Accessor<T, Self>, ) -> impl ::core::future::Future< Output = Result< Option<wasmtime::component::__internal::String>, Error, >, > + Send238 fn option_test<T: Send>( 239 accessor: &wasmtime::component::Accessor<T, Self>, 240 ) -> impl ::core::future::Future< 241 Output = Result< 242 Option<wasmtime::component::__internal::String>, 243 Error, 244 >, 245 > + Send; 246 } 247 pub trait Host: Send {} 248 impl<_T: Host + ?Sized + Send> Host for &mut _T {} 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 + Send,249 pub fn add_to_linker<T, D>( 250 linker: &mut wasmtime::component::Linker<T>, 251 host_getter: fn(&mut T) -> D::Data<'_>, 252 ) -> wasmtime::Result<()> 253 where 254 D: HostWithStore, 255 for<'a> D::Data<'a>: Host, 256 T: 'static + Send, 257 { 258 let mut inst = linker.instance("foo:foo/anon")?; 259 inst.func_wrap_concurrent( 260 "option-test", 261 move |caller: &wasmtime::component::Accessor<T>, (): ()| { 262 wasmtime::component::__internal::Box::pin(async move { 263 let host = &caller.with_getter(host_getter); 264 let r = <D as HostWithStore>::option_test(host).await; 265 Ok((r,)) 266 }) 267 }, 268 )?; 269 Ok(()) 270 } 271 } 272 } 273 } 274 pub mod exports { 275 pub mod foo { 276 pub mod foo { 277 #[allow(clippy::all)] 278 pub mod anon { 279 #[allow(unused_imports)] 280 use wasmtime::component::__internal::Box; 281 #[derive(wasmtime::component::ComponentType)] 282 #[derive(wasmtime::component::Lift)] 283 #[derive(wasmtime::component::Lower)] 284 #[component(enum)] 285 #[derive(Clone, Copy, Eq, PartialEq)] 286 #[repr(u8)] 287 pub enum Error { 288 #[component(name = "success")] 289 Success, 290 #[component(name = "failure")] 291 Failure, 292 } 293 impl Error { name(&self) -> &'static str294 pub fn name(&self) -> &'static str { 295 match self { 296 Error::Success => "success", 297 Error::Failure => "failure", 298 } 299 } message(&self) -> &'static str300 pub fn message(&self) -> &'static str { 301 match self { 302 Error::Success => "", 303 Error::Failure => "", 304 } 305 } 306 } 307 impl core::fmt::Debug for Error { fmt( &self, f: &mut core::fmt::Formatter<'_>, ) -> core::fmt::Result308 fn fmt( 309 &self, 310 f: &mut core::fmt::Formatter<'_>, 311 ) -> core::fmt::Result { 312 f.debug_struct("Error") 313 .field("code", &(*self as i32)) 314 .field("name", &self.name()) 315 .field("message", &self.message()) 316 .finish() 317 } 318 } 319 impl core::fmt::Display for Error { fmt( &self, f: &mut core::fmt::Formatter<'_>, ) -> core::fmt::Result320 fn fmt( 321 &self, 322 f: &mut core::fmt::Formatter<'_>, 323 ) -> core::fmt::Result { 324 write!(f, "{} (error {})", self.name(), * self as i32) 325 } 326 } 327 impl core::error::Error for Error {} 328 const _: () = { 329 assert!( 330 1 == < Error as wasmtime::component::ComponentType >::SIZE32 331 ); 332 assert!( 333 1 == < Error as wasmtime::component::ComponentType >::ALIGN32 334 ); 335 }; 336 #[derive(Clone)] 337 pub struct Guest { 338 option_test: wasmtime::component::Func, 339 } 340 #[derive(Clone)] 341 pub struct GuestIndices { 342 option_test: wasmtime::component::ComponentExportIndex, 343 } 344 impl GuestIndices { 345 /// Constructor for [`GuestIndices`] which takes a 346 /// [`Component`](wasmtime::component::Component) as input and can be executed 347 /// before instantiation. 348 /// 349 /// This constructor can be used to front-load string lookups to find exports 350 /// within a component. new<_T>( _instance_pre: &wasmtime::component::InstancePre<_T>, ) -> wasmtime::Result<GuestIndices>351 pub fn new<_T>( 352 _instance_pre: &wasmtime::component::InstancePre<_T>, 353 ) -> wasmtime::Result<GuestIndices> { 354 let instance = _instance_pre 355 .component() 356 .get_export_index(None, "foo:foo/anon") 357 .ok_or_else(|| { 358 wasmtime::format_err!( 359 "no exported instance named `foo:foo/anon`" 360 ) 361 })?; 362 let mut lookup = move |name| { 363 _instance_pre 364 .component() 365 .get_export_index(Some(&instance), name) 366 .ok_or_else(|| { 367 wasmtime::format_err!( 368 "instance export `foo:foo/anon` does \ 369 not have export `{name}`" 370 ) 371 }) 372 }; 373 let _ = &mut lookup; 374 let option_test = lookup("option-test")?; 375 Ok(GuestIndices { option_test }) 376 } load( &self, mut store: impl wasmtime::AsContextMut, instance: &wasmtime::component::Instance, ) -> wasmtime::Result<Guest>377 pub fn load( 378 &self, 379 mut store: impl wasmtime::AsContextMut, 380 instance: &wasmtime::component::Instance, 381 ) -> wasmtime::Result<Guest> { 382 let _instance = instance; 383 let _instance_pre = _instance.instance_pre(&store); 384 let _instance_type = _instance_pre.instance_type(); 385 let mut store = store.as_context_mut(); 386 let _ = &mut store; 387 let option_test = *_instance 388 .get_typed_func::< 389 (), 390 ( 391 Result< 392 Option<wasmtime::component::__internal::String>, 393 Error, 394 >, 395 ), 396 >(&mut store, &self.option_test)? 397 .func(); 398 Ok(Guest { option_test }) 399 } 400 } 401 impl Guest { call_option_test<_T, _D>( &self, accessor: &wasmtime::component::Accessor<_T, _D>, ) -> wasmtime::Result< Result<Option<wasmtime::component::__internal::String>, Error>, > where _T: Send, _D: wasmtime::component::HasData,402 pub async fn call_option_test<_T, _D>( 403 &self, 404 accessor: &wasmtime::component::Accessor<_T, _D>, 405 ) -> wasmtime::Result< 406 Result<Option<wasmtime::component::__internal::String>, Error>, 407 > 408 where 409 _T: Send, 410 _D: wasmtime::component::HasData, 411 { 412 let callee = unsafe { 413 wasmtime::component::TypedFunc::< 414 (), 415 ( 416 Result< 417 Option<wasmtime::component::__internal::String>, 418 Error, 419 >, 420 ), 421 >::new_unchecked(self.option_test) 422 }; 423 let (ret0,) = callee.call_concurrent(accessor, ()).await?; 424 Ok(ret0) 425 } 426 } 427 } 428 } 429 } 430 } 431