GeneralUpdate.Tools
这是什么
GeneralUpdate.Tools 是一个基于 Avalonia 12 开发的跨平台桌面工具(Windows / Linux / macOS),用于在软件发布流程中生成和管理补丁包、扩展包、版本清单以及执行本地更新仿真。它不替代你的 CI/CD 系统,而是把”打包、校验、验证”这些重复劳动收敛到一个可视化工具中。
Tools 与 CI/CD 的关系
Tools 是桌面 GUI 工具,适合开发者在本地交互式地生成补丁、验证更新。如果你需要在 CI/CD 流水线中自动化补丁生成,可以直接调用 GeneralUpdate.Core.Pipeline.DiffPipeline.CleanAsync() —— GUI 和脚本走的是同一条代码路径。
仓库地址:https://github.com/GeneralLibrary/GeneralUpdate.Tools
下载与运行
方式一:从源码运行(推荐开发者)
当前工具基于 .NET 10 构建。确保本机安装了 .NET 10 SDK:
git clone https://github.com/GeneralLibrary/GeneralUpdate.Tools.git
cd GeneralUpdate.Tools\src
dotnet run --project GeneralUpdate.Tools.csproj
方式二:下载预编译版本
前往 GeneralUpdate.Tools Releases 下载对应平台的可执行文件,直接运行即可。
Simulation 模块内部会调用
dotnet publish构建测试应用,因此使用仿真功能时必须安装 .NET SDK,仅运行 Patch / Extension / OSS / Config 模块则不需要。
六个模块速览
| 模块 | 你提供 | 工具产出 | 下游消费者 |
|---|---|---|---|
| Patch | 旧版本目录 + 新版本目录 | {name}.zip(含 .patch 文件、新文件、generalupdate.delete.json) | Server、OSS/CDN、Core Upgrade 进程 |
| Extension | 扩展源目录 + 元数据 | {name}_{version}.zip(含 manifest.json) | GeneralUpdate.Extension 组件 |
| OSS Config | 包名、版本、下载 URL、本地 ZIP(计算 Hash) | oss_config.json(版本数组) | OSS 客户端、对象存储发布流程 |
| Config | Client/Upgrade 的 .csproj | generalupdate.manifest.json + sample_output/ 发布目录 | Client/Upgrade 启动引导 |
| Simulation | 旧版本目录 + 补丁 ZIP | 本地更新服务 + simulation_report.md | 发布前质量把关 |
| Hash | 本地文件(ZIP) | SHA256 小写十六进制字符串 | 完整性校验、服务端版本记录 |
Patch:生成补丁包
解决什么问题
当你发布了一个新版本,用户不想下载整个安装包。Patch 模块比较旧版本目录和新版本目录,只输出变更内容:修改过的文件生成二进制差分 .patch,新增文件直接复制,删除的文件写入清单。差分包通常远小于完整发布目录。