From ee077944ca0b374a222dfc750855f238c08a59d2 Mon Sep 17 00:00:00 2001 From: Rob Rix Date: Mon, 22 Oct 2018 12:45:36 -0400 Subject: [PATCH] Generalize the Abstract.Boolean smart constructors. --- src/Control/Abstract/Value.hs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Control/Abstract/Value.hs b/src/Control/Abstract/Value.hs index f66d21156..466a217b6 100644 --- a/src/Control/Abstract/Value.hs +++ b/src/Control/Abstract/Value.hs @@ -114,15 +114,15 @@ newtype FunctionC term address value m a = FunctionC { runFunctionC :: (term -> -- | Construct a boolean value in the abstract domain. -boolean :: (Member (Boolean value) sig, Carrier sig m) => Bool -> Evaluator term address value m value +boolean :: (Member (Boolean value) sig, Carrier sig m) => Bool -> m value boolean = send . flip Boolean ret -- | Extract a 'Bool' from a given value. -asBool :: (Member (Boolean value) sig, Carrier sig m) => value -> Evaluator term address value m Bool +asBool :: (Member (Boolean value) sig, Carrier sig m) => value -> m Bool asBool = send . flip AsBool ret -- | Eliminate boolean values. TODO: s/boolean/truthy -ifthenelse :: (Member (Boolean value) sig, Carrier sig m) => value -> Evaluator term address value m a -> Evaluator term address value m a -> Evaluator term address value m a +ifthenelse :: (Member (Boolean value) sig, Carrier sig m, Monad m) => value -> m a -> m a -> m a ifthenelse v t e = asBool v >>= \ c -> if c then t else e -- | Compute the disjunction (boolean or) of two computed values. This should have short-circuiting semantics where applicable.