组件化之pod私有库创建步骤
随着项目越来越复杂,模块越来越多,这时候可以使用组件化方式解耦,分块管理代码,组件化方式很多,CocoaPods是组件化方式之一。
1.pod私有库,别人看不到你的源码;
2.pod私有库可以减少项目合并造成的冲突,整洁易管理;
3.但是增加了维护成本,修改代码就需要上传更新库版本;
由于GitHub私有库收费,这里使用码云托管平台(还有GitLab/Coding等平台)
1.创建仓库:
2.复制仓库路径;cd到桌面克隆仓库:
//git克隆仓库
duningdeMBP:Desktop duning$ git clone https://gitee.com/DonnyDN/SFString1.git
3.clone之后,在目录下创建工程,Example里是测试demo:
4.在仓库路径下,生成.podspec文件,使用命令:
//pod spec create + 私有库名字
duningdeMBP:SFString1 duning$ pod spec create SFString1
5.编辑podspec描述文件,填写私有库相关信息(可以去Github仿照一些知名库的podspec文件配置):
Pod::Spec.new do |s|
//私有库名字
s.name = “SFString1"
//版本
s.version = “0.0.1”
//简介
s.summary = "iOS字符串类别”
//私有库详细描述(比简介更详细)
s.description = <<-DESC
pod私有库 - iOS字符串类别,方便开发
DESC
//项目主页地址
s.homepage = "https://gitee.com/DonnyDN/SFString1
//开源许可证类型
s.license = "MIT"
//作者
s.author = { "DNCoder" => “aaa@qq.com" }
//库路径(即仓库路径,复制并在后添加.git后缀)
s.source = { :git => "https://gitee.com/DonnyDN/SFString1.git", :tag => "#{s.version}" }
//最低支持的系统版本
s.platform = :ios, '8.0'
//是否支持ARC
s.requires_arc = true
//资源文件路径(**表示匹配所有子目录;*表示匹配所有文件)
s.source_files = "SFString1/*.{h,m}"
//若有依赖的库,要填写s.dependency:
#s.dependency "JSONKit", "~> 1.4"
#s.dependency "Masonry", "~> 1.0.0"
end
6.提交所有文件到git仓库
duningdeMBP:SFString1 duning$ git add .
duningdeMBP:SFString1 duning$ git commit -m "第一次提交(库文件+podspec文件)”
duningdeMBP:SFString1 duning$ git pull
duningdeMBP:SFString1 duning$ git push
7.给工程打tag标签:
//注意tag和podspec文件里的s.version一样
duningdeMBP:SFString1 duning$ git tag "0.0.1"
duningdeMBP:SFString1 duning$ git push —tags
6.验证上一步编辑的 .podspec文件是否有错,在podspec文件所在目录下执行命令:
pod lib lint --allow-warnings
如果有ERROR,则需要去一个个修改完成
(1) - -verbose:表示显示全部的日志信息,建议加上这个,方便判断错误信息;
(2) - -sources:如果我们在podspec里面依赖到一些私有的库之后,直接进行校验是会报错的提示找不到,这里可以加上Spec仓库的地址告诉CocoaPods找不到的时候去哪里找;
(3) - -allow-warnings:表示允许警告;
(4) - -use-libraries:表示使用静态库或者是framework,这里主要是解决当我们依赖一些framework库后校验提示找不到库的时候用到。
7.创建私有的索引库Spec Repo:
duningdeMBP:SFString1 duning$ pod repo add SFString1 https://gitee.com/DonnyDN/SFString1
duningdeMBP:SFString1 duning$ pod repo push SFString1 SFString1.podspec
打开本地cocopods仓库,查看本地repo库(会包含SFString1库):
open ~/.cocoapods/repos/
检查podspec文件是否有效:
duningdeMBP:SFString1 duning$ pod spec lint --allow-warnings
8.查询本地是否有对应的项目库
pod search SFString1
查看本地pod索引库
pod repo
9.最后,在podfile文件里试验一***意要添加两个source源,pod install成功!:
platform:ios,'8.0'
source 'https://github.com/CocoaPods/Specs.git'
source 'https://gitee.com/DonnyDN/SFString1.git'
def common_pods
#这是从本地加载
#pod 'SFString1', :podspec => '~/.cocoapods/repos/SFString1/SFString1.podspec'
#这是从远程仓库下载
pod 'SFString1'
pod 'Masonry', '~> 1.0.0'
end
target 'TestDemo' do
common_pods
end
10.更新维护
需重新提交代码,修改spec描述文件并提交,大概步骤如下:
1.重新提交代码:
git add .
git commit -m ‘更新了*’
git push origin master2.打tag,同时改spec描述文件:
git tag 0.0.2
git push –tags3.更新spec文件到索引库
pod repo add SFString1 https://gitee.com/DonnyDN/SFString1
pod repo push SFString1 SFString1.podspec
11.私有库关联trunk账号变为公有库:
注册trunk需要CocoaPods 0.33版本以上:
//查看pod版本
pod --version
//版本低的话,升级pod
sudo gem install cocoapods
pod setup
查看自己是否注册过Trunk
pod trunk me
注册trunk账户:
// 加上--verbose可以输出详细debug信息,方便出错时查看(邮箱 + 名字)。
pod trunk register aaa@qq.com163.com "userName" --verbose
注册完成之后会给你的邮箱发个邮件,进入邮箱邮件里面有个链接,需要点击确认一下.
注册成功后可以再查看一下个人信息:
pod trunk me
发布时会验证 Pod 的有效性,如果你在手动验证 Pod 时使用了 –use-libraries 或 –allow-warnings 等修饰符,那么发布的时候也应该使用相同的字段修饰,否则出现相同的报错。
// --use-libraries --allow-warnings
pod trunk push SFString1.podspec
后续:
1.也有单独创建一个podspec文件仓库的方式,我这里是直接git项目和podspec文件共用git仓库了;
1.也有使用如下命令的方式创建项目的
例:https://www.jianshu.com/p/9992feb8b00b
pod lib create SFString2
参考:
https://www.cnblogs.com/daxueshan/p/6901641.html
https://segmentfault.com/a/1190000012269388
http://www.cocoachina.com/ios/20180308/22509.html
https://blog.csdn.net/sdefzhpk/article/details/69389584
https://blog.csdn.net/xiaofei125145/article/details/50673392
https://www.jianshu.com/p/9992feb8b00b
https://www.jianshu.com/p/48c229d13fdd
上一篇: H3C交换机Telnet远程登录
下一篇: 华为路由器:ipsec技术