1. 程式人生 > >如何釋出自己的開源框架到CocoaPods---持續更新中

如何釋出自己的開源框架到CocoaPods---持續更新中

如何釋出自己的開源框架到CocoaPods

——在專案所在目錄下執行* pod init * , 生成Podfile檔案, 我們需要對其進行相應的配置。

在開發過程中,經常會使用到第三框架,我們通過一個pod install命令,很方便的就將第三方框架加到我們自己的專案中。
用CocoaPods做iOS程式的依賴管理

1. 在github建立倉庫完成,需要將倉庫檢出到本地(擷取網上的例子)

注意:LICENSE(許可證)檔案不可缺少,否則檢測spec檔案時,會有警告

2. 將寫好開源框架/庫的Demo或者Example放到Git倉庫下,還要將要開源的資料夾也放入到git倉庫中(該資料夾在後面會被用到)(擷取網上的例子)

3. 專案釋出到github後,我們在工程根目錄中初始化一個Podspec檔案:建立自己專案的Podspec描述檔案:

pod spec create ECGCustomAlertView

  1. 該命令將在本目錄產生一個名為ECGCustomAlertView.podspec檔案。用編輯器(命令列:vim ECGCustomAlertView.podspec)開啟該檔案,裡面已經有非常豐富的說明文件。下面介紹如何宣告第三方庫的程式碼目錄和資源目錄,還有該第三方庫所依賴ios核心框架和第三方庫。這是我的podspec檔案:
    這裡寫圖片描述
    這裡寫圖片描述
    這裡寫圖片描述
    這裡寫圖片描述
    這裡寫圖片描述
    這裡寫圖片描述
    這裡寫圖片描述
    s.name:名稱,pod search 搜尋的關鍵詞,注意這裡一定要和.podspec的名稱一樣,否則報錯 s.version:版本號 s.ios.deployment_target:支援的pod最低版本 s.summary: 簡介 s.homepage:專案主頁地址 s.license:許可證 s.author:作者 s.social_media_url:社交網址,這裡我寫的微博預設是Twitter,如果你寫Twitter的話,你的podspec釋出成功後會@你 s.source:專案的地址 s.source_files:需要包含的原始檔 s.resources: 資原始檔 s.requires_arc: 是否支援ARC s.dependency:依賴庫,不能依賴未釋出的庫,如 s.dependency = ‘AFNetworking’ s.dependency:依賴庫,如有多個可以這樣寫。我這裡是託管在github上,所以這裡將地址copy過來就行了。


    source_files: 核心程式碼的檔案地址。注意:這裡是經常出錯的地方!—如果使用的是這種方式來顯示核心程式碼地址而不是下面的模組化的話,注意:需要將程式碼檔案必須以倉庫名命名(也就意味著最多隻有兩個檔案.h和.m檔案了,可以有一個.h檔案,把它作為標頭檔案就行),這種方式檢驗podspec檔案有點嚴格,否則就會報錯。
    寫法及含義建議大家寫第一種或者第二種。
    這裡寫圖片描述
    “ECGCustomAlertView/*”
    “ECGCustomAlertView/ECGCustomAlertView/*.{h,m}”
    “ECGCustomAlertView/*/.h”

    “*” 表示匹配所有檔案
    “*.{h,m}” 表示匹配所有以.h和.m結尾的檔案
    “**” 表示匹配所有子目錄

4. 模組化

  1. 通過PodSpec的subspec 可以使一個專案能模組化輸出功能 ,一個例子:
