是罗斯林的”.WithFooToken()“调用多余

本文关键字:调用 多余 调用多余 罗斯林 WithFooToken | 更新日期: 2023-09-27 18:35:49

我正在使用LinqPad来运行片段来尝试Roslyn的代码生成功能。林克帕德的 .Dump() 扩展方法将对象的格式化视图呈现到"结果"窗格。

http://roslynquoter.azurewebsites.net/生成的代码包括许多代码,这些代码除了增加膨胀之外似乎没有太多作用。以下代码输出return null;是否注释掉.WithFooToken(...)调用。

using Microsoft.CodeAnalysis;
using Microsoft.CodeAnalysis.CSharp;
using Microsoft.CodeAnalysis.CSharp.Syntax;
var syn =
    SyntaxFactory.ReturnStatement(
        SyntaxFactory.LiteralExpression(SyntaxKind.NullLiteralExpression)
//          .WithToken(SyntaxFactory.Token(SyntaxKind.NullKeyword))
    )
//  .WithReturnKeyword(
//      SyntaxFactory.Token(SyntaxKind.ReturnKeyword)
//  )
//  .WithSemicolonToken(
//      SyntaxFactory.Token(SyntaxKind.SemicolonToken)
//  )
;
syn.NormalizeWhitespace().ToFullString().Dump();

此类调用是对所有语言都是可选的,还是仅适用于在其 Roslyn 支持库中内置了合理默认值的语言?

是罗斯林的”.WithFooToken()“调用多余

@svick的答案是正确的。我只是忘了重新启用该代码,因为 Roslyn 脚本不可用。

现在脚本是公开的,我重新启用了该代码并更新了网站:http://roslynquoter.azurewebsites.net/

立即试用该网站,上面提到的冗余调用应该消失(当需要修改琐事/评论/等时,它们仍然会出现)。

是的,在简单的情况下,这些调用是不必要的。RoslynQuoter的代码具有RemoveRedundantModifyingCalls选项,我相信它应该完全按照您想要的方式进行。但它没有实现,唯一的用法被注释掉了:

private void AddModifyingCall(ApiCall apiCall, MethodCall methodCall)
{
    // TODO: this needs scripting
    ////if (RemoveRedundantModifyingCalls)
    ////{
    ////    var before = Evaluate(apiCall, UseDefaultFormatting);
    ////    apiCall.Add(methodCall);
    ////    var after = Evaluate(apiCall, UseDefaultFormatting);
    ////    if (before == after)
    ////    {
    ////        apiCall.Remove(methodCall);
    ////    }
    ////}
    apiCall.Add(methodCall);
    return;
}