gpt4 book ai didi

.net - MSBuild 和 F# 的 FAKE 有什么区别?

转载 作者:IT老高 更新时间:2023-10-28 11:14:46 26 4
gpt4 key购买 nike

我是 .NET 生态系统的新手,我正在加入 F#,来自 Java 领域。我正在尝试围绕工具和构建过程进行思考。

我的理解是 MSBuild 是 .NET 应用程序的构建工具,它的构建配置是在 .sln 和/或 .*proj 文件中的 XML 中定义的。我假设这类似于 java 中的 pom.xml 或 build.gradle 文件是否正确?

无论如何,如果 MSBuild 是构建工具,那么 FAKE 究竟是为了什么? FAKE 能做什么 MSBuild 不能做的?它只是围绕 MSBuild 配置文件的更友好的“包装器”吗?

编辑:

我看到了一个名为 Ionide and the State of F# Open Source Environment 的视频,并且在其中,主要演示者提供了一个原因,为什么 .*proj 文件至少在 VSCode 中仍然需要。以下不是直接引用,但在接近尾声时,他说了类似的话

The MSBuild system is not needed at all in terms of communicating withthe compiler and getting your code to work. The only reason we can'ttoally pull it out yet is because the F# compiler service - whichprovides the tooltip info, certain type of type checking, etc - depends onthe project file, but we're working on expanding it so itcan use different types of formats.

最佳答案

嗯,Fake 的想法是构建 不仅仅是编译。典型的 Fake 设置将实际编译委托(delegate)给 MSBuild,并负责围绕它的任务:运行测试、打包、部署等。虽然在技术上可以在 MSBuild 中完成这些事情,但它的 XML 语法和特性可以做到一个非常痛苦的经历。因此,通常最好保持 .*proj 纯粹是声明性的(列出源文件、引用和属性)并使用 Fake 来描述构成构建的任务序列,其中一个任务是调用 MSBuild 来执行编译。

至于为什么我们仍然倾向于使用MSBuild作为中介,而不是直接从Fake调用编译器,主要是因为IDE依赖.*proj作为项目描述格式,点击“Build”时会自己调用MSBuild,所以我们要确保从 IDE 编译和从命令行构建之间的一致性。

关于.net - MSBuild 和 F# 的 FAKE 有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43021516/

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