module ADP.Fusion.Unit.Term.Epsilon where import Data.Proxy import Data.Strict.Tuple import qualified Data.Vector.Fusion.Stream.Monadic as S import GHC.Exts import Data.PrimitiveArray import ADP.Fusion.Core import ADP.Fusion.Unit.Core instance forall m pos posLeft ls i lg . ( TermStream m (Z:.pos) (TermSymbol M (Epsilon lg)) (Elm (Term1 (Elm ls (Unit i))) (Z:.Unit i)) (Z:.Unit i) , posLeft ~ LeftPosTy pos (Epsilon lg) (Unit i) , TermStaticVar pos (Epsilon lg) (Unit i) , MkStream m posLeft ls (Unit i) ) ⇒ MkStream m pos (ls :!: Epsilon lg) (Unit i) where mkStream pos (ls :!: Epsilon) grd us is = S.map (\(ss,ee,ii) -> ElmEpsilon ii ss) . addTermStream1 pos (Epsilon @lg) us is . mkStream (Proxy ∷ Proxy posLeft) ls (termStaticCheck pos (Epsilon @lg) us is grd) us $ termStreamIndex pos (Epsilon @lg) is {-# Inline mkStream #-} --instance -- ( TermStreamContext m ps ts s x0 i0 is (Unit I) -- , TermStream m ps ts (Elm x0 i0) is -- ) ⇒ TermStream m (TermSymbol ts Epsilon) s (is:.Unit I) where -- termStream (ts:|Epsilon) (cs:.IStatic ()) (us:.._) (is:._) -- = S.map (\(TState s ii ee) -> TState s (ii:.:RiU) (ee:.())) -- . termStream ts cs us is -- {-# Inline termStream #-} {- instance ( TstCtx m ts s x0 i0 is (Unit O) ) => TermStream m (TermSymbol ts Epsilon) s (is:.Unit O) where termStream (ts:|Epsilon) (cs:.OStatic ()) (us:.._) (is:._) = S.map (\(TState s ii ee) -> TState s (ii:.:RiU) (ee:.())) . termStream ts cs us is {-# Inline termStream #-} instance TermStaticVar Epsilon (Unit I) where termStaticVar _ _ _ = IStatic () termStreamIndex _ _ _ = Unit {-# Inline [0] termStaticVar #-} {-# Inline [0] termStreamIndex #-} instance TermStaticVar Epsilon (Unit O) where termStaticVar _ _ _ = OStatic () termStreamIndex _ _ _ = Unit {-# Inline [0] termStaticVar #-} {-# Inline [0] termStreamIndex #-} -}