Roslyn:如何获取未解析类型的候选名称空间
Roslyn: How to get candidate namespaces for unresolved types
使用 Roslyn,有没有一种方法可以获得列表中每个未解析符号的候选命名空间列表?如果是这样,有没有一种方法可以对属于多个可能命名空间的具有歧义的符号执行 'best match'?
我想为文件中未解析的符号生成一个 using 语句列表。我能够使用 Roslyn : How to get unresolved types 之类的方法从语义信息中获取未解析的符号,但找不到从项目中引用的程序集中获取这些符号的命名空间的方法。
我浏览了 Roslyn Repo,看起来他们在认为用户丢失 using
时使用 SymbolFinder
检索信息:参见 here.
至于找到 "best" 匹配项,我相信这是您必须根据您认为的 "best" 匹配项来实现的内容。 Visual Studio 简单地向您显示所有候选 using
语句。
这是我快速拼凑的示例,用于演示 SymbolFinder
:
var ws = new AdhocWorkspace();
var solutionInfo = SolutionInfo.Create(SolutionId.CreateNewId();, VersionStamp.Create());
var solution = ws.AddSolution(solutionInfo);
var project = ws.AddProject("Sample", "C#");
//Add reference to mscorlib
var mscorlib = PortableExecutableReference.CreateFromAssembly(typeof(object).Assembly);
project = project.AddMetadataReference(mscorlib);
ws.TryApplyChanges(project.Solution);
string text = @"
class C
{
void M()
{
//Missing a using System;
Console.Write();
}
}";
var sourceText = SourceText.From(text);
//Add document to project
var doc = ws.AddDocument(project.Id, "NewDoc", sourceText);
var model = doc.GetSemanticModelAsync().Result;
var unresolved = doc.GetSyntaxRootAsync().Result.DescendantNodes().OfType<IdentifierNameSyntax>()
.Where(x => model.GetSymbolInfo(x).Symbol == null);
foreach (var identifier in unresolved)
{
var candidateUsings = SymbolFinder.FindDeclarationsAsync(doc.Project, identifier.Identifier.ValueText, ignoreCase: false).Result;
//Process candidate usings...
}
使用 Roslyn,有没有一种方法可以获得列表中每个未解析符号的候选命名空间列表?如果是这样,有没有一种方法可以对属于多个可能命名空间的具有歧义的符号执行 'best match'?
我想为文件中未解析的符号生成一个 using 语句列表。我能够使用 Roslyn : How to get unresolved types 之类的方法从语义信息中获取未解析的符号,但找不到从项目中引用的程序集中获取这些符号的命名空间的方法。
我浏览了 Roslyn Repo,看起来他们在认为用户丢失 using
时使用 SymbolFinder
检索信息:参见 here.
至于找到 "best" 匹配项,我相信这是您必须根据您认为的 "best" 匹配项来实现的内容。 Visual Studio 简单地向您显示所有候选 using
语句。
这是我快速拼凑的示例,用于演示 SymbolFinder
:
var ws = new AdhocWorkspace();
var solutionInfo = SolutionInfo.Create(SolutionId.CreateNewId();, VersionStamp.Create());
var solution = ws.AddSolution(solutionInfo);
var project = ws.AddProject("Sample", "C#");
//Add reference to mscorlib
var mscorlib = PortableExecutableReference.CreateFromAssembly(typeof(object).Assembly);
project = project.AddMetadataReference(mscorlib);
ws.TryApplyChanges(project.Solution);
string text = @"
class C
{
void M()
{
//Missing a using System;
Console.Write();
}
}";
var sourceText = SourceText.From(text);
//Add document to project
var doc = ws.AddDocument(project.Id, "NewDoc", sourceText);
var model = doc.GetSemanticModelAsync().Result;
var unresolved = doc.GetSyntaxRootAsync().Result.DescendantNodes().OfType<IdentifierNameSyntax>()
.Where(x => model.GetSymbolInfo(x).Symbol == null);
foreach (var identifier in unresolved)
{
var candidateUsings = SymbolFinder.FindDeclarationsAsync(doc.Project, identifier.Identifier.ValueText, ignoreCase: false).Result;
//Process candidate usings...
}