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