Safe Haskell | None |
---|---|
Language | Haskell2010 |
String formatting helpers, starting to get a bit out of control.
Synopsis
- takeEnd :: Int -> [a] -> [a]
- lowercase :: String -> String
- uppercase :: String -> String
- underline :: String -> String
- stripbrackets :: String -> String
- quoteIfNeeded :: String -> String
- singleQuoteIfNeeded :: String -> String
- words' :: String -> [String]
- unwords' :: [String] -> String
- stripAnsi :: String -> String
- strip :: String -> String
- lstrip :: String -> String
- rstrip :: String -> String
- chomp :: String -> String
- chomp1 :: String -> String
- singleline :: String -> String
- elideLeft :: Int -> String -> String
- elideRight :: Int -> String -> String
- formatString :: Bool -> Maybe Int -> Maybe Int -> String -> String
- charWidth :: Char -> Int
- strWidth :: String -> Int
- strWidthAnsi :: String -> Int
- takeWidth :: Int -> String -> String
Documentation
misc
stripbrackets :: String -> String Source #
quoteIfNeeded :: String -> String Source #
Double-quote this string if it contains whitespace, single quotes or double-quotes, escaping the quotes as needed.
singleQuoteIfNeeded :: String -> String Source #
Single-quote this string if it contains whitespace or double-quotes. No good for strings containing single quotes.
words' :: String -> [String] Source #
Quote-aware version of words - don't split on spaces which are inside quotes.
NB correctly handles "a'b" but not "'a'
". Can raise an error if parsing fails.
unwords' :: [String] -> String Source #
Quote-aware version of unwords - single-quote strings which contain whitespace
stripAnsi :: String -> String Source #
Strip ANSI escape sequences from a string.
>>>
stripAnsi "\ESC[31m-1\ESC[m"
"-1"
single-line layout
chomp1 :: String -> String Source #
Remove all trailing newline/carriage returns, leaving just one trailing newline.
singleline :: String -> String Source #
Remove consecutive line breaks, replacing them with single space
formatString :: Bool -> Maybe Int -> Maybe Int -> String -> String Source #
Clip and pad a string to a minimum & maximum width, andor leftright justify it. Works on multi-line strings too (but will rewrite non-unix line endings).
wide-character-aware layout
charWidth :: Char -> Int Source #
Get the designated render width of a character: 0 for a combining character, 1 for a regular character, 2 for a wide character. (Wide characters are rendered as exactly double width in apps and fonts that support it.) (From Pandoc.)
strWidth :: String -> Int Source #
Calculate the render width of a string, considering wide characters (counted as double width)
strWidthAnsi :: String -> Int Source #
Like strWidth, but also strips ANSI escape sequences before calculating the width.
This is no longer used in code, as widths are calculated before adding ANSI escape sequences, but is being kept around for now.