前言
在前面的章節(jié)中有介紹過(guò)CocoaPods
的使用:
制作CocoaPods公有庫(kù)以及私有庫(kù)的區(qū)別
[制作Framework以及上傳至CocoaPods庫(kù)]
(http://www.reibang.com/p/a832740aa491)
此篇文章會(huì)著重介紹下制作過(guò)程以及記錄過(guò)程遇到的一些問(wèn)題和解決辦法。
制作過(guò)程
首先膜毁,我們要先了解整個(gè)制作過(guò)程氛改,這樣我們可以快速的熟悉制作的整體流程宵呛,并且可以很好的控制過(guò)程中可能出現(xiàn)的問(wèn)題。
- 創(chuàng)建私有的源倉(cāng)庫(kù)
- 創(chuàng)建私有的
Pod
倉(cāng)庫(kù) - 添加私有庫(kù)源文件 (添加代碼蝠嘉、資源、包等等)
- 修改
.podSpec
文件 - 驗(yàn)證
.podSpec
文件 - 提交代碼至遠(yuǎn)程倉(cāng)庫(kù)
- 推送
.podSpec
文件
創(chuàng)建私有的源倉(cāng)庫(kù)
1.在遠(yuǎn)端倉(cāng)庫(kù)中,創(chuàng)建一個(gè)源索引庫(kù)PodSpecs
翅楼。 (遠(yuǎn)端倉(cāng)庫(kù)可以選擇github
、gitlab
真慢、碼云
)
2.將遠(yuǎn)端索引庫(kù)添加到本地源中(使用終端輸入以及命令)
/**
pod repo add [repoName] [source]
*/
pod repo add component https://github.com/component/specs.git
創(chuàng)建私有的Pod
倉(cāng)庫(kù)
1.在遠(yuǎn)端倉(cāng)庫(kù)中毅臊,創(chuàng)建一個(gè)源代碼pod
庫(kù)。 注意??:這里先不著急關(guān)聯(lián)到本地黑界;
- 選擇一個(gè)目錄下管嬉,創(chuàng)建本地
Pod
庫(kù)工程。
/**
pod lib create Pod庫(kù)名
*/
pod lib create RTCComponent
執(zhí)行完成后朗鸠,命令行會(huì)有一系例的問(wèn)題蚯撩,按需填寫(xiě)即可;
To get you started we need to ask a few questions, this should only take a minute.
If this is your first time we recommend running through with the guide:
- https://guides.cocoapods.org/making/using-pod-lib-create.html
( hold cmd and double click links to open in a browser. )
What platform do you want to use?? [ iOS / macOS ]
> iOS
What language do you want to use?? [ Swift / ObjC ]
> Swift
Would you like to include a demo application with your library? [ Yes / No ]
> yes
Which testing frameworks will you use? [ Quick / None ]
> none
Would you like to do view based testing? [ Yes / No ]
> no
命令執(zhí)行完后會(huì)幫我們創(chuàng)建一個(gè)Workspace烛占,里面包含了兩個(gè)Project胎挎, RTCComponent
是我們Pod庫(kù)的運(yùn)行Demo項(xiàng)目沟启;Pods
是我們開(kāi)發(fā)庫(kù)的代碼項(xiàng)目
添加私有庫(kù)源文件
我們可以在Pods/Development Pods/RTCComponent
目錄下導(dǎo)入我們的代碼文件或者framework。在這一步就是將我們代碼以及資源文件都放置到項(xiàng)目中犹菇,導(dǎo)入的文件以及資源目錄后面需要在.podSpec
文件中配置德迹, 這里就不過(guò)多說(shuō)明。
修改.podSpec
文件
Pod::Spec.new do |s|
s.name = 'RTCComponent'
s.version = '0.1.0'
s.summary = '組件'
s.description = 'xxxxxxxxxxxxxxxxx'
s.homepage = 'http://xxxx/component'
# s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
s.license = { :type => 'MIT', :file => 'LICENSE' }.
s.author = { 'xxxxxxxx' => 'xxxxxxxxx@qq.com' }
s.source = { :git => 'http://xxxx/component/RTCComponent.git', :tag => s.version.to_s }
# s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'
s.ios.deployment_target = '9.0'
# 這里是源文件的路徑
s.source_files = 'RTCComponent/Classes/**/*'
# 這里是資源文件的路徑
# s.resource_bundles = {
# 'RTCComponent' => ['RTCComponent/Assets/*.png']
# }
# 這里是頭文件的路徑
# s.public_header_files = 'Pod/Classes/**/*.h'
# 如果導(dǎo)入了framework
s.frameworks = 'OpenAL', 'Accelerate'
# 如果依賴了library(記得把lib前綴揭芍,以及.tbd去掉)
s.libraries = 'sqlite3', 'resolv', 'c++', 'z'
# 如果依賴了三方pod庫(kù)
s.dependency 'HandyJSON', '~> 5.0.2'
s.dependency 'TXLiteAVSDK_Professional', '~> 8.9.10382'
s.dependency 'SwiftyBeaver', '~> 1.9.3' # Log
s.dependency 'SwifterSwift/SwiftStdlib'
# 如果需要修改pod中的target設(shè)置胳搞,寫(xiě)在這里
s.pod_target_xcconfig = { 'VALID_ARCHS' => 'x86_64 armv7 arm64', 'ENABLE_BITCODE' => 'NO' }
# s.user_target_xcconfig = { 'ENABLE_BITCODE' => 'NO' }
end
這里如果需要設(shè)置請(qǐng)參照 CocoaPods官網(wǎng)文檔
驗(yàn)證.podSpec
文件
cd到該目錄下;執(zhí)行以下操作:
/** 網(wǎng)絡(luò)校驗(yàn) */
pod spec lint
/** 本地校驗(yàn) */
pod lib lint
常用附加處理:
- 查看詳細(xì)信息称杨,請(qǐng)?jiān)诿詈蠹尤?
--verbose
- 忽略警告流酬,請(qǐng)?jiān)诿詈蠹尤?code>--allow-warnings
- 使用本地庫(kù),請(qǐng)?jiān)诿詈蠹尤?
--use-libraries
- 檢查所有問(wèn)題列另,請(qǐng)?jiān)诿詈蠹尤?
--no-clean
- 依賴了私有庫(kù)芽腾,需要添加源,請(qǐng)?jiān)诿詈蠹尤?
--sources=
(注意如果依賴了公有庫(kù)页衙,還需要添加公有庫(kù)源:https://github.com/CocoaPods/Specs
即--sources=私有庫(kù)名,https://github.com/CocoaPods/Specs
)
提交代碼至遠(yuǎn)程倉(cāng)庫(kù)
將本地pod
庫(kù)工程提交推送到遠(yuǎn)程倉(cāng)庫(kù)摊滔,打上Tag發(fā)布。
1.提交本地倉(cāng)庫(kù)店乐,并推送
/** cd Pod工程目錄 */
cd PodProject
/** git commit -m "提交信息" */
git commit -m "commit"
/** git branch -M 分支 */
git branch -M main
/** git remote add origin git倉(cāng)庫(kù)地址 */
git remote add origin https://github.com/XXXX.git
/** git push -u origin 分支 */
git push -u origin main
2.打上Tag發(fā)布
/** 新建tag git tag [tagName] */
git tag "0.0.1"
/** 推送單個(gè)tag至遠(yuǎn)端 git push origin [tagName] */
git push origin "0.0.1"
/** 推送本地所有tag git push origin --tags */
git push origin --tags
推送.podSpec
文件
檢查下本地repo
艰躺,如果有,繼續(xù)下一步眨八,反之腺兴,則重新在添加一次(pod repo add [name] [源倉(cāng)庫(kù)git地址]
);
pod repo list
本地倉(cāng)庫(kù)檢查無(wú)誤后廉侧,開(kāi)始將創(chuàng)建的Pod
庫(kù)中的.podspec
文件推送至指定源倉(cāng)庫(kù)页响;
首先,還是cd
到.podspec
文件的目錄下段誊,執(zhí)行以下操作:
/** 推送命令: pod repo push [repoName] [name].podspec */
pod repo push component RTCComponent.podspec
到這里所有流程已經(jīng)完成闰蚕;整個(gè)過(guò)程中的驗(yàn)證過(guò)程可能是最容易出問(wèn)題的,如果驗(yàn)證通過(guò)连舍,那么發(fā)布就不會(huì)有什么問(wèn)題没陡,所以如果驗(yàn)證沒(méi)有通過(guò)的話,發(fā)布也是不會(huì)成功的索赏;
文章的最后盼玄,我會(huì)把制作過(guò)程中所遇到的問(wèn)題一一匯總。
問(wèn)題匯總(Error)
- 問(wèn)題1: 校驗(yàn)失敗
** BUILD FAILED **
The following build commands failed:
CompileSwift normal x86_64
CompileSwiftSources normal i386 com.apple.xcode.tools.swift.compiler
CompileSwift normal i386
CompileSwift normal arm64
(4 failures)
Testing with `xcodebuild`.
解決辦法:在.podspec
文件中加入;參考iOS 指令集架構(gòu)
s.pod_target_xcconfig = { 'VALID_ARCHS' => 'x86_64 armv7 arm64' }
- 問(wèn)題2: 組件中依賴的第三方庫(kù)中有framework或者.a文件潜腻, pod install 報(bào)錯(cuò)
target has transitive dependencies that include statically linked binaries:
解決辦法: 在podfile文件中加入以下代碼埃儿;
pre_install do |installer| Pod::Installer::Xcode::TargetValidator.send(:define_method, :verify_no_static_framework_transitive_dependencies) {}
end
- 問(wèn)題3: Xcode setting ENABLE_BITCODE
You must rebuild it with bitcode enabled (Xcode setting ENABLE_BITCODE)
解決辦法:將target下 ENABLE_BITCODE
設(shè)置為 NO
參考文檔:
CocoaPods官方制作文檔
用 CocoaPods 私有庫(kù)提高團(tuán)隊(duì)的整體效率
GitHub 將使用 main替換掉 master等術(shù)語(yǔ)
走過(guò)路過(guò)不要錯(cuò)過(guò),覺(jué)得不錯(cuò)砾赔,來(lái)杯coffee??