gpt4 book ai didi

学习SourceGenerators之输出生成的文件

转载 作者:撒哈拉 更新时间:2024-04-02 16:42:21 55 4
gpt4 key购买 nike

上一篇文章学习了通过获取和解析swagger.json的内容,来生成API的请求响应类。 但是其中无法移动与编辑。 那么本文将介绍如何输出生成的文件.

EmitCompilerGeneratedFiles

在控制台程序中,的PropertyGroup添加 true 再次编译,文件将会输出到obj/Debug/net8.0/generated/GenerateClassFromSwagger.Analysis/GenerateClassFromSwagger.Analysis.ClassFromSwaggerGenerator目录下。 打开目录我们可以看到如下文件:

指定生成目录

前面生成的文件在obj目录下,多少有一些不方便,那么如何指定输出目录呢。 可以通过添加CompilerGeneratedFilesOutputPath到PropertyGroup中来指定我们的输出目录。 如这里配置输出目录为SwaggerEntities:

<PropertyGroup>
  <OutputType>Exe</OutputType>
  <TargetFramework>net8.0</TargetFramework>
  <ImplicitUsings>enable</ImplicitUsings>
  <Nullable>enable</Nullable>
  <EmitCompilerGeneratedFiles>true</EmitCompilerGeneratedFiles>
  <CompilerGeneratedFilesOutputPath>SwaggerEntities</CompilerGeneratedFilesOutputPath>
</PropertyGroup>

再次编译项目,可以看到文件输出在我们的项目内。 此时打开文件也是可编辑的状态.

动态目录

除了上面的方法,还可以通过一些环境变量来指定文件输出的目录.

	<PropertyGroup>
		<OutputType>Exe</OutputType>
		<TargetFramework>net8.0</TargetFramework>
		<ImplicitUsings>enable</ImplicitUsings>
		<Nullable>enable</Nullable>
		<EmitCompilerGeneratedFiles>true</EmitCompilerGeneratedFiles>
		<GeneratedFolder>Generated</GeneratedFolder>
		<CompilerGeneratedFilesOutputPath>$(GeneratedFolder)\$(TargetFramework)</CompilerGeneratedFilesOutputPath>
	</PropertyGroup>

比如我们添加 Generated 到PropertyGroup中,CompilerGeneratedFilesOutputPath的内容改成 $(GeneratedFolder)$(TargetFramework),那么我们的输出目录将变成Generated\net8.0。 利用这一点我们可以灵活的输出我们的代码文件.

缺点

通过这种方式也有一个缺点,就是我们只能编译一次成功。第二次则会出现报错提示。 所以这种方式适合需要修改输出文件和并且把文件移动到别的位置的情况.

结语

本文介绍了Source Generators生成和输出文件的方式。利用这些功能,我们可以灵活选择是否需要输出代码文件到我们的项目中.

本文代码仓库地址https://github.com/fanslead/Learn-SourceGenerator 。

最后此篇关于学习SourceGenerators之输出生成的文件的文章就讲到这里了,如果你想了解更多关于学习SourceGenerators之输出生成的文件的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

55 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com