-- | Miscellaneous text manipulation functions.
module Text.Hakyll.Util
( trim
, stripHtml
, link
) where
import Data.Char (isSpace)
-- | Trim a string (drop spaces, tabs and newlines at both sides).
trim :: String -> String
trim = reverse . trim' . reverse . trim'
where
trim' = dropWhile isSpace
-- | Strip html tags from the given string.
stripHtml :: String -> String
stripHtml [] = []
stripHtml str = let (beforeTag, rest) = break (== '<') str
(_, afterTag) = break (== '>') rest
in beforeTag ++ stripHtml (tail' afterTag)
where
-- We need a failsafe tail function.
tail' [] = []
tail' xs = tail xs
-- | Make a HTML link.
--
-- > link "foo" "bar.html" == "foo"
link :: String -- ^ Link text.
-> String -- ^ Link destination.
-> String
link text destination = ""
++ text ++ ""