MNN CocoaPods 支持
MNN 支持通过 CMake 自动生成 iOS CocoaPods 的 podspec 文件,方便集成到 iOS 项目中。
概述
MNN_GENERATE_PODSPEC 是一个实验性选项,用于从 CMake 配置自动生成 iOS CocoaPods 的 podspec 文件。启用后,CMake 会自动扫描所有 MNN target 的源文件,生成完整的 MNN.podspec。
使用方式
方式一:使用脚本(推荐)
# 生成 podspec
./tools/script/generate_podspec.sh
# 生成并验证
./tools/script/generate_podspec.sh --validate
# 生成并完整验证(需要 Xcode)
./tools/script/generate_podspec.sh --validate-full
# 检查 podspec 是否与 CMake 配置同步
./tools/script/generate_podspec.sh --check
# 指定版本号
./tools/script/generate_podspec.sh -v 3.3.0
# CI 模式(无颜色输出)
./tools/script/generate_podspec.sh --validate --ci
方式二:手动 CMake 构建
mkdir build && cd build
cmake .. \
-DCMAKE_TOOLCHAIN_FILE=../cmake/ios.toolchain.cmake \
-DMNN_METAL=ON \
-DMNN_AAPL_FMWK=ON \
-DMNN_BUILD_SHARED_LIBS=OFF \
-DMNN_SEP_BUILD=OFF \
-DMNN_GENERATE_PODSPEC=ON
make -j8
构建完成后,MNN.podspec 会生成在项目根目录。
脚本参数说明
| 参数 | 说明 |
|---|---|
--version, -v |
覆盖 podspec 版本号(默认使用 CMakeLists.txt 中的 MNN_VERSION) |
--check, -c |
检查现有 podspec 是否与 CMake 配置同步(用于 CI) |
--validate |
生成后执行快速语法验证 |
--validate-full |
生成后执行完整验证(需要 Xcode,耗时较长) |
--ci |
CI 模式,禁用颜色输出,严格退出码 |
--help, -h |
显示帮助信息 |
生成的 podspec 包含内容
平台:iOS 11.0+
架构:arm64
框架依赖:Metal、Accelerate、CoreVideo、Foundation
弱依赖:MetalPerformanceShaders
源文件:自动从 CMake targets 提取
ARM82 子规范:FP16 计算支持(需要
-march=armv8.2-a+fp16)ARC 配置:自动识别 .mm 文件
发布到 CocoaPods
# 1. 验证 podspec
pod spec lint MNN.podspec --allow-warnings
# 2. 推送到私有 spec repo
pod repo push my-specs MNN.podspec --allow-warnings
# 3. 推送到 CocoaPods trunk(需要权限)
pod trunk push MNN.podspec --allow-warnings
在 Podfile 中使用
# 使用本地 podspec
pod 'MNN', :path => './path/to/MNN'
# 使用 Git 仓库
pod 'MNN', :git => 'https://github.com/alibaba/MNN.git', :tag => '3.3.0'
# 使用 CocoaPods trunk
pod 'MNN', '~> 3.3.0'
注意事项
仅支持 iOS:当前实现仅支持 iOS 平台,不支持 macOS 或 Catalyst
Metal 后端:生成的 podspec 默认启用 Metal 后端
ARM82 子规范:FP16 计算作为子规范提供,需要特殊编译标志
同步检查:修改 CMake 配置后,请重新生成 podspec 并保持同步
错误处理:如果生成失败,请检查 CMake 配置是否完整,特别是 MNN_TARGETS 是否正确定义