module Synthesizer.LLVM.CausalParameterized.RingBuffer (
T, track, trackConst,
index, oldest,
) where
import Synthesizer.LLVM.RingBuffer
import qualified Synthesizer.LLVM.CausalParameterized.ProcessPrivate as CausalP
import qualified LLVM.DSL.Parameter as Param
import qualified LLVM.Extra.Marshal as Marshal
import qualified LLVM.Extra.Memory as Memory
import qualified LLVM.Extra.Tuple as Tuple
track ::
(Marshal.C a, Tuple.ValueOf a ~ al) =>
Param.T p a -> Param.T p Int -> CausalP.T p al (T al)
track initial time =
Param.withValue initial $ \getInitial valueInitial ->
Param.withValue (Param.wordInt time) $ \getTime valueTime ->
CausalP.Cons
(trackNext valueTime)
(return ())
(\(x, size) -> trackStart valueTime (valueInitial x, size))
trackStop
(trackCreate getInitial getTime)
trackDelete
trackConst :: (Memory.C al) => al -> Param.T p Int -> CausalP.T p al (T al)
trackConst initial time =
Param.withValue (Param.wordInt time) $ \getTime valueTime ->
CausalP.Cons
(trackNext valueTime)
(return ())
(\size -> trackStart valueTime (initial, size))
trackStop
(trackConstCreate getTime)
trackDelete