Skip to content

Commit a04a6be

Browse files
committed
refactor(api): add Send + Sync trait when creating an instance + regen test
Signed-off-by: Benjamin Coenen <[email protected]>
1 parent aa626ef commit a04a6be

File tree

3 files changed

+19
-18
lines changed

3 files changed

+19
-18
lines changed

lib/engine/src/resolver.rs

+16-16
Original file line numberDiff line numberDiff line change
@@ -64,7 +64,7 @@ impl<T: NamedResolver> NamedResolver for &T {
6464
}
6565
}
6666

67-
impl NamedResolver for Box<dyn NamedResolver> {
67+
impl NamedResolver for Box<dyn NamedResolver + Send + Sync> {
6868
fn resolve_by_name(&self, module: &str, field: &str) -> Option<Export> {
6969
(**self).resolve_by_name(module, field)
7070
}
@@ -293,7 +293,7 @@ pub fn resolve_imports(
293293
}
294294

295295
/// A [`Resolver`] that links two resolvers together in a chain.
296-
pub struct NamedResolverChain<A: NamedResolver, B: NamedResolver> {
296+
pub struct NamedResolverChain<A: NamedResolver + Send + Sync, B: NamedResolver + Send + Sync> {
297297
a: A,
298298
b: B,
299299
}
@@ -303,31 +303,31 @@ pub struct NamedResolverChain<A: NamedResolver, B: NamedResolver> {
303303
/// ```
304304
/// # use wasmer_engine::{ChainableNamedResolver, NamedResolver};
305305
/// # fn chainable_test<A, B>(imports1: A, imports2: B)
306-
/// # where A: NamedResolver + Sized,
307-
/// # B: NamedResolver + Sized,
306+
/// # where A: NamedResolver + Sized + Send + Sync,
307+
/// # B: NamedResolver + Sized + Send + Sync,
308308
/// # {
309309
/// // override duplicates with imports from `imports2`
310310
/// imports1.chain_front(imports2);
311311
/// # }
312312
/// ```
313-
pub trait ChainableNamedResolver: NamedResolver + Sized {
313+
pub trait ChainableNamedResolver: NamedResolver + Sized + Send + Sync {
314314
/// Chain a resolver in front of the current resolver.
315315
///
316316
/// This will cause the second resolver to override the first.
317317
///
318318
/// ```
319319
/// # use wasmer_engine::{ChainableNamedResolver, NamedResolver};
320320
/// # fn chainable_test<A, B>(imports1: A, imports2: B)
321-
/// # where A: NamedResolver + Sized,
322-
/// # B: NamedResolver + Sized,
321+
/// # where A: NamedResolver + Sized + Send + Sync,
322+
/// # B: NamedResolver + Sized + Send + Sync,
323323
/// # {
324324
/// // override duplicates with imports from `imports2`
325325
/// imports1.chain_front(imports2);
326326
/// # }
327327
/// ```
328328
fn chain_front<U>(self, other: U) -> NamedResolverChain<U, Self>
329329
where
330-
U: NamedResolver,
330+
U: NamedResolver + Send + Sync,
331331
{
332332
NamedResolverChain { a: other, b: self }
333333
}
@@ -339,28 +339,28 @@ pub trait ChainableNamedResolver: NamedResolver + Sized {
339339
/// ```
340340
/// # use wasmer_engine::{ChainableNamedResolver, NamedResolver};
341341
/// # fn chainable_test<A, B>(imports1: A, imports2: B)
342-
/// # where A: NamedResolver + Sized,
343-
/// # B: NamedResolver + Sized,
342+
/// # where A: NamedResolver + Sized + Send + Sync,
343+
/// # B: NamedResolver + Sized + Send + Sync,
344344
/// # {
345345
/// // override duplicates with imports from `imports1`
346346
/// imports1.chain_back(imports2);
347347
/// # }
348348
/// ```
349349
fn chain_back<U>(self, other: U) -> NamedResolverChain<Self, U>
350350
where
351-
U: NamedResolver,
351+
U: NamedResolver + Send + Sync,
352352
{
353353
NamedResolverChain { a: self, b: other }
354354
}
355355
}
356356

357357
// We give these chain methods to all types implementing NamedResolver
358-
impl<T: NamedResolver> ChainableNamedResolver for T {}
358+
impl<T: NamedResolver + Send + Sync> ChainableNamedResolver for T {}
359359

360360
impl<A, B> NamedResolver for NamedResolverChain<A, B>
361361
where
362-
A: NamedResolver,
363-
B: NamedResolver,
362+
A: NamedResolver + Send + Sync,
363+
B: NamedResolver + Send + Sync,
364364
{
365365
fn resolve_by_name(&self, module: &str, field: &str) -> Option<Export> {
366366
self.a
@@ -371,8 +371,8 @@ where
371371

372372
impl<A, B> Clone for NamedResolverChain<A, B>
373373
where
374-
A: NamedResolver + Clone,
375-
B: NamedResolver + Clone,
374+
A: NamedResolver + Clone + Send + Sync,
375+
B: NamedResolver + Clone + Send + Sync,
376376
{
377377
fn clone(&self) -> Self {
378378
Self {

lib/wasi/src/lib.rs

+3-2
Original file line numberDiff line numberDiff line change
@@ -109,11 +109,12 @@ impl WasiEnv {
109109
pub fn import_object_for_all_wasi_versions(
110110
&mut self,
111111
module: &Module,
112-
) -> Result<Box<dyn NamedResolver>, WasiError> {
112+
) -> Result<Box<dyn NamedResolver + Send + Sync>, WasiError> {
113113
let wasi_versions =
114114
get_wasi_versions(module, false).ok_or(WasiError::UnknownWasiVersion)?;
115115

116-
let mut resolver: Box<dyn NamedResolver> = { Box::new(()) };
116+
let mut resolver: Box<dyn NamedResolver + Send + Sync> =
117+
{ Box::new(()) as Box<dyn NamedResolver + Send + Sync> };
117118
for version in wasi_versions.iter() {
118119
let new_import_object =
119120
generate_import_object_from_env(module.store(), self.clone(), *version);
Binary file not shown.

0 commit comments

Comments
 (0)