您的位置:首页 > 其它

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

2015-10-27 00:00 302 查看
摘要: CocoaPods的安装,使用和一些注意点。
举例说明了和Git配合使用的一些注意点。

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创建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)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  CocoaPods