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

CocoaPodsios


打场子git


要先装Ruby,而后在终端里sudo gem install cocoapods,安装cocoapods。若是半天没反应,应该是被墙了,须要:vim

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

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

为了验证你的Ruby镜像是而且仅是taobao,能够用如下命令查看:spa

$ gem sources -l命令行

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

*** CURRENT SOURCES ***版本控制

http://ruby.taobao.org/code

这时候,你再次在终端中运行:$ 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(配置)

 

4.    Pods工程下FMDB文件下的common文件夹,Support Files文件夹下的全部文件(类的相关文件)
5.    Pods工程下Targets Support Files文件下Pods文件夹下的全部文件(支持文件)
 

6.    第二个大tab下的Podfile.lock(版本控制)
7.    第二个大tab下的Manifest.lock(版本控制)

8.    其余的License.txt,或者readme能够不用提交。
 

若是另一个开发人员又添加了SDWebImage,要commit的时候,还须要本身选择的有:

1.    Pods工程下SDWebImage文件下的core文件夹,Support Files文件夹下的全部文件(类的相关文件)
2.    Pods工程下FMDB文件下的Support Files文件夹下的全部文件,由于这边可能会多出一个FMDB-Private.xcconfig文件,也须要提交。若是之后又填加了一个类库,其余已有类库又多出了一个xxx-Private.xcconfig文件,也须要提交。
 

3.    其余的关于工程的文件,Xcode本身会选中。若是添加的第三方库是xxx.framework,必定要进去第二个大tab,把framework里面的文件都选择全,第一个tab可能显示你已经选上了,可是其实framework里面的文件可能会漏掉,此时项目是没法运行,会提示错误:linker command failed with exit code 1 (use -v to see invocation)

相关文章
相关标签/搜索