Это ошибка?
{-# LANGUAGE NoMonomorphismRestriction #-}
import qualified Text.Parsec.Token as P
import Text.Parsec.Language (haskellDef)
(P.TokenParser { P.identifier = ident }) = P.makeTokenParser haskellDef
дает ident
типа Text.Parsec.Prim.ParsecT String GHC.Prim.Any Data.Functor.Identity.Identity String
, тогда как определение
haskell = P.makeTokenParser haskellDef
ident = P.identifier haskell
дает один из типов Text.Parsec.Prim.ParsecT String u Data.Functor.Identity.Identity String
1012 * редактировать *
В ghci поведение не идентично,
infixl 4 <++>
(<++>) = liftM2 (++)
(P.TokenParser { P.identifier = ident }) = P.makeTokenParser haskellDef
suitable_macro = ident
parseMacro = many space *> suitable_macro
parseMacro' =
try (string "{{" *> parseMacro <* string "}}")
parseAll = many (noneOf "{") <++>
option "" (parseMacro' <|> (string "{" <++> parseAll))
Затем попробуйте запустить его,
*Hz2.Preproc> parseTest parseAll "asdf{{b}}"
<interactive>:0:11:
Couldn't match expected type `()' with actual type `GHC.Prim.Any'
Expected type: Parsec String () a0
Actual type: ParsecT
String GHC.Prim.Any Data.Functor.Identity.Identity [Char]
In the first argument of `parseTest', namely `parseAll'
In the expression: parseTest parseAll "asdf{{b}}"