• 注册
当前位置:1313e > 默认分类 >正文

CocoaPods的使用,和git配合使用的一些注意点。

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

CocoaPods


打场子


要先装Ruby,然后在终端里sudo gem install cocoapods,安装cocoapods。如果半天没反应,应该是被墙了,需要:

$ gem sources --remove https://rubygems.org/     //等有反应之后再敲入以下命令

$ gem sources -a http://ruby.taobao.org/

为了验证你的Ruby镜像是并且仅是taobao,可以用以下命令查看:

$ gem sources -l

只有在终端中出现下面文字才表明你上面的命令是成功的:

*** CURRENT SOURCES ***

http://ruby.taobao.org/

这时候,你再次在终端中运行:$ sudo gem install cocoapods

等上十几秒钟,CocoaPods就可以在你本地下载并且安装好了,不再需要其他设置。


使用


每个项目只需要一个Podfile文件,只能是这个文件名,不能有后缀。在终端cd到项目所在的目录,利用vim创建Podfilevim Podifle

然后再Podfile文件中输入以下文字(这只是一个例子,取决于项目需要)

platform :ios, '7.0'

pod "AFNetworking", '~> 2.0'

pod 'ReactiveCocoa'

pod 'SDWebImage', '~> 3.7.2'

pod 'FMDB', '~> 2.5'

pod 'Bugly'

在当前目录,终端运行命令$ pod install 即可。

从此,打开项目就要用自动生成的.xcworkspace 打开,而不是之前的.xcodeproj文件。


常用命令


1.搜索类库:$ pod search AFNetworking

2.vim环境下,保存退出命令为: :wq

3.取消正在执行的命令行为:Crtl+C


注意点


1.如果有指定某个类库的版本号,$ pod update 也只会更新到这个版本。

2.网上下载的项目,如果使用了CocoaPods,只要cd到项目所在的目录,$ pod update即可。

3.如果执行pod install还是pod update都卡在了Analyzing dependencies不动,原因在于当执行以上两个命令的时候会升级CocoaPodsspec仓库,加一个参数可以省略这一步,然后速度就会提升不少。加参数的命令如下:

pod install --verbose --no-repo-update

pod update --verbose --no-repo-update

4. 当在updateinstall时遇到这个问题:

Unable to find a specification for `xxxxx (~> 1.x.x)` depended upon by Podfile.  

只需要把当前Pod的目录清理一下就行了。在终端执行以下命令:

pod repo remove master  

pod setup  

setup成功后执行installupdate即可

5.关于 Podfile.lock

当你执行pod install之后,除了 Podfile 外,CocoaPods 还会生成一个名为Podfile.lock的文件,Podfile.lock 应该加入到版本控制里面,不应该把这个文件加入到.gitignore中。因为Podfile.lock会锁定当前各依赖库的版本,之后如果多次执行pod install 不会更改版本,要pod update才会改Podfile.lock了。这样多人协作的时候,可以防止第三方库升级时造成大家各自的第三方库版本不一致。


和git配合使用下的版本管理的注意点


如果一开始添加了FMDB,要commit的时候,除了Xcode本身帮我们选中的,还需要自己选择的有:黄色底的为公共的,添加过一次,就不用再添加了,只会修改。

1.    test2(wrokspace),选中这个,会连Workspace Settingsye 也选中(工程)
2.    test2工程下Pods黄色文件下的Pods.debug.xcconfig  Pods.release.xcconfig(配置)
3.    Pods工程下的Project Settings 和Podfile(配置)
 102006_R8Ce_172808.png

4.    Pods工程下FMDB文件下的common文件夹,Support Files文件夹下的所有文件(类的相关文件)
5.    Pods工程下Targets Support Files文件下Pods文件夹下的所有文件(支持文件)
 102030_lfXD_172808.png

6.    第二个大tab下的Podfile.lock(版本控制)
7.    第二个大tab下的Manifest.lock(版本控制)
8.    其他的License.txt,或者readme可以不用提交。
 102106_7TKV_172808.png

如果另外一个开发人员又添加了SDWebImage,要commit的时候,还需要自己选择的有:

1.    Pods工程下SDWebImage文件下的core文件夹,Support Files文件夹下的所有文件(类的相关文件)
2.    Pods工程下FMDB文件下的Support Files文件夹下的所有文件,因为这边可能会多出一个FMDB-Private.xcconfig文件,也需要提交。如果以后又填加了一个类库,其他已有类库又多出了一个xxx-Private.xcconfig文件,也需要提交。
 102200_r8qW_172808.png

3.    其他的关于工程的文件,Xcode自己会选中。


如果添加的第三方库是xxx.framework,一定要进去第二个大tab,把framework里面的文件都选择全,第一个tab可能显示你已经选上了,但是其实framework里面的文件可能会漏掉,此时项目是无法运行,会提示错误:linker command failed with exit code 1 (use -v to see invocation)








转载于:https://my.oschina.net/u/172808/blog/522538

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 162202241@qq.com 举报,一经查实,本站将立刻删除。

最新评论

欢迎您发表评论:

请登录之后再进行评论

登录