Pod::Spec.new do |s|
  s.name         = "iOS_Util"
  s.version      = "0.10.0"
  s.summary      = "Some iOS Util"

  s.license      = 'MIT'

  s.author       = { "文通" => "[email protected]" }


  s.platform     = :ios, '6.1'

  s.ios.deployment_target = '4.3'

  s.subspec 'Common' do |cos|
    cos.source_files = 'iOS_Util/Common/*.{h,m}'
    cos.public_header_files = 'iOS_Util/Common/*.h'
  end

  s.subspec 'Core' do |cs|
    cs.source_files = 'iOS_Util/Core/*.{h,m}'
    cs.public_header_files = 'iOS_Util/Core/*.h'
    cs.dependency 'libextobjc', '0.2.5'
  end

  s.subspec 'Json' do |js|
    js.source_files = 'iOS_Util/Json/*.{h,m}'
    js.public_header_files = 'iOS_Util/Json/*.h'
    js.dependency 'iOS_Util/Core'
  end

  s.subspec 'Bean' do |bs|
    bs.source_files = 'iOS_Util/Bean/*.{h,m}'
    bs.public_header_files = 'iOS_Util/Bean/*.h'
    bs.dependency 'iOS_Util/Core'
  end

  s.subspec 'DB' do |ds|
    ds.source_files = 'iOS_Util/DB/*.{h,m}'
    ds.public_header_files = 'iOS_Util/DB/*.h'
    ds.dependency 'FMDB/standard' ,'~> 2.1'
    ds.dependency 'iOS_Util/Common'
    ds.dependency 'iOS_Util/Core'
  end

  s.subspec 'WebP' do |ws|
    ws.source_files = 'iOS_Util/WebP/*.{h,m}'
    ws.public_header_files = 'iOS_Util/WebP/*.h'
    ws.dependency 'libwebp' ,'~> 0.3.0-rc7'
    ws.frameworks = 'CoreGraphics'
  end

  s.subspec 'Location' do |ls|
    ls.source_files = 'iOS_Util/Location/*.{h,m}'
    ls.public_header_files = 'iOS_Util/Location/*.h'
    ls.dependency 'iOS_Util/Common'
    ls.dependency 'iOS_Util/DB'
    ls.frameworks = 'CoreLocation' ,'MapKit'
    ls.resource = 'iOS_Util/Location/chinaDivision.sqlite'
  end

  s.subspec 'AMR' do |as|
    as.source_files = 'iOS_Util/AMR/**/*.{h,m,mm}'
    as.public_header_files = 'iOS_Util/AMR/**/*.h'
    as.preserve_paths = "iOS_Util/AMR/**"
    as.library   = 'opencore-amrnb','opencore-amrwb'
    as.xcconfig  = { 'LIBRARY_SEARCH_PATHS' => '"$(PODS_ROOT)/iOS_Util/iOS_Util/AMR/lib"' }
  end

  s.subspec 'Cache' do |cas|
    cas.source_files = 'iOS_Util/Cache/*.{h,m,mm}'
    cas.public_header_files = 'iOS_Util/Cache/*.h'
    cas.dependency 'iOS_Util/Common'
  end

  s.subspec 'Preference' do |ps|
    ps.source_files = 'iOS_Util/Preference/*.{h,m,mm}'
    ps.public_header_files = 'iOS_Util/Preference/*.h'
    ps.dependency 'iOS_Util/Json'
  end

  s.requires_arc = true



end

5. 設定tag號,提交修改(注:只要spec檔案被修改,就必須重新執行如下命令)

git commit -m "Release 1.0.1"  (先提交當前修改)
git tag 1.0.1            (新增tag)
git push --tags         (推送tag到遠端)
git push origin master  (推送到遠端到程式碼倉庫)

6. 提交之前先驗證.podspec檔案是否合法

pod spec lint ECGCustomAlertView.podspec  
pod spec lint ECGCustomAlertView.podspec --allow-warnings     (忽略警告)
  • 錯誤列表
    這裡寫圖片描述
    從錯誤資訊中得到:我的專案編譯不通過:ECGLoadsAlertViewController.h 類檔案找不到,需要將專案錯誤的地方修改掉,如果顯示這樣的提示資訊:

  • 驗證通過
    這裡寫圖片描述
    那麼就是已經配置成功,可以提交到cocoapods了,否則要將所有提示的error和warn修改掉。

7. 驗證.podspec檔案報錯,解決方法

  • 先刪除tag
// 刪除本地tag
git tag -d 1.0.0
// 刪除遠端tag
git push origin -d tag 1.0.0
  • 修改spec檔案(必須修改相應的version和source)
  • 重新執行–>設定tag號,提交修改的步驟

8. podspec檔案驗證成功,通過trunk推送podspec檔案

pod trunk push ECGCustomAlertView.podspec
  • 如果有如下提示,需要你用郵箱註冊一個trunk
    這裡寫圖片描述

  • 用郵箱註冊trunk(建議:用github註冊的郵箱地址為好,外加使用者名稱–>gitub的使用者名稱(我用郵箱使用者名稱也通過了))

pod trunk register 郵箱地址 "使用者名稱" --description="macbook pro"
  • 之後會有一封帶有驗證連結的郵件傳送到你輸入的郵箱,點選驗證後就可以回來終端繼續提交操作了。

9. 提交到cocoapods

pod trunk push ECGCustomAlertView.podspec
pod trunk push ECGCustomAlertView.podspec --allow-warnings
  • 我碰到了個錯誤提示1:
    這裡寫圖片描述
  • 網上查的解決方法:解決方案
    實質:If you get this error message:(如果你獲得這個錯誤資訊:)
    這裡寫圖片描述
    You need to set and unset that rename limit:
    這裡寫圖片描述
