首页
/ Moon项目v1.36.0版本发布:工具链插件与远程缓存能力升级

Moon项目v1.36.0版本发布:工具链插件与远程缓存能力升级

2025-06-16 21:58:11作者:苗圣禹Peter

Moon是一个现代化的构建系统和任务运行器,旨在为多语言、多项目的代码库提供统一的开发体验。它通过智能的任务编排、依赖管理和缓存机制,显著提升了开发团队的构建效率。本次发布的v1.36.0版本带来了多项重要更新,特别是在工具链插件支持和远程缓存功能方面有了显著增强。

工具链插件支持全面升级

本次版本最引人注目的变化是对工具链插件的不稳定支持进行了大幅扩展。Moon现在允许插件通过WASM API深度参与项目的构建生命周期:

  1. 项目图扩展:插件现在可以向项目图中注入额外的依赖关系、任务定义和项目别名。这使得工具链能够根据自身特性动态调整项目结构。

  2. 环境设置与依赖安装:新增了SetupEnvironmentInstallDependencies两个核心动作,分别对应setup_environmentinstall_dependencies WASM API。这些API让插件能够在任务执行前准备必要的环境条件。

  3. 任务执行增强:插件现在可以干预任务执行过程,包括:

    • 在命令或脚本执行前注入额外参数
    • 将依赖和锁文件信息纳入哈希计算,确保缓存正确性
  4. Docker集成改进docker prune命令现在利用新的WASM API与工具链插件交互,实现了更智能的容器清理机制。

图形化工具增强

Moon的图形化分析工具现在支持自定义主机和端口配置:

  • moon action-graphmoon task-graphmoon project-graph命令新增了--host--port选项,方便开发者在不同环境中使用这些可视化工具。

输入处理优化

针对持续集成场景,v1.36.0改进了文件变更检测机制:

  • moon cimoon run命令新增--stdin选项,允许通过标准输入传递变更文件列表,而非依赖VCS命令检测。这种显式的方式避免了之前版本中出现的边缘情况问题。

远程缓存可靠性提升

远程缓存功能在本版本中获得了多项改进:

  1. 完整性验证:新增unstable_remote.cache.verifyIntegrity配置项,启用后会校验下载的缓存blob的摘要,确保数据完整无误。虽然会轻微影响性能,但大幅提高了可靠性。

  2. 失败回滚机制:当缓存恢复过程部分失败时,系统会自动清理已写入的文件,保持工作区一致性。

  3. 批量检查优化:缓存blob的存在性检查现在采用批量化并行处理,显著提升了效率。

  4. 纯环境变量配置:现在可以完全通过环境变量启用远程缓存功能,简化了配置流程。

代码生成能力扩展

模板系统新增了对复杂数据类型的支持:

  • template.yml现在支持arrayobject类型的变量,这些值必须符合JSON格式规范。
  • generator.templates配置项新增了对HTTPS归档文件的支持,可以直接从网络URL加载模板资源。

其他重要改进

  1. 任务输入限制解除:移除了对moon.{yml,pkl}作为任务输入的限制,不过在使用**/*通配符时仍会被排除。

  2. 终端提示修复:解决了终端提示验证有时不触发的问题。

  3. 缓存一致性增强

    • 修复了任务依赖的argsenv变更时缓存不失效的问题
    • 命令行环境变量现在能正确覆盖任务定义中的env
  4. 依赖关系修正

    • 修复了基于标签的任务依赖未正确创建隐式项目依赖的问题
    • 改进了任务/命令参数的引号处理逻辑

插件API扩展

工具链插件开发者将获得一系列新的WASM API:

  • 项目图操作:extend_project_graph
  • 任务扩展:extend_task_commandextend_task_script
  • 依赖管理:locate_dependencies_rootparse_manifestparse_lock
  • 多项输入输出结构的扩展,支持更丰富的操作类型和数据传递

底层升级

项目内部完成了多项技术栈更新:

  • Rust工具链升级至v1.87.0
  • proto依赖从v0.47.11升级至v0.49.1

Moon v1.36.0版本通过增强工具链插件支持和改进远程缓存等核心功能,进一步巩固了其作为现代化构建系统的地位。这些改进不仅提升了开发体验,也为更复杂的构建场景提供了可靠支持。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
144
1.93 K
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
274
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
930
553
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
423
392
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
66
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.11 K
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
64
511