Yup. Możesz użyć interfejsu API DataFlowAnalysis
.
var tree = CSharpSyntaxTree.ParseText(
@"
class C{
void M(){
var x = ""foo"";
var a = new string[0];
var testing = a.Any(i => i == x);
}
}
");
var Mscorlib = PortableExecutableReference.CreateFromAssembly(typeof(object).Assembly);
var compilation = CSharpCompilation.Create("MyCompilation",
syntaxTrees: new[] { tree }, references: new[] { Mscorlib });
var model = compilation.GetSemanticModel(tree);
var lambda = tree.GetRoot().DescendantNodes().OfType<LocalDeclarationStatementSyntax>().Last();
var dataFlowAnalysis = model.AnalyzeDataFlow(lambda);
var capturedVariables = dataFlowAnalysis.Captured;
foreach(var variable in capturedVariables)
{
//Do something
}
'x' będzie pole pewnej klasy zamknięcia, jeśli jest to wolny/zmiennej niewoli. – leppie
Spójrz na [RoslynClrHeapAllocationAnalyzer] (https://github.com/mjsabby/RoslynClrHeapAllocationAnalyzer). Analizuje przydziały pamięci, a także zamknięcia. –
@YuvalItzchakov dzięki za link, teraz jasne, że muszę sprawdzić właściwość 'Captured' obiektu' DataFlowAnalysis', który mogę pobrać z 'SemanticModel'. – Seldon