Invoke-Build 项目技术文档
2024-12-25 03:08:38作者:董宙帆
1. 安装指南
1.1 通过 PowerShell Gallery 安装
Invoke-Build 可以通过 PowerShell Gallery 安装。执行以下命令即可:
Install-Module InvokeBuild
1.2 通过 Chocolatey 安装
如果你使用 Chocolatey,可以运行以下命令进行安装:
choco install invoke-build
1.3 通过 Scoop 安装
如果你使用 Scoop,可以运行以下命令进行安装:
scoop install invoke-build
1.4 通过 NuGet 安装
Invoke-Build 也可以通过 NuGet 安装。下载包后,将其重命名为 zip 文件,解压其中的 tools 目录,并将其重命名为 InvokeBuild。你可以将该目录添加到系统路径中,或者将其复制到 PowerShell 模块目录中以作为模块使用。
1.5 通过 dotnet 工具安装
Invoke-Build 还可以作为 dotnet 工具安装。你可以选择全局安装或本地安装:
- 全局安装:
dotnet tool install --global ib
- 本地安装:
dotnet new tool-manifest # 仅在设置工具的仓库时执行一次
dotnet tool install --local ib
2. 项目的使用说明
Invoke-Build 是一个用于 PowerShell 的构建和测试自动化工具,支持 PowerShell v3.0 及以上版本。它类似于 psake,但使用起来更简单且功能更强大。Invoke-Build 支持以下特性:
- 增量任务:有效处理输入和输出。
- 持久化构建:可以在中断后恢复。
- 并行构建:在不同的工作空间中并行执行构建,并共享统计信息。
- 批量测试任务:将测试任务组合成批量执行。
- 自定义任务类:允许定义新的任务类。
Invoke-Build 支持跨平台运行,并且可以与 VSCode 和 ISE 集成使用。
3. 项目 API 使用文档
3.1 基本命令
Invoke-Build.ps1:调用构建脚本,这是构建引擎的核心脚本。Build-Checkpoint.ps1:调用持久化构建,使用构建引擎。Build-Parallel.ps1:调用并行构建,使用构建引擎。Resolve-MSBuild.ps1:查找指定的或最新的 MSBuild。Show-TaskHelp.ps1:显示任务帮助信息,通常在WhatIf调用时使用。
3.2 额外工具
Invoke-Build.ArgumentCompleters:为 PowerShell v5 提供参数补全功能。Invoke-TaskFromVSCode:从 VSCode 中调用构建脚本中的任务。Show-BuildGraph:使用 Graphviz Viz.js 或 dot 显示任务图。New-VSCodeTask:生成绑定到构建脚本任务的 VSCode 任务。Invoke-TaskFromISE:从 ISE 中调用构建脚本中的任务。
3.3 其他工具
ib.cmd和ib.sh:cmd 和 bash 的辅助脚本。Build-JustTask.ps1:在不引用其他任务的情况下调用任务。Convert-psake.ps1:将 psake 构建脚本转换为 Invoke-Build 脚本。Show-BuildTree.ps1:以文本形式显示任务树。Show-BuildDgml.ps1:以 DGML 格式显示任务图。Show-BuildMermaid.ps1:使用 Mermaid 显示任务图。
4. 项目安装方式
4.1 作为模块安装
Invoke-Build 可以作为 PowerShell 模块安装,使用以下命令:
Install-Module InvokeBuild
4.2 作为脚本安装
Invoke-Build 也可以作为脚本安装。你可以通过 Scoop 或手动下载 NuGet 包进行安装。
4.3 作为 dotnet 工具安装
Invoke-Build 还可以作为 dotnet 工具安装,支持全局或本地安装。
5. 获取帮助
如果你在使用模块时遇到问题,或者脚本不在系统路径中,可以使用完整路径调用 Invoke-Build.ps1 来获取帮助:
help Invoke-Build -full
对于内部命令的帮助,可以执行以下命令:
. Invoke-Build
help task -full
help exec -full
6. 在线资源
- 基本概念:了解构建脚本的优势。
- 脚本教程:快速熟悉构建脚本。
- 逐步教程:从“Hello world”到复杂脚本。
- 项目 Wiki:详细教程、辅助工具、笔记等。
- 示例:在各种项目中使用的构建脚本。
- 任务:示例、模式和各种技术。
- 设计笔记:为贡献者提供的技术细节。
- 发布说明
7. 致谢
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0114- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiMo-V2.5-ProMiMo-V2.5-Pro作为旗舰模型,擅⻓处理复杂Agent任务,单次任务可完成近千次⼯具调⽤与⼗余轮上 下⽂压缩。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
SenseNova-U1-8B-MoT-SFTenseNova U1 是一系列全新的原生多模态模型,它在单一架构内实现了多模态理解、推理与生成的统一。 这标志着多模态AI领域的根本性范式转变:从模态集成迈向真正的模态统一。SenseNova U1模型不再依赖适配器进行模态间转换,而是以原生方式在语言和视觉之间进行思考与行动。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
718
4.58 K
Ascend Extension for PyTorch
Python
583
718
deepin linux kernel
C
28
16
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
963
959
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
420
363
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
703
114
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.63 K
955
昇腾LLM分布式训练框架
Python
154
180
Oohos_react_native
React Native鸿蒙化仓库
C++
342
389
暂无简介
Dart
957
238