From 0c36f490719f613dc23b6632a4098bd17fb0ab7c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Roman=20Smr=C5=BE?= Date: Sat, 31 Jan 2026 17:48:55 +0100 Subject: Data structure for formatted text --- src/Erebos/TextFormat/Ansi.hs | 59 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 src/Erebos/TextFormat/Ansi.hs (limited to 'src/Erebos/TextFormat/Ansi.hs') diff --git a/src/Erebos/TextFormat/Ansi.hs b/src/Erebos/TextFormat/Ansi.hs new file mode 100644 index 0000000..504e098 --- /dev/null +++ b/src/Erebos/TextFormat/Ansi.hs @@ -0,0 +1,59 @@ +{-# LANGUAGE OverloadedStrings #-} + +module Erebos.TextFormat.Ansi ( + FormattedText, + + AnsiText(..), + renderAnsiText, +) where + +import Control.Applicative + +import Data.Text (Text) +import Data.Text qualified as T + +import Erebos.TextFormat.Types + + +newtype AnsiText = AnsiText { fromAnsiText :: Text } + +renderAnsiText :: FormattedText -> AnsiText +renderAnsiText = AnsiText . go ( Nothing, Nothing ) + where + go cur@( cfg, cbg ) = \case + PlainText text -> text + ConcatenatedText ftexts -> mconcat $ map (go cur) ftexts + FormattedText (CustomTextColor fg bg) ftext -> mconcat + [ ansiColor fg bg + , go ( fg <|> cfg, bg <|> cbg ) ftext + , ansiColor + (if fg /= cfg then cfg <|> Just DefaultColor else Nothing) + (if bg /= cbg then cbg <|> Just DefaultColor else Nothing) + ] + + +ansiColor :: Maybe Color -> Maybe Color -> Text +ansiColor Nothing Nothing = "" +ansiColor (Just fg) Nothing = "\ESC[" <> T.pack (show (colorNum fg)) <> "m" +ansiColor Nothing (Just bg) = "\ESC[" <> T.pack (show (colorNum bg + 10)) <> "m" +ansiColor (Just fg) (Just bg) = "\ESC[" <> T.pack (show (colorNum fg)) <> ";" <> T.pack (show (colorNum bg + 10)) <> "m" + +colorNum :: Color -> Int +colorNum = \case + DefaultColor -> 39 + Black -> 30 + Red -> 31 + Green -> 32 + Yellow -> 33 + Blue -> 34 + Magenta -> 35 + Cyan -> 36 + White -> 37 + BrightBlack -> 90 + BrightRed -> 91 + BrightGreen -> 92 + BrightYellow -> 93 + BrightBlue -> 94 + BrightMagenta -> 95 + BrightCyan -> 96 + BrightWhite -> 97 -- cgit v1.2.3