mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-17 20:41:49 +03:00
36 lines
642 B
Haskell
36 lines
642 B
Haskell
|
{-# LANGUAGE NoImplicitPrelude #-}
|
||
|
|
||
|
module Hasura.GraphQL.NonEmptySeq
|
||
|
( NESeq
|
||
|
, (<|)
|
||
|
, (|>)
|
||
|
, init
|
||
|
, head
|
||
|
, toSeq
|
||
|
) where
|
||
|
|
||
|
import qualified Data.Sequence as Seq
|
||
|
import Hasura.Prelude hiding (head)
|
||
|
|
||
|
infixr 5 <|
|
||
|
infixl 5 |>
|
||
|
|
||
|
newtype NESeq a
|
||
|
= NESeq { unNESeq :: (a, Seq.Seq a)}
|
||
|
deriving (Show, Eq)
|
||
|
|
||
|
init :: a -> NESeq a
|
||
|
init a = NESeq (a, Seq.empty)
|
||
|
|
||
|
head :: NESeq a -> a
|
||
|
head = fst . unNESeq
|
||
|
|
||
|
(|>) :: NESeq a -> a -> NESeq a
|
||
|
(NESeq (h, l)) |> v = NESeq (h, l Seq.|> v)
|
||
|
|
||
|
(<|) :: a -> NESeq a -> NESeq a
|
||
|
v <| (NESeq (h, l)) = NESeq (v, h Seq.<| l)
|
||
|
|
||
|
toSeq :: NESeq a -> Seq.Seq a
|
||
|
toSeq (NESeq (v, l)) = v Seq.<| l
|