module Staversion.Internal.Megaparsec
( module Text.Megaparsec,
Parser,
#if MIN_VERSION_megaparsec(6,0,0)
module Text.Megaparsec.Char,
string,
string'
#endif
) where
import Text.Megaparsec
#if MIN_VERSION_megaparsec(6,0,0)
import Data.Text (Text, pack, unpack)
import Data.Void (Void)
import Text.Megaparsec.Char hiding (string, string')
import qualified Text.Megaparsec.Char as MC
type Parser = Parsec (ErrorFancy Void) Text
liftToString :: Monad m => (Text -> m Text) -> String -> m String
liftToString f = fmap unpack . f . pack
string :: String -> Parser String
string = liftToString MC.string
string' :: String -> Parser String
string' = liftToString MC.string'
#else
import Data.Text (Text)
type Parser = Parsec Dec Text
#endif