Diffstat (limited to 'src/walk/walkers/core/value.rs')
| -rw-r--r-- | src/walk/walkers/core/value.rs | 41 |
1 files changed, 25 insertions, 16 deletions
diff --git a/src/walk/walkers/core/value.rs b/src/walk/walkers/core/value.rs index 5ed43e0..d3f9159 100644 --- a/src/walk/walkers/core/value.rs +++ b/src/walk/walkers/core/value.rs @@ -1,4 +1,9 @@ -use effectful::{bound::IsSync, environment::{DynBind, Environment, NativeForm}, forward_send_sync}; +use effectful::{ + bound::IsSync, + effective::Effective, + environment::{DynBind, Environment, NativeForm}, + forward_send_sync, +}; use crate::{ any::{BorrowedStatic, OwnedStatic, TempBorrowedStatic}, @@ -40,9 +45,9 @@ impl<T: Copy> From<&T> for ValueWalker<T> { } } -impl<'ctx, T: 'static, E: Environment> crate::Walker<'ctx, E> for ValueWalker<T> +impl<'ctx, T: 'static, E: Environment> crate::Walker<'ctx, E> for ValueWalker<T> where - T: DynBind<E> + T: DynBind<E>, { type Error = Never; @@ -54,7 +59,9 @@ where visitor: DynVisitor<'b, 'ctx, E>, ) -> NativeForm<'c, Result<Self::Output, Self::Error>, E> { // Attempt to visit using the value protocol. - visit_value::<_, E>(visitor, OwnedStatic(self.0)).map(|_| Ok(())) + visit_value::<_, E>(visitor, OwnedStatic(self.0)) + .map((), |_, _| Ok(())) + .cast() } } @@ -76,7 +83,7 @@ impl<'ctx, T: ?Sized> BorrowWalker<'ctx, T> { impl<'ctx, T: ?Sized + DynBind<E> + 'static, E: Environment> crate::Walker<'ctx, E> for BorrowWalker<'ctx, T> where - T: IsSync<E::NeedSend> + T: IsSync<E::NeedSend>, { type Error = Never; @@ -88,16 +95,18 @@ where visitor: DynVisitor<'b, 'ctx, E>, ) -> NativeForm<'c, Result<Self::Output, Self::Error>, E> { // Attempt to visit using the value protocol. - E::as_ctx((self, visitor), |(this, visitor)| { - visit_value::<_, E>(visitor.cast(), BorrowedStatic(this.0)) - .map(VisitResult::unit_skipped) - .cast() - }) - .if_skipped(|(this, visitor)| { - visit_value::<_, E>(visitor.cast(), TempBorrowedStatic(this.0)) - .map(VisitResult::unit_skipped) - .cast() - }) - .map(|((this, _), _)| Ok(this.0)) + E::value((self, visitor)) + .update((), |_, (this, visitor)| { + visit_value::<_, E>(visitor.cast(), BorrowedStatic(this.0)) + .map((), |_, x| VisitResult::unit_skipped(x)) + .cast() + }) + .if_skipped((), |_, (this, visitor)| { + visit_value::<_, E>(visitor.cast(), TempBorrowedStatic(this.0)) + .map((), |_, x| VisitResult::unit_skipped(x)) + .cast() + }) + .map((), |_, ((this, _), _)| Ok(this.0)) + .cast() } } |