1.Github创建项目
在GitHub上创建“wzi-specs”项目,https://github.com/wzi90921/wzi-specs.git,这是我们的Spec Repo(私有库仓库);
说明: 我们用Cocoapod管理类库时,Podfile文件的开头
source 'https://github.com/CocoaPods/Specs.git'
source 'https://github.com/aliyun/aliyun-specs.git'
//当使用我们自己的使用库时,需要指定来源,如下
source 'https://github.com/wzi90921/wzi-specs.git'
在GitHub上创建“wzi-baseLib”,这个项目是基础类库(私有库)。https://github.com/wzi90921/wzi-baseLib.git
在GitHub上创建“wzi-moduleA”,这个项目是组件A(私有库)。https://github.com/wzi90921/wzi-moduleA.git
在GitHub上创建“wzi-podDemo”,这个项目是主程序。https://github.com/wzi90921/wzi-podDemo.git
说明:创建项目时,我这边选择"MIT License"(选择自己适合的License)。
通过终端命令或者SourceTree将3个项目clone到本地;
image.png
2.私有库仓库添加在到本机
//终端执行,将我们的私有库仓库添加在到本机
pod repo add wzi-specs https://github.com/wzi90921/wzi-specs.git
执行后,通过Finder——>"前往文件夹":~/.cocoapods/repos,可以看到repos文件夹里有wzi-specs的文件夹。
image.png
3.podspec文件说明
在本地“wzi-baseLib”的目录下创建“Assets”,“Classes”两个文件夹,“wzi-baseLib.podspec”文件
Assets:资源文件目录(png,xib,plist……)
Classes:代码目录
wzi-baseLib.podspec:私有库的配置文件 官方文档
image.png
wzi-baseLib.podspec 有两种创建方式,
第一种方式:终端执行,生成一个完整版的podspec,
pod spec create wzi-baseLib
第二种方式:复制下面的内容保存 wzi-baseLib.podspec,
Pod::Spec.new do |s|
s.name = "wzi-baseLib"
s.version = "0.0.1"
s.summary = "wzi-baseLib is a base lib"
s.homepage = "https://github.com/wzi90921"
s.license = "MIT"
s.author = {
"weizixiong" => "wzi90921@sina.com"
}
s.source = { :git => "https://github.com/wzi90921/wzi-baseLib.git", :branch => 'master' }
s.prefix_header_file = 'Classes/Prefix.h'
s.source_files = "Classes/**/*.{h,m}"
s.requires_arc = true
# s.resources = ['Resources/**/*.png']
# s.resource_bundles = {
# 'Resources' => ['Resources/*.png'],
# }
s.ios.deployment_target = "8.0"
s.ios.framework = "UIKit"
#s.libraries = "sqlite3","z"
s.dependency "YTKNetwork"
s.dependency "MJExtension"
s.dependency "MBProgressHUD"
s.dependency "SDWebImage"
s.dependency "MJRefresh"
s.dependency "YTKKeyValueStore"
s.dependency "WZLSerializeKit"
end
配置项说明
//代码源是 wzi-baseLib.git 的主分支
s.source= { :git => "https://github.com/wzi90921/wzi-baseLib.git", :branch => 'master' }
//代码源是 wzi-baseLib.git, tag:"v1.0.7"的分支
s.source = { :git => "https://github.com/wzi90921/wzi-baseLib.git", :tag => "v1.0.7"}
//代码源是 wzi-baseLib.git 的某个tag,这个tag跟s.version是一样的。
s.source = { :git => 'https://github.com/wzi90921/wzi-baseLib.git', :tag => s.version.to_s }
//跟上面类似,可能你的tag有"v",或者其他
s.source = { :git => "https://github.com/wzi90921/wzi-baseLib.git", :tag => "v#{s.version}"}
//代码源是本地目录,相对路径/绝对路径
s.source = { :git => "../BaseLib" }
s.source = { :git => "/Users/weizixiong/WorkPlace/Gitee_WorkPlace/BaseLib" }
说明:开发完后,我一般先用本地目录验证;提交到GitHub后,指向master主分支,再验证;最后确定了版本后,指向对应的Tag;这样可以避免每一次修改后都要提交到GitHub;
/*
配置预编译头文件,
开发类库时,该文件的内容会被复制到“Support Files”——>"wzi-baseLib-prefix.pch";
开发过程中,
修改“Prefix.h”文件,需要执行 pod update 才会生效;
修改“wzi-baseLib-prefix.pch”会立即生效,但是要把新添加的内容复制到“Prefix.h”,否则执行 pod update 后,新添加的内容会没有了。
*/
s.prefix_header_file = 'Classes/Prefix.h'
/*
s.resources 与 s.resource_bundles 这两个配置都是指定资源目录,类型
两者的区别,在于s.resources会把资源文件直接拷贝到生成的App,s.resource_bundles会打包成.bundle在拷贝到生成的App;
*/
s.resources = ['Resources/**/*.png'];
[UIImage imageNamed:@"imageName"];
//有可能出现图片名冲突的情况;
s.resource_bundles = {
'Resources' => ['Resources/**/*.png'],
}
[UIImage imageNamed:@"Resources.bundle/imageName"];
//避免了图片名冲突,但是需要指定bundle
//如果项目中有引用其他的framewor、a类库的,需加上;反则不需要
s.vendored_frameworks = 'Classes/**/*.framework'
s.vendored_libraries = 'Classes/**/*.a'
//引用系统的framework、libraries
s.ios.framework = "CFNetwork","UIKit","JavaScriptCore","AudioToolbox"
s.libraries = "sqlite3","z"
//引用其他的类库
s.dependency "YTKNetwork"
s.dependency "YYWebImage"