From b098daf7bcb6e4a493723026f5644bd81164c641 Mon Sep 17 00:00:00 2001 From: tv Date: Fri, 6 Mar 2026 20:45:39 +0100 Subject: modularize --- src/TextViewport/Buffer/Buffer.hs | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 src/TextViewport/Buffer/Buffer.hs (limited to 'src/TextViewport/Buffer/Buffer.hs') diff --git a/src/TextViewport/Buffer/Buffer.hs b/src/TextViewport/Buffer/Buffer.hs new file mode 100644 index 0000000..7b9582f --- /dev/null +++ b/src/TextViewport/Buffer/Buffer.hs @@ -0,0 +1,35 @@ +module TextViewport.Buffer.Buffer where + +import Data.Sequence qualified as Seq +import TextViewport.Buffer.Item (Item) + +newtype Buffer = Buffer { unBuffer :: Seq.Seq Item } + deriving (Eq, Show) + +-- | Build a buffer from a list +fromList :: [Item] -> Buffer +fromList xs = Buffer (Seq.fromList xs) + +-- | Modify an item at index +modifyItem :: Int -> (Item -> Item) -> Buffer -> Buffer +modifyItem ix f (Buffer xs) = + Buffer (Seq.adjust' f ix xs) + +-- | Insert an item +insertItem :: Int -> Item -> Buffer -> Buffer +insertItem ix x (Buffer xs) = + Buffer (Seq.insertAt ix x xs) + +-- | Delete an item +deleteItem :: Int -> Buffer -> Buffer +deleteItem ix (Buffer xs) = + Buffer (Seq.deleteAt ix xs) + +-- | Append an item +appendItem :: Item -> Buffer -> Buffer +appendItem x (Buffer xs) = + Buffer (xs Seq.|> x) + +-- | Extract underlying Seq (if needed) +toSeq :: Buffer -> Seq.Seq Item +toSeq (Buffer xs) = xs -- cgit v1.2.3