.Net Core 你必須知道的source-generators

源生成器是 C# 9 中引入的一項功能,允許在編譯過程中動態生成代碼

它們直接與 C# 編譯器集成(Roslyn)並在編譯時運行,分析源代碼並根據分析結果生成附加代碼

源生成器提供了一種簡化的自動化代碼生成方法,無需外部工具或單獨的預編譯步驟。

通過無縫集成到編譯過程中,源生成器可以提高生產力、減少錯誤並實現更高效的開發工作流程。

 

如何使用

創建 .NET 控制檯應用程序。 此示例使用 .NET 6。將 Program 類替換爲以下代碼。 

namespace ConsoleApp;

partial class Program
{
    static void Main(string[] args)
    {
        HelloFrom("Generated Code");
    }

    static partial void HelloFrom(string name);
}

接下來,我們將創建一個源生成器項目來實現 partial void HelloFrom 方法對應項。

創建一個以 netstandard2.0 目標框架名字對象爲目標的 .NET 類庫。 添加以下 NuGet 包

<ItemGroup>
    <PackageReference Include="Microsoft.CodeAnalysis.CSharp" Version="4.8.0" PrivateAssets="all" />
    <PackageReference Include="Microsoft.CodeAnalysis.Analyzers" Version="3.3.4" PrivateAssets="all" />
</ItemGroup>

 

然後,創建一個名爲 HelloSourceGenerator.cs 的新 C# 文件,該文件指定你自己的源生成器,如下所示:

using Microsoft.CodeAnalysis;

namespace SourceGeneratorInCSharp
{
    [Generator]
    public class SourceGenerator : ISourceGenerator
    {
        public void Execute(GeneratorExecutionContext context)
        {
            // Find the main method
            var mainMethod = context.Compilation.GetEntryPoint(context.CancellationToken);

            // Build up the source code
            string source = $@"// <auto-generated/>
using System;

namespace {mainMethod.ContainingNamespace.ToDisplayString()}
{{
    public static partial class {mainMethod.ContainingType.Name}
    {{
        static partial void HelloFrom(string name) =>
            Console.WriteLine($""Generator says: Hi from '{{name}}'"");
    }}
}}
";
            var typeName = mainMethod.ContainingType.Name;

            // Add the source code to the compilation
            context.AddSource($"{typeName}.g.cs", source);
        }

        public void Initialize(GeneratorInitializationContext context)
        {
            // No initialization required for this one
        }
    }
}

 

現在,我們有一個正常運行的生成器,但需要將其引用到控制檯應用程序。 

新引用不是傳統的項目引用,必須手動編輯以包含 OutputItemType 和 ReferenceOutputAssembly 屬性。

<ItemGroup>
    <ProjectReference Include="..\SourceGeneratorInCSharp\SourceGeneratorInCSharp.csproj"
                        OutputItemType="Analyzer"
                        ReferenceOutputAssembly="false" /> 
</ItemGroup>

 

現在,運行控制檯應用程序時,應會看到生成的代碼運行並打印到屏幕。

控制檯應用程序本身不實現 HelloFrom 方法,而是在編譯過程中從源生成器項目生成的源。

 

如果使用的是 Visual Studio,則可以看到源生成的文件。

在“解決方案資源管理器”窗口中,展開“依賴項”>“分析器”>“SourceGenerator”>“SourceGenerator.HelloSourceGenerator”,然後雙擊“Program.g.cs”文件即可看到生成的內容。

 

https://learn.microsoft.com/zh-cn/dotnet/csharp/roslyn-sdk/source-generators-overview

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章