module Control.Monad.Imperative.Operators where
import Control.Monad.Imperative.Internals
(+=:), (*=:), (-=:) :: (HasValue r (V k r) i, Num b) => V TyVar r b -> V k r b -> MIO i r ()
(+=:) a b = modifyOp (+) a b
(*=:) a b = modifyOp (*) a b
(-=:) a b = modifyOp () a b
(%=:) :: (HasValue r (V k r) i, Integral b) => V TyVar r b -> V k r b -> MIO i r ()
(%=:) a b = modifyOp mod a b
(<.), (>.), (>=.), (<=.) :: (Ord c, HasValue r (V b1 r) i, HasValue r (V b2 r) i) => V b1 r c -> V b2 r c -> V (TyComp i TyVal) r Bool
(<.) a b = liftOp2 (<) a b
(>.) a b = liftOp2 (>) a b
(>=.) a b = liftOp2 (>=) a b
(<=.) a b = liftOp2 (<=) a b
(==.) :: (Eq c, HasValue r (V b1 r) i, HasValue r (V b2 r) i) => V b1 r c -> V b2 r c -> V (TyComp i TyVal) r Bool
(==.) a b = liftOp2 (==) a b
(+.), (-.), (*.) :: (Num c, HasValue r (V b1 r) i, HasValue r (V b2 r) i) => V b1 r c -> V b2 r c -> V (TyComp i TyVal) r c
(+.) a b = liftOp2 (+) a b
(-.) a b = liftOp2 () a b
(*.) a b = liftOp2 (*) a b
(%.) :: (Integral c, HasValue r (V b1 r) i, HasValue r (V b2 r) i) => V b1 r c -> V b2 r c -> V (TyComp i TyVal) r c
(%.) a b = liftOp2 mod a b
(/.) :: (HasValue r (V b1 r) i, HasValue r (V b2 r) i, Fractional c) => V b1 r c -> V b2 r c -> V (TyComp i TyVal) r c
(/.) a b = liftOp2 (/) a b
(&&.), (||.) :: (HasValue r (V b1 r) i , HasValue r (V b2 r) i) => V b1 r Bool -> V b2 r Bool -> V (TyComp i TyVal) r Bool
(&&.) a b = liftOp2 (&&) a b
(||.) a b = liftOp2 (||) a b
(~.) :: (HasValue r (V b r) i) => V b r Bool -> V (TyComp i TyVal) r Bool
(~.) a = C $ do
a' <- val a
return $ Lit $ not a'
liftOp2 :: (HasValue r (V b1 r) i, HasValue r (V b2 r) i) => (a -> b -> c) -> V b1 r a -> V b2 r b -> V (TyComp i TyVal) r c
liftOp2 f v1 v2 = C $ do
v1' <- val v1
v2' <- val v2
return $ Lit $ f v1' v2'