Haskell - 快乐的解析器错误

时间:2013-05-27 22:51:13

标签: parsing haskell happy

我正在开发一个使用Happy parser生成器的项目。这就是我到目前为止所做的事情:

Exp   : Exp1                    { $1 }

Exp1  : Exp1 '+' Term           { \p -> $1 p + $3 p }
      | Exp1 '-' Term           { \p -> $1 p - $3 p }
      | Term                    { $1 }

Term  : Term '*' Factor         { \p -> $1 p * $3 p }
      | Term '/' Factor         { \p -> $1 p / $3 p }
      | sqrt Factor             { \p -> sqrt $2 p }
      | Factor                  { $1 }

Factor                    
      : double                  { \p -> $1 }
      | '(' Exp ')'             { $2 }

问题是我收到以下错误:

Parser.hs:158:38:
No instance for (Floating ([a0] -> Double))
  arising from a use of `happyReduction_7'
Possible fix:
  add an instance declaration for (Floating ([a0] -> Double))
In the second argument of `happySpecReduce_2', namely
  `happyReduction_7'
In the expression: happySpecReduce_2 6 happyReduction_7
In an equation for `happyReduce_7':
    happyReduce_7 = happySpecReduce_2 6 happyReduction_7

你知道我怎么解决这个问题?

更新:我解决了它,但现在只有在我写“sqrt2”(sqrt和2之间没有空格)时它才有效;如果我写“sqrt 2”,我会得到“解析错误”。

这就是我在Alex(lex)文件中的内容:

       tokens :-

       $white+         ;
       "--".*          ;
       "sqrt"                   { \s -> TokenSqrt}
       "sin"                    { \s -> TokenSin}
       "log"                    { \s -> TokenLog}
       @doubleNumber            { \s -> TokenDouble (read s) }
       @var                     { \s -> TokenVar s }
       "+"                      { \s -> TokenPlus }
       "-"                      { \s -> TokenMinus }
       "*"                      { \s -> TokenMul }
       "/"                      { \s -> TokenDiv }
       "("                      { \s -> TokenOB }
       ")"                      { \s -> TokenCB }
       "="                      { \s -> TokenEq }

1 个答案:

答案 0 :(得分:5)

sqrt $2 p

以函数sqrt作为参数调用$2,然后将结果函数应用于参数p。这只有在sqrt可以接受函数并生成函数时才有意义,当且仅当函数有Floating实例时才会出现这种情况。因此错误信息。

您无疑打算将函数$2应用于参数p,然后将sqrt应用于您要编写的结果:

sqrt ($2 p)