git config merge.renameLimit 999999
git config --unset merge.renameLimit
  • 我碰到的錯誤資訊2:
    這裡寫圖片描述

  • 該錯誤為:無法開啟TCP連線到trunk.cocoapods.org:
    具體原因我沒有找出來,我的解決辦法是重新修改spec配置檔案(vim),需要修改版本號,然後繼續提交就成功了!

  • 然後繼續提交到cocoapods,如果成功會出現:
    這裡寫圖片描述

10. Cocoapods: pod search無法搜尋到類庫的解決辦法

  • 刪除~/Library/Caches/CocoaPods目錄下的search_index.json檔案
 pod setup成功後會生成~/Library/Caches/CocoaPods/search_index.json檔案。
 終端輸入rm ~/Library/Caches/CocoaPods/search_index.json
 刪除成功後再執行pod search

稍等片刻就會出現你所要搜的類庫了。

11. podspec檔案更新方法

  • 以後我們的庫有新版本時,我們可以修改相應的version和source。

  • 有時你可能會遇到這種情況:執行pod trunk push操作後發現podspec檔案的某個地方寫錯了,想更新一下。對於這種情況,我們可能會先嚐試著在把podspec檔案push一次。但是如果你的程式碼版本號沒變(podspec裡的version自然也沒變)就會提示push失敗,即使你更改了podspec的其他地方,pod也會認為這兩個檔案是同一個。 我目前為止找不到trunk的相關update介面,所以只能順水推舟,更新原始碼版本號(如:1.1.1->1.1.2),重新push version tag,然後再執行pod trunk push操作。

  • 後來遇到的坑:


    • 1.通過程式碼建立的podspec檔案裡面都是雙引號,博主用的都是單引號,經測試,無影響,還有UIKIT等庫和第三方庫的引入,以及版本升級,這一部分已經放在這裡;

    • 2.發現一個問題,如果你在某個庫中用了NSInteger,會報警告,原因是:typedef long NSInteger;類似這種情況的還有別的,如果遇到你可以替換成像這裡應該是long,也可以選擇忽略警告,比如:pod trunk push ScrollSliderView.podspec –allow-warnings;

    • 3.有時候在push時會遇到這樣的報錯:[!] There was an error pushing a new version to trunk: Net::OpenTimeout 不要驚慌,僅僅是因為網路不好沒有push成功,不妨再試一次。

相關推薦

如何釋出自己開源框架CocoaPods---持續更新

如何釋出自己的開源框架到CocoaPods ——在專案所在目錄下執行* pod init * , 生成Podfile檔案, 我們需要對其進行相應的配置。 在開發過程中,經常會使用到第三框架,我們通過一個pod install命令,很方便的就將第三方框架加

