{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE TypeSynonymInstances #-}
{-# LANGUAGE OverloadedStrings #-}
module Miso.String
( ToMisoString (..)
, MisoString
, module Data.Monoid
, module Data.Text
, ms
) where
import qualified Data.ByteString as B
import qualified Data.ByteString.Lazy as BL
import Data.Monoid
import Data.Text
import qualified Data.Text as T
import qualified Data.Text.Encoding as T
import qualified Data.Text.Lazy as LT
import qualified Data.Text.Lazy.Encoding as LT
type MisoString = Text
class ToMisoString str where
toMisoString :: str -> MisoString
fromMisoString :: MisoString -> str
ms :: ToMisoString str => str -> MisoString
ms = toMisoString
instance ToMisoString MisoString where
toMisoString = id
fromMisoString = id
instance ToMisoString String where
toMisoString = T.pack
fromMisoString = T.unpack
instance ToMisoString LT.Text where
toMisoString = LT.toStrict
fromMisoString = LT.fromStrict
instance ToMisoString B.ByteString where
toMisoString = toMisoString . T.decodeUtf8
fromMisoString = T.encodeUtf8 . fromMisoString
instance ToMisoString BL.ByteString where
toMisoString = toMisoString . LT.decodeUtf8
fromMisoString = LT.encodeUtf8 . fromMisoString