1

我有一些问题要理解为 haskell 高兴的解析器生成器系统的错误消息。

例如这段代码

{
module Test_parser where

import System.IO
import Test_lexer

}

%name parse

%tokentype { Token }
%error { parseError }

%token

    true                { TokenTrue posn }
    false               { TokenFalse posn }
    number              { TokenInteger posn $$ }

%%

LiteralExpr :
        true            {LiteralTrue ()}
    | false         {LiteralFalse ()}
    | number        {LiteralInteger () $1}

{

data Expression n =
    LiteralTrue n
    | LiteralFalse n
    | LiteralInteger n Integer
        deriving (Eq, Show)

parseError xs = error "Parse error"

main = do 
  inStr <- getContents
  let parseTree = parse (alexScanTokens inStr)  
  putStrLn $ show(parseTree)
}

工作正常。

但如果我做这样的事情

....

LiteralExpr :
    true            {LiteralTrue ()}
    | false         {LiteralFalse ()}
    | Inte          {$1}

Inte :
    number          {LiteralInteger () $1}


{

data Expression n =
    LiteralTrue n
    | LiteralFalse n
    | Inte n
        deriving (Eq, Show)

data Inte n =
    LiteralInteger n Integer
        deriving (Eq, Show)

....

我会收到一条巨大的错误消息。因此,如果您能帮助我理解它,那将是非常好的。

提前致谢

4

2 回答 2

2

似乎您在混淆数据构造函数和类型构造函数。Intein是一个数据构造函数,它恰好与您在下面定义Expression的数据类型具有相同的名称(并且与之无关) 。Inte

你应该有类似的东西

data Expression n =
    LiteralTrue n
    | LiteralFalse n
    | LiteralInt (Inte n)

并适当地修改您的代码(LiteralInt在需要的地方添加)。

于 2012-10-07T20:36:37.053 回答
0

好的,这就是它的方式:

...
LiteralExpr :
    true            {LiteralTrue ()}
    | false         {LiteralFalse ()}
    | Inte          {LiteralInt $1}

Inte :
    number          {LiteralInteger () $1}
...

...
data Expression n =
    LiteralTrue n
    | LiteralFalse n
    | LiteralInt (Inte n)
        deriving (Eq, Show)

data Inte n =
    LiteralInteger n Integer
        deriving (Eq, Show)
...
于 2012-10-08T08:15:32.180 回答