一、壳工程的实现
新建SFUIKitDemo作为壳工程
1、创建pod工程
a、cd到创建的Demo的根目录下,然后执行:
pod init
然后根目录文件夹下会多出一个podFile文件。
b、生成xcworkspace工程,执行:
pod install
c、新建一个Lib(自己起名)文件夹,用来存放组件库
然后cd到Lib下,执行:
pod lib create SFUIKit
其中SFUIKit就是你自定义的一个工程名字,也就是你的其中一个组件或者业务模块,然后根据提示,生成pod工程模板。如下图所示:
然后根据提示,会自动生成pod工程模板。
打开新建的SFUIKit工程里的Example,可以看到pods里面,有个ReplaceMe的文件,意思就是要替换它,换成我们自己需要对外提供的类。
把我们需要拆分的工程代码,复制粘贴到ReplaceMe同级目录下,并删掉ReplaceMe.m文件
之后cd到Lib/SFUIKit/Example/文件目录下,执行:
pod install
这个时候在Development Pods文件下会多出这两个文件,这就是本地开发的pods文件
至此,一个组件的本地库就创建完成了。
二、使用本地组件库
首先cd到壳工程SFUIKit目录下,修改SFUIKitDemo的Podfile文件,增加
pod ‘SFUIKit’, :path => ‘Lib/SFUIKit’
执行:
pod install
这样壳工程就pod到本地组件库的内容了,原理跟使用平时的第三方远程库一样。只不过这次使用的是本地的。只不过本地的pod放在了Development Pods文件夹里面,这个文件夹里的内容其实是可以修改的,修改后立刻生效。
三、关联git
完成了本地pod依赖,但这个并不是最终我们想要的。想要多人开发,还是需要把组件推送到远端,才能实现联合开发。以下级gitee为例:
1、创建仓库
创建完成后,然后cd组件的根目录:
首先我们需要先编辑一下podspec文件:
改好后,在上传之前,最好先本地检查一下podspec是否合法:
pod lib lint --verbose
注:如果因为警告而造成的错误可使用下面的方法验证:
pod lib lint --verbose --allow-warnings
如果出现passed validation,说明通过,可以提交到远端仓库上了
初始化git,执行:
git init
然后添加代码,执行:
git add .
然后,提交初始化工程:
git commit -m "xxxx"
接下来,我们要让这个工程和刚才在Gitee上创建的仓库关联
git remote add origin https://gitee.com/aistarfish/SFUIKit.git
然后,提交初始化工程到远端的master:
git push origin master
这时我们的代码已经上传到仓库了。
组件,需要对外提供依赖关系。所以我们还得多做一步操作,那就是修改podspec文件。我们可以根据不同的tag对应不同的podspec文件来进行版本控制和升级。执行:
git tag 1.0.0
git push --tags
刷新gitee,会看到多了一个tag分支:
接下来,我们需要将组件的spec文件发布到我们创建的spec仓库中去。
pod repo push SFPodSpec SFUIKit.podspec --verbose --allow-warnings
当spec仓库添加成功,就表明当前组件创建成功了。
最后我们就可以使用pod的方式引入我们的组件了:
最后如果组件需要更新,只需要打出对应的tag,更新本地的spec文件就可以了
pod repo update