首页
/ mas-cli 2.0.0 发布:全面适配 macOS 15.4+ 的重大更新

mas-cli 2.0.0 发布:全面适配 macOS 15.4+ 的重大更新

2025-06-06 06:38:15作者:房伟宁

mas-cli 是一个 macOS 上的命令行工具,用于管理 Mac App Store(MAS)应用程序。它允许用户通过命令行搜索、安装、更新和卸载 App Store 应用,为喜欢终端操作或需要自动化管理应用的用户提供了极大便利。

重大变更:最低系统要求提升至 macOS 10.15

mas-cli 2.0.0 版本最显著的变化是将最低系统要求从 macOS 10.13(High Sierra)提升到了 macOS 10.15(Catalina)。这一变更主要出于以下技术考量:

  1. Swift 并发模型迁移:项目从第三方 PromiseKit 迁移到了原生的 Swift Concurrency(Swift 并发),这需要 macOS 10.15 及以上版本的支持。Swift Concurrency 是苹果在 Swift 5.5 中引入的现代并发编程模型,相比 PromiseKit 提供了更好的性能和更简洁的代码结构。

  2. 应用列表获取方式重构:新版本放弃了原先依赖的 Apple 私有框架 CommerceKit,转而使用公开的 Spotlight 元数据接口来获取已安装的 MAS 应用列表。这一变更不仅解决了在 macOS 15.4 及以上版本中应用列表为空的问题,还提高了工具的长期稳定性,因为 Spotlight 作为公开接口不太可能突然失效。

关键修复:macOS 15.4+ 兼容性问题

在 macOS 15.4 中,原先使用的 CKSoftwareMap.shared().allProducts() 方法开始返回空数组,导致 listoutdatedupdate 命令失效。2.0.0 版本通过以下方式解决了这个问题:

  1. Spotlight 元数据替代方案:现在通过查询 Spotlight 的 kMDItemAppStoreHasReceipt 属性来识别 MAS 安装的应用。这种方法虽然可靠,但目前存在一个小限制:应用名称是从应用文件夹名称派生而来(去除 .app 后缀),可能与实际应用名称略有差异。

  2. 应用排序优化:新版本对已安装应用列表进行了不区分大小写的按名称排序,提升了用户体验。

其他改进

  1. 版本检测优化:移除了从 MAS 网页抓取应用版本信息的逻辑,简化了版本检测流程。

  2. 开发工具链升级:包括测试框架 Quick 和 Nimble 的版本更新,以及 SwiftLint 配置的调整,提高了开发效率和代码质量。

  3. 构建系统改进:解决了多架构可执行文件构建的问题,并优化了版本命名策略。

技术影响与用户建议

对于开发者而言,这次更新展示了如何将项目从依赖私有 API 迁移到公开接口的最佳实践,同时也体现了采用现代 Swift 特性的优势。对于终端用户,建议所有使用 macOS 10.15 及以上系统的用户升级到此版本,特别是那些已经升级到 macOS 15.4 的用户,以确保所有功能正常工作。

需要注意的是,由于系统要求提高,仍在使用 macOS 10.13 或 10.14 的用户将无法使用此版本。这些用户可以考虑继续使用 1.x 版本,或者升级操作系统以获得更好的兼容性和安全性。

mas-cli 2.0.0 的发布标志着该项目向着更稳定、更可持续的方向迈出了重要一步,为未来的功能扩展奠定了坚实基础。

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

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
154
1.98 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
941
555
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
405
387
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Python
75
70
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
992
395
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
509
44
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
344
1.32 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
194
279