F#编译器服务错误地解析程序

时间:2016-03-21 18:26:54

标签: f# f#-compiler-services

UPDATE:

我现在意识到这个问题很愚蠢,我本应该提出这个问题。事后来看,我不明白为什么我甚至都会问这个问题 问题出在这里:https://github.com/fsharp/FSharp.Compiler.Service/issues/544

原始问题:

我使用FSharp编译器服务来解析一些F#代码 我现在面对的特定代码是:

  let f x y = x+y
  let g = f 1
  let h = (g 2) + 3

此程序在最后一行没有(+)调用的情况下产生TAST。也就是说,编译器服务返回TAST,就好像最后一行只是let h = g 2

问题是:这是一个我应该报告的合法错误,还是我错过了什么?

一些注释

  1. Here is a repo包含最少的repro(我不想将它包含在这个问题中,因为编译器服务需要相当多的跳舞)。
  2. let h行之后
  3. Adding more statements不会改变结果。
  4. 当编译为IL(而不是使用编译器服务解析)时,它似乎按预期工作(例如,见fiddle
  5. If I make g a value,程序正确解析。
  6. If I make g a normal function(而不是部分应用),程序正确解析。

1 个答案:

答案 0 :(得分:7)

我没有使用FSharp.Compiler.Services的先验经验,但我使用Visual Studio的调试器进行了一些小调查。我分析了以下字符串的抽象语法树:

            """
              module X

              let f x y = x+y
              let g = f 1
              let h = (g 2) + 3
            """ 

我发现里面有以下物品:

App (Val (op_Addition,NormalValUse,D:\file.fs (6,32--6,33) IsSynthetic=false),TType_forall ([T1; T2; T3],TType_fun (TType_var T1,TType_fun (...,...))),...,...,...)

正如您所看到的,在32和33之间的第6行 行中添加了一个。

最有可能的解释为什么F#Interactive没有正确显示它是一个库中的错误(可能AST处于不一致状态或漂亮的打印被打破)。我认为您应该在project's issue tracker中提交错误。

更新:

上述对象可以通过以下方式在debbuger中获得:

error.[0] 
(option of Microsoft.FSharp.Compiler.SourceCodeServices.FSharpImplementationFileDeclaration.Entity) 
.Item2 
.[2]
(option of Microsoft.FSharp.Compiler.SourceCodeServices.FSharpImplementationFileDeclaration.MemberOrFunctionOrValue)
.Item3
.f (private member)
.Value
(option of Microsoft.FSharp.Compiler.SourceCodeServices.FSharpExprConvert.ConvExprOnDemand@903)
.expr