module Feldspar.Core.Constructs.MutableReference
where
import Data.IORef
import Language.Syntactic
import Language.Syntactic.Constructs.Binding
import Language.Syntactic.Constructs.Binding.HigherOrder
import Feldspar.Lattice
import Feldspar.Core.Types
import Feldspar.Core.Interpretation
import Feldspar.Core.Constructs.Binding
import Feldspar.Core.Constructs.Mutable
data MutableReference a
where
NewRef :: Type a => MutableReference (a :-> Full (Mut (IORef a)))
GetRef :: Type a => MutableReference (IORef a :-> Full (Mut a))
SetRef :: Type a => MutableReference (IORef a :-> a :-> Full (Mut ()))
ModRef :: Type a => MutableReference (IORef a :-> (a -> a) :-> Full (Mut ()))
instance Semantic MutableReference
where
semantics NewRef = Sem "newRef" newIORef
semantics GetRef = Sem "getRef" readIORef
semantics SetRef = Sem "setRef" writeIORef
semantics ModRef = Sem "modRef" (\r f -> readIORef r >>= writeIORef r . f)
semanticInstances ''MutableReference
instance EvalBind MutableReference where evalBindSym = evalBindSymDefault
instance AlphaEq dom dom dom env =>
AlphaEq MutableReference MutableReference dom env
where
alphaEqSym = alphaEqSymDefault
instance Sharable MutableReference
instance Monotonic MutableReference
instance SizeProp MutableReference
where
sizeProp NewRef _ = universal
sizeProp GetRef _ = universal
sizeProp SetRef _ = universal
sizeProp ModRef _ = universal
instance ( MutableReference :<: dom
, MONAD Mut :<: dom
, Project (CLambda Type) dom
, Project (Variable :|| Type) dom
, OptimizeSuper dom
)
=> Optimize MutableReference dom
where
constructFeatUnOpt opts ModRef (_ :* (lam :$ body) :* Nil)
| Just (SubConstr2 (Lambda v1)) <- prjLambda lam
, Just (C' (Variable v2)) <- prjF body
, v1 == v2
= constructFeatUnOptDefaultTyp opts (MutType UnitType) Return (literalDecor () :* Nil)
constructFeatUnOpt opts NewRef args = constructFeatUnOptDefaultTyp opts (MutType $ RefType typeRep) NewRef args
constructFeatUnOpt opts GetRef args = constructFeatUnOptDefaultTyp opts (MutType typeRep) GetRef args
constructFeatUnOpt opts SetRef args = constructFeatUnOptDefaultTyp opts (MutType typeRep) SetRef args
constructFeatUnOpt opts ModRef args = constructFeatUnOptDefaultTyp opts (MutType typeRep) ModRef args