上一篇文章学习了通过获取和解析swagger.json的内容,来生成API的请求响应类。
但是其中无法移动与编辑。
那么本文将介绍如何输出生成的文件。
EmitCompilerGeneratedFiles
在控制台程序中,的PropertyGroup添加true
再次编译,文件将会输出到obj/Debug/net8.0/generated/GenerateClassFromSwagger.Analysis/GenerateClassFromSwagger.Analysis.ClassFromSwaggerGenerator目录下。
打开目录我们可以看到如下文件:
指定生成目录
前面生成的文件在obj目录下,多少有一些不方便,那么如何指定输出目录呢。
可以通过添加CompilerGeneratedFilesOutputPath到PropertyGroup中来指定我们的输出目录。
如这里配置输出目录为SwaggerEntities:
Exe
net8.0
enable
enable
true
SwaggerEntities
再服务器托管次编译项目,可以看到文件输出在我们的项目内。
此时打开文件也是可编辑的状态。
动态目录
除了上面的方法,还可以通过一些环境变量来指定文件输出的目录。
Exe
net8.0
enable
enable
true
Generated
$(GeneratedFolder)$(TargetFramework)
比如我们添加Generated到PropertyGroup中,CompilerGeneratedFilesOutputPath的内容改成
$(GeneratedFolder)$(TargetFramework),那么我们的输出目录将变成Generatednet8.0。
利用这一点我们可以灵活的输出我们的代码文件。
缺点
通过这种方式也有一个缺点,就是我们只能编译一次成功。第二次则会出现报错提示。
所以这种方式适合需要修改输出文件和并且把文件移动到别的位置的情况。
结语
本文介绍了Source Generators生成和输出文件的方式。利用这些功能,我们可以灵活选择是否需要输出代码文件到我们的项目中。
本文代码仓库地址https://github.com/fanslead服务器托管/Learn-SourceGenerator
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
第七章 前端工程化_2 六、Vue3视图渲染技术 6.1 模版语法 6.1.1 插值表达式和文本渲染 6.1.2 Attribute属性渲染 6.1.3 事件的绑定 6.2 响应式基础 6.2.1 响应式需求案例 6.2.2 响应式实现关键字ref 6.2.3…