在上篇文章CocoaPods与SVN的配合使用(一)中我们使用CocoaPods制作了基于SVN地址的开发库,然后通过Pod命令将开发库以源代码方式引入工程中。但是,有时我们不希望开发库以源代码方式提供给别人,这时就要制作静态库,这种静态库有两种形式:
- .framework
- .a文件 加 .h头文件
CocoaPods 提供了cocoapods-packager来创建静态库,安装此工具的过程在此不再赘述。(需要更新CocoaPods到较新的版本)
制作静态库的过程:
- 制作好源代码开发库,参考CocoaPods与SVN的配合使用(一)
- 重新编辑.podspec文件,用cocoapods-packager将源代码开发库打包成静态库,配置.podspec文件支持静态库的Pod集成,本文将重点讨论此过程。
下面我们紧接CocoaPods与SVN的配合使用(一)中创建支持CocoaPods的开发库的流程,从SVN中的tag
分支入手。
-
从
tags
文件夹0.1.0
分支上创建一个新分支0.1.0-framework
放入branches
中,现在以新分支0.1.0-framework
为当前开发分支,这一步主要是为了方便开发。
重新编辑
.podspec
文件,然后在终端.app
中使用pod package XXX.podspec --force
命令来打包生成framework。
打包工具cocoapods-packager会根据.podspec
文件中的s.source
和s.source_files
来确定源码库的路径和所包含文件,其中s.source
不支持本地路径,请确保打包的文件被正确提交到了svn。
根据上图分支的svn路径,我们使用的路径为
s.source = { :svn => 'svn://IP_ADDRESS/app/Common/ios/XXX/branches/0.1.0-framework'}
,
s.source_files = 'XXX/Classes/**/*'
编辑完成,在
终端.app
中定位到.podspec
文件的上级目录,使用pod package XXX.podspec --force
命令生成framework。查看刚才的目录中,已经生成了包含
XXX.framework
的文件夹。将新生成的文件夹和framework文件提交到svn。- 配置
.podspec
文件支持framework的Pod集成。
三种集成配置方式(源码方式、framework方式、.a文件方式)见图中红框,这里我们使用framework下载方式设置项,将framework的路径设置给s.vendored_frameworks
项。
之后通过终端.app
在0.1.0-framework/Example
文件夹使用pod install --no-repo-update
来安装,打开Xcode目录,发现framework被添加进了工程,接下来运行测试。
我在测试中出现了Expected a type
的问题,而使用源代码方式集成却没有问题,经查证是由于生成的framework的头文件中没有显示添加#import <UIKit/UIKit.h>
,导致无法识别UIView
,显示添加之后再次打包framework,问题解决。 - 制作tag分支,并删除tag分支上的源代码。
我们将XXX.podspec
中的s.source
还原为
s.source = { :svn => 'svn://IPAddress/app/Common/ios/XXX', :tag => s.version.to_s }
根据:tag => s.version.to_s
,在SVN的tag中打包为相应版本。这里为了和源码版本的区别开来,我们将s.version
的值设置为0.1.0-framework
制作tag分支,步骤(以Cornerstone为例):
制作完成后记得删除掉tag分支上的源代码。
下面是在其他工程中使用刚刚配置好的framework
1. 使用CocoaPods引入framework
在已有工程中的Podfile文件中编辑
pod ‘XXX’,:svn =>'svn://YourSvnPath/XXX’,:tag =>'0.1.0-framework'
可参考 Profile文件 Pod语法然后使用pod install --no-repo-update
进行安装
更新后可以看到XXX.framework已经被下载下来了,现在你就可以在工程中使用这个framework了。