在早期版本(Roslyn CTP)中,我使用以下代码来格式化我生成的代码,它工作得很好:
SyntaxNode.Format(FormattingOptions.GetDefaultOptions()).GetFormattedRoot()
使用新的Roslyn版本它不再适用,那么新版本(SDK预览版)中上述代码的等价物是什么?
答案 0 :(得分:11)
您可以使用SyntaxNodes
格式化Microsoft.CodeAnalysis.Formatting.Formatter
(如果您有工作区):
using Microsoft.CodeAnalysis.Formatting;
var formattedResult = Formatter.Format(syntaxNode, workspace);
编辑:正如Jeroen在评论中所写,如果您没有工作区且不需要特定于工作区的格式设置,您只需创建一个:
var workspace = MSBuildWorkspace.Create();
答案 1 :(得分:2)
文档现在位于:https://roslyn.codeplex.com/
点击https://roslyn.codeplex.com/documentation的链接,点击"样本和演练",然后打开演示解决方案" FormatSolution - 一个控制台应用程序,格式化所有C#和VB源文件一个解决方案。"。
不幸的是,我不认为可以快速进行格式化工作,因为您必须将代码添加到新解决方案中。
答案 2 :(得分:0)
我认为这对你有用。
var syntaxTree = CSharpSyntaxTree.ParseText(finalProgramText);
var compilationRoot = syntaxTree.GetCompilationUnitRoot();
/*
MSBuildLocator.RegisterDefaults();
var workspace = MSBuildWorkspace.Create();
var sharpTree = CSharpSyntaxTree.ParseText(programText);
var formattedNode = Formatter.Format(sharpTree.GetRoot(), workspace);
var fullText = formattedNode.ToFullString();
*/
var nameSpaces = from n in compilationRoot.DescendantNodes().OfType<UsingDirectiveSyntax>() select n;
var usings = compilationRoot.Usings.AddRange(nameSpaces);
var propertyNodes = (from field in compilationRoot.DescendantNodes().OfType<PropertyDeclarationSyntax>() select field).ToList();
var st = new SyntaxTrivia();
var withoutProperty = compilationRoot.ReplaceNodes(propertyNodes, (syntax, declarationSyntax) => null).NormalizeWhitespace();
var withoutPropText = withoutProperty.GetText().ToString();
var tree = CSharpSyntaxTree.ParseText(withoutPropText);
var root = tree.GetCompilationUnitRoot();
var commentTrivia = from t in root.DescendantTrivia()
where t.IsKind(SyntaxKind.SingleLineCommentTrivia)
|| t.IsKind(SyntaxKind.MultiLineCommentTrivia)
|| t.IsKind(SyntaxKind.EndRegionDirectiveTrivia)
|| t.IsKind(SyntaxKind.RegionDirectiveTrivia)
|| t.IsKind(SyntaxKind.PragmaChecksumDirectiveTrivia)
|| t.IsKind(SyntaxKind.PragmaWarningDirectiveTrivia)
|| t.IsKind(SyntaxKind.PragmaKeyword)
|| t.IsKind(SyntaxKind.EmptyStatement)
|| t.IsKind(SyntaxKind.XmlComment)
|| t.IsKind(SyntaxKind.SingleLineDocumentationCommentTrivia)
|| t.IsKind(SyntaxKind.AttributeList)
select t;
var newRoot = root.ReplaceTrivia(commentTrivia, (t1, t2) => st).NormalizeWhitespace();
var text = newRoot.GetText().ToString();
var attrTree = CSharpSyntaxTree.ParseText(text);
var attrRoot = attrTree.GetCompilationUnitRoot();
var attrList = from a in attrRoot.DescendantNodes().OfType<AttributeListSyntax>() select a;
var methodList = (from m in attrRoot.DescendantNodes().OfType<MethodDeclarationSyntax>()
where m.ExpressionBody != null
select m).ToList();
var normalMethods = (from m in attrRoot.DescendantNodes().OfType<MethodDeclarationSyntax>()
where m.ExpressionBody == null
select m).ToList();
Console.WriteLine(normalMethods.Count);
var withoutAttrList = attrRoot.ReplaceNodes(attrList, (syntax, listSyntax) => null).NormalizeWhitespace()
.GetText().ToString();
var fieldTree = CSharpSyntaxTree.ParseText(withoutAttrList);
var fieldRoot = fieldTree.GetCompilationUnitRoot();
var fieldsList = (from field in fieldRoot.DescendantNodes().OfType<FieldDeclarationSyntax>() select field).ToList();
var withoutFields = fieldRoot.ReplaceNodes(fieldsList, (syntax, declarationSyntax) => null);
var plainTextLines = withoutFields.NormalizeWhitespace().GetText().ToString().Split('\n')
.Where(d => !usings.Any(u => d.Trim('\r', ' ').Equals(u.ToString())) && !string.IsNullOrEmpty(d.Trim('\r', ' '))
&& !Regex.IsMatch(d.Trim('\r', ' '), @"^([;()\[\]]+)$")
).Select(s => Regex.Replace(s.TrimEnd('\r', '\n', ' '), "\\s+", " ")).ToList();
Console.WriteLine(plainTextLines);