Github上比較實用的開源專案(持續更新

https://github.com/hongyangAndroid/FlowLayout Android流式佈局,支援單選、多選等,適合用於產品標籤等 AutoCompleteTextView for android with KMP algorithm https:/

優秀的Android開源框架持續更新

開源是軟體發展的趨勢,越來越多的人投入到開源世界中去。我們可以從開源世界中獲得很多有益的東西,本著不重複造輪子的精神,我們應該充分利用這些開源專案的成果。本文會持續更新湧現出來的優秀開源框架。 UI BottomNavigation and

【從0開始Tornado建站】0.9版本號python站點代碼開源--持續更新

分享 body clas .com tis https -m SM 。。 ? ? ? ? 從5月份開始【從0開始Tornado建站】這個專欄,開始一點一點把這個分類

golang開發常用開源項目工具(持續更新

golang開源項目 golang工具 本人在日常golang項目開發中,用到了一些第三方開源庫,大多都是優秀的開源項目,源碼值得認真閱讀研究。在此記錄用到的一些庫:解析配置文件go-ini https://github.com/go-ini/inigolang開發常用開源項目工具(持續更新中)

2018年阿里巴巴重要開源專案彙總(持續更新

摘要: 雲棲社群特在2018年年末,將阿里巴巴的一些重要的開源專案進行整理,希望對大家有所幫助。 開源展示了人類共同協作,成果分享的魅力,每一次技術發展都是站在巨人的肩膀上,技術諸多創新和發展往往就是基於開源發展起來的,沒有任何一家網路公司可以不使用開源技術,僅靠自身技術而發展起來。阿里巴巴各個團

總結Spring框架擴充套件點(二)bean生命週期的擴充套件點(持續更新...)

面向業務開發的時候,程式設計師需要明白業務的邏輯,並設計程式碼結構。而在進行中介軟體開發的時候,則需要明白框架的邏輯,進行開發。 所以要開發提供給spring的中介軟體,需要知道spring中有哪些擴充套件點,好在對應的地方插入我們的功能。 1. Spring容器初始化b

從零開始搭建Detox自動化測試框架測試React Native (IOS/Andriod)也許是全網最全的教程 持續更新

構建APP並執行用例 構建APP 編譯 debug模式 detox build --configuration ios.sim.debug release模式 detox build --configuration ios.sim.release 5.2 執

Android精品開源專案整理_V20140221(持續更新..)

讓我們回顧下2013年有哪些精品資源:Android精品開源專案整理_V20131115(持續更新中..)引言:    成長和上升並不意味著前路永無止境,更不等於是無休止的重複勞作,行百里者半九十,許多人因為平時交流就太少,更沒有機會開拓眼界,加上對知識和技能的理解運作不當,

ASP.NET Core框架揭祕(持續更新…)

之前寫了一系列關於.NET Core/ASP.NET Core的文章,但是大都是針對RC版本。到了正式的RTM,很多地方都發生了改變,所以我會將之前釋出的文章針對正式版本的.NET Core 1.0進行改寫。除此之外,我還會撰寫一系列與此相關的文章,這些文章以ASP.NET Core為核心,我個人將它們分成三

專案框架搭建用到的第三方框架—3(持續更新

專案框架搭建用到的第三方框架—3 QMUI_Android Git地址: https://github.com/QMUI/QMUI_Android 官網: https://qmuiteam.com/android/ Api說明地址 https://qmuitea

自己測試過程總結的易忽略的測試點和經驗--持續更新

1.app多語言測試中,彈窗一般會出現居中問題。德語和法語容易在按鈕和固定大小的控制元件上超出長度 2.web測試中,對各個輸入框的報錯提示可能會有重疊情況。 3.自動化測試中,頁面如果重新整理了,控制元件就得重新定位。所以定位的程式碼放在哪很重要

Gradle 匯入開源工程 常見問題解決方法(持續更新)

1. build時出現以下錯誤 Cause: peer not authenticated 通常情況下這是HTTPS下載時認證不通過造成的。這時可看出現問題的連結是什麼,如果是下載gradle外掛自身,則可以找到gradle/wrapper/gradle-wrapper.

react專案框架環境搭建(持續更新

一、建立react專案 1.1 install node 1.2 命令列:npx create-react-app my-app (npx comes with npm 5.2+ and higher) 利用react官方提供的腳手架建立專案,建立完一

React Native開源專案-嘎嘎商城客戶端(持續更新)

歡迎大家star,fork.... 專案介紹基於React Native 實現的嘎嘎商城客戶端,暫時只是適配Android版本,暫時大部分佈局頁面正在開發中,業務邏輯功能以及iOS版本適配會後面進行。當前的商城客戶端後期會繼續開發商品點單,訂單,購物車,支付,商品列表以及詳情

精彩的 Silverlight 開源專案(持續更新...)

The Unity Application Block (Unity) is a lightweight extensible dependency injection container with support for constructor, property, and method call inje

gradle匯入開源工程常見的錯誤(持續更新)

Gradle是一個基於Apache Ant和Apache Maven概念的專案自動化建構工具。它使用一種基於Groovy的特定領域語言來宣告專案設定,而不是傳統的XML。當前其支援的語言限於Java、Groovy和Scala,計劃未來將支援更多的語言。(百度上拿

讓微信小程式在瀏覽器和自己的App執行--自己寫的一個開源框架FreeMina(開發。。)

FreeMina: An open mina compatible framework for running in browser or webview. 一個相容微信小程式Mina框架的開源框架 從小程式的設計來看,微信正走向封閉生態。我們開發的微信

HTML5+Bootstrap後臺系統框架集(持續更新……)

HTML5+Bootstrap後臺系統框架集(更新時間:2017年1月8日。持續更新中……)科普:Bootstrap (Web框架):Bootstrap,來自 Twitter,是目前很受歡迎的前端框架。

How ASP.NET Web API 2.0 Works?[持續更新…]

throws case rep 生命 indexof http face auto 攔截 一、概述 RESTful Web API [Web標準篇]RESTful Web API [設計篇] 在一個空ASP.NET Web項目上創建一個ASP.NET Web API 2.