是罗斯林的”.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 支持库中内置了合理默认值的语言?
@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;
}