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建立Podfile:vim 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不动,缘由在于当执行以上两个命令的时候会升级CocoaPods的spec仓库,加一个参数能够省略这一步,而后速度就会提高很多。加参数的命令以下:
pod install --verbose --no-repo-update
pod update --verbose --no-repo-update
4. 当在update或install时遇到这个问题:
Unable to find a specification for `xxxxx (~> 1.x.x)` depended upon by Podfile.
只须要把当前Pod的目录清理一下就好了。在终端执行如下命令:
pod repo remove master
pod setup
setup成功后执行install或update便可
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)