roslynAnalizza il codice sorgente con Roslyn

Analisi introspettiva di un analizzatore in C #

  1. Crea una nuova applicazione console
  2. Aggiungere il pacchetto NuGet Microsoft.CodeAnalysis
  3. Importare i namespace Microsoft.CodeAnalysis.MSBuild , System.Linq e Microsoft.CodeAnalysis.CSharp.Syntax
  4. Scrivi il seguente codice di esempio nel metodo Main :
// Declaring a variable with the current project file path.
const string projectPath = @"C:\<your path to the project\<project file name>.csproj";

// Creating a build workspace.
var workspace = MSBuildWorkspace.Create();
        
// Opening this project.
var project = workspace.OpenProjectAsync(projectPath).Result;

// Getting the compilation.
var compilation = project.GetCompilationAsync().Result;

// As this is a simple single file program, the first syntax tree will be the current file.
var syntaxTree = compilation.SyntaxTrees.First();

// Getting the root node of the file.
var rootSyntaxNode = syntaxTree.GetRootAsync().Result;

// Finding all the local variable declarations in this file and picking the first one.
var firstLocalVariablesDeclaration = rootSyntaxNode.DescendantNodesAndSelf().OfType<LocalDeclarationStatementSyntax>().First();

// Getting the first declared variable in the declaration syntax.
var firstVariable = firstLocalVariablesDeclaration.Declaration.Variables.First();

// Getting the text of the initialized value.
var variableInitializer = firstVariable.Initializer.Value.GetFirstToken().ValueText;

// This will print to screen the value assigned to the projectPath variable.
Console.WriteLine(variableInitializer);

Console.ReadKey();

Durante l'esecuzione del progetto, vedrai la variabile dichiarata in alto stampata sullo schermo. Ciò significa che hai analizzato correttamente un progetto e trovato una variabile in esso.

Analizza una semplice applicazione "Hello World" in C #

Creare una nuova applicazione console con una riga nel metodo Main : Console.WriteLine("Hello World")

Ricorda il percorso del file .csproj e sostituiscilo nell'esempio.

Creare una nuova applicazione console e installare il pacchetto NuGet Microsoft.CodeAnalysis e provare il seguente codice:

const string projectPath = @"C:\HelloWorldApplication\HelloWorldProject.csproj";

// Creating a build workspace.
var workspace = MSBuildWorkspace.Create();
        
// Opening the Hello World project.
var project = workspace.OpenProjectAsync(projectPath).Result;

// Getting the compilation.
var compilation = project.GetCompilationAsync().Result;

foreach (var tree in compilation.SyntaxTrees)
{
    Console.WriteLine(tree.FilePath);

    var rootSyntaxNode = tree.GetRootAsync().Result;

    foreach (var node in rootSyntaxNode.DescendantNodes())
    {
        Console.WriteLine($" *** {node.Kind()}");
        Console.WriteLine($"     {node}");
    }
}

Console.ReadKey();

Questo stamperà tutti i file e tutti i nodi di sintassi nel progetto Hello World .

Analizza una semplice applicazione "Hello World" in VB.NET

Creare una nuova applicazione console con una riga nel metodo Main : Console.WriteLine("Hello World")

Ricordare il percorso del file .vbproj e sostituirlo nell'esempio.

Creare una nuova applicazione console e installare il pacchetto NuGet Microsoft.CodeAnalysis e provare il seguente codice:

Const projectPath = "C:\HelloWorldApplication\HelloWorldProject.vbproj"

' Creating a build workspace.
Dim workspace = MSBuildWorkspace.Create()

' Opening the Hello World project.
Dim project = workspace.OpenProjectAsync(projectPath).Result

' Getting the compilation.
Dim compilation = project.GetCompilationAsync().Result

For Each tree In compilation.SyntaxTrees

    Console.WriteLine(tree.FilePath)

    Dim rootSyntaxNode = tree.GetRootAsync().Result

    For Each node In rootSyntaxNode.DescendantNodes()

        Console.WriteLine($" *** {node.Kind()}")
        Console.WriteLine($"     {node}")
    Next
Next

Console.ReadKey()

Questo stamperà tutti i file e tutti i nodi di sintassi nel progetto Hello World .

Analizzare il codice sorgente dal testo in C #

var syntaxTree = CSharpSyntaxTree.ParseText(
@"using System;
using System.Collections;
using System.Linq;
using System.Text;

namespace HelloWorldApplication
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine(""Hello World"");
}
}
}");

var root = syntaxTree.GetRoot() as CompilationUnitSyntax;

var namespaceSyntax = root.Members.OfType<NamespaceDeclarationSyntax>().First();
        
var programClassSyntax = namespaceSyntax.Members.OfType<ClassDeclarationSyntax>().First();

var mainMethodSyntax = programClassSyntax.Members.OfType<MethodDeclarationSyntax>().First();

Console.WriteLine(mainMethodSyntax.ToString());

Console.ReadKey();

Questo esempio stamperà il metodo Main dal testo che analizza la sintassi.

Ottieni il tipo di 'var'

Per ottenere il tipo effettivo per una variabile dichiarata utilizzando var , chiamare GetSymbolInfo() sul SemanticModel . È possibile aprire una soluzione esistente utilizzando MSBuildWorkspace , quindi enumerarne i progetti e i relativi documenti. Utilizzare un documento per ottenere la sua SyntaxRoot e SemanticModel , quindi cercare VariableDeclarations e recuperare i simboli per il Type di una variabile dichiarata in questo modo:

var workspace = MSBuildWorkspace.Create();
var solution = workspace.OpenSolutionAsync("c:\\path\\to\\solution.sln").Result;

foreach (var document in solution.Projects.SelectMany(project => project.Documents))
{
    var rootNode = document.GetSyntaxRootAsync().Result;
    var semanticModel = document.GetSemanticModelAsync().Result;

    var variableDeclarations = rootNode
            .DescendantNodes()
            .OfType<LocalDeclarationStatementSyntax>();
    foreach (var varDeclaration in variableDeclarations)
    {
        var symbolInfo = semanticModel.GetSymbolInfo(varDeclaration.Declaration.Type);
        var typeSymbol = symbolInfo.Symbol; // the type symbol for the variable..
    }
}