Safe Haskell | None |
---|---|
Language | Haskell98 |
Text.StringTemplate.Classes
- data SElem a
- class Show a => StringTemplateShows a where
- class ToSElem a where
- type SMap a = Map String (SElem a)
- data STShow = StringTemplateShows a => STShow a
- newtype StFirst a = StFirst {
- stGetFirst :: Maybe a
- class Monoid a => Stringable a where
- stShowsToSE :: (StringTemplateShows a, Stringable b) => a -> SElem b
Documentation
class Show a => StringTemplateShows a where #
The StringTemplateShows class should be instantiated for all types that are directly displayed in a StringTemplate, but take an optional format string. Each such type must have an appropriate ToSElem method defined as well.
Methods
stringTemplateShow :: a -> String #
Defaults to show
.
stringTemplateFormattedShow :: String -> a -> String #
Defaults to _ a -> stringTemplateShow a
The ToSElem class should be instantiated for all types that can be inserted as attributes into a StringTemplate.
Minimal complete definition
Constructors
StringTemplateShows a => STShow a |
Constructors
StFirst | |
Fields
|
class Monoid a => Stringable a where #
The Stringable class should be instantiated with care. Generally, the provided instances should be enough for anything.
Minimal complete definition
Methods
stFromString :: String -> a #
stFromByteString :: ByteString -> a #
stFromText :: Text -> a #
stToString :: a -> String #
mconcatMap :: [b] -> (b -> a) -> a #
Defaults to mconcatMap m k = foldr (mappend . k) mempty m
mintercalate :: a -> [a] -> a #
Defaults to (mconcat .) . intersperse
Defaults to mlabel x y = mconcat [x, stFromString "[", y, stFromString "]"]
stShowsToSE :: (StringTemplateShows a, Stringable b) => a -> SElem b #
This method should be used to create ToSElem instances for types defining a custom formatted show function.