一芥牌、新建工程LZDemo作為殼工程
1桨菜、添加Podfile文件
cd到你剛創(chuàng)建的工程目錄下源哩,執(zhí)行以下語句
pod init
然后會(huì)發(fā)現(xiàn)你的工程目錄下多了Podfile文件
2厘线、生成xcworkspace工程
執(zhí)行
pod install
3鸳惯、新建一個(gè)Lib(自己起名)文件夾商蕴,用來存放組件庫(其他獨(dú)立工程)
然后cd到Lib下
執(zhí)行
pod lib create TRUNetworking
其中TRUNetworking就是你自定義的一個(gè)工程名字,也就是你的其中一個(gè)組件或者業(yè)務(wù)模塊
然后根據(jù)提示芝发,生成pod工程模板
打開新建的TRUNetworking工程里的Example绪商,可以看到pods里面,有個(gè)ReplaceMe的文件辅鲸,意思就是要替換它格郁,換成我們自己需要對(duì)外提供的類。
新建一個(gè)類独悴,比如TRUNetworking例书,復(fù)制粘貼到ReplaceMe同級(jí)目錄下,并刪掉ReplaceMe.m文件
之后cd到Lib/TRUNetworking/Example/文件目錄下绵患,執(zhí)行
pod install
這個(gè)時(shí)候在Development Pods文件下會(huì)多出這兩個(gè)文件雾叭,這就是本地開發(fā)的pods文件
而Podfile的內(nèi)容其實(shí)是
pod 'TRUNetworking', :path => '../'
說明他獲取的是本地路徑
然后刪除Example for TRUNetworking里面的TRUNetworking類,不然運(yùn)行會(huì)因?yàn)轭愔貜?fù)報(bào)錯(cuò)落蝙。
至此织狐,一個(gè)組件的本地庫就創(chuàng)建完成了。
二筏勒、殼工程使用本地組件庫
首先cd到殼工程LZDemo目錄下移迫,修改LZDemo的Podfile文件,增加
pod 'TRUNetworking', :path => 'Lib/TRUNetworking'
執(zhí)行
pod install
這樣殼工程就pod到本地組件庫的內(nèi)容了管行,原理跟使用平時(shí)的第三方遠(yuǎn)程庫一樣厨埋。只不過這次使用的是本地的。只不過本地的pod放在了Development Pods文件夾里面捐顷,這個(gè)文件夾里的內(nèi)容其實(shí)是可以修改的荡陷,修改后立刻生效雨效,會(huì)比遠(yuǎn)程pod需要提交版本號(hào),本地再pod對(duì)應(yīng)的版本號(hào)方便得多废赞。
我們?cè)儆猛瑯臃椒▌?chuàng)建另一個(gè)本地工程徽龟,登錄模塊TRULogining
但是這個(gè)模塊需要依賴TRUNetworking,所以我們得在兩個(gè)地方添加依賴
由于依賴的TRUNetworking在更上一層的文件中唉地,所以需要../../
執(zhí)行
pod install
之后應(yīng)該能看到Development Pods里已經(jīng)有2個(gè)文件夾了
這個(gè)時(shí)候就可以import里面的類据悔,在本地使用了。
三耘沼、關(guān)聯(lián)git
完成了本地pod依賴极颓,但是我們肯定不會(huì)是個(gè)人開發(fā),否則弄這個(gè)組件化的意義也不大群嗤,所以我們首先得提交到遠(yuǎn)程菠隆,一般公司里都會(huì)搭建私有倉庫諸如GitLab,這里就拿GitHub來做演示骚烧。
1)提交殼工程到遠(yuǎn)程
首先浸赫,在Github上Create a new repository
然后闰围,cd回殼工程目錄下赃绊,依次執(zhí)行
git init
初始化git
git add .
執(zhí)行g(shù)it add .的時(shí)候,會(huì)發(fā)現(xiàn)警告warning: adding embedded git repository: Lib/TRULogining之類的羡榴,是因?yàn)門RULogining目錄下有它自己的git倉庫碧查,它倆是獨(dú)立存在的,有另外一個(gè)git倉庫專門管理他校仑,因?yàn)樗彩且粋€(gè)完整的獨(dú)立工程忠售,這里我們先忽略它。
然后迄沫,提交初始化工程
git commit -m "init project"
接下來稻扬,我們要讓這個(gè)工程和剛才在Github上創(chuàng)建的Repository關(guān)聯(lián)
git remote add origin https://github.com/liuzhao/LZDemo.git
git branch -M main
git push -u origin main
刷新一下Github上的LZDemo,會(huì)看到已經(jīng)提交上去了
2)提交子工程到遠(yuǎn)端
和提交主工程一樣的做法羊瘩,分別在Github上Create a new repository泰佳,然后把他們關(guān)聯(lián)起來
唯一和殼工程不同的是,他們是組件尘吗,需要對(duì)外提供依賴關(guān)系逝她。所以我們還得多做一步操作,那就是增加podspec文件睬捶。
以TRUNetworking為例黔宛,cd到TRUNetworking目錄下,執(zhí)行
git tag 0.1.0
git push --tags
刷新一下Github上的地址擒贸,會(huì)看到多了一個(gè)分支
這個(gè)tag分支就是將來提供給別人依賴的版本號(hào)分支臀晃,有了它觉渴,別人使用你的組件的時(shí)候就可以根據(jù)版本號(hào)來控制了。
接下來徽惋,使用trunk方式將代碼發(fā)布到CocoaPods上
首先先編輯一下podspec文件
改好后疆拘,在上傳之前,最好先本地檢查一下podspec是否合法
執(zhí)行下面語句
pod lib lint --verbose
或
pod lib lint --allow-warnings --verbose
如果出現(xiàn)passed validation寂曹,說明通過哎迄,可以提交到cocoapods上了
接著你需要注冊(cè)?個(gè)trunk賬號(hào):
pod trunk register '郵箱' '昵稱'
成功之后會(huì)有讓你打開郵箱進(jìn)?
驗(yàn)證的提示,打開你的郵箱點(diǎn)擊鏈接進(jìn)?驗(yàn)證隆圆。
驗(yàn)證之后漱挚,
輸?:pod trunk me
進(jìn)?驗(yàn)證,看是否激活成功渺氧。
執(zhí)行
pod trunk push TRUNetworking.podspec --verbose
或
pod trunk push TRUNetworking.podspec --allow-warnings(可能需要?會(huì))
成功后旨涝,就可以pod search到我們提交的庫了
ps:如果搜不到,不是沒傳成功侣背,是我們的本地搜索庫沒更新白华,可以先刪除~/Library/Caches/CocoaPods目錄下的search_index.json文件或者pod repo update一下
終端執(zhí)行
rm ~/Library/Caches/CocoaPods/search_index.json
再執(zhí)行
pod search
這樣,本地庫就會(huì)變成遠(yuǎn)程庫贩耐,我殼工程的podfile文件就可以改成
pod 'TRUNetworking'弧腥,而不再需要后面的path了
重新對(duì)殼工程LZDemo進(jìn)行pod install之后,會(huì)發(fā)現(xiàn)潮太,原來的TRUNetworking文件已經(jīng)從Development Pods里跑到Pods里去了
一些注意點(diǎn):
1)如果pod trunk push上去的podspec文件管搪,如果有依賴庫,這個(gè)依賴庫必須是在cocoapods上铡买,即使是不能依賴本地庫更鲁,而是遠(yuǎn)程庫。所以說奇钞,比如剛才創(chuàng)建的TRUNetworking和TRULogining澡为,如果要發(fā)布TRULogining到cocoapods,但是由于TRULogining是依賴于TRUNetworking的景埃,所以要首先將TRUNetworking提上到cocoapods上媒至,否則TRULogining是提不上去的。
2)由于殼工程和子工程都有獨(dú)立存在的git纠亚,所以別人從殼工程的git地址clone下來的工程塘慕,是沒有子工程的存在的。如果想運(yùn)行起來殼工程蒂胞,要么是所有的子工程都已經(jīng)提到cocoapods上图呢,要么是拿到子工程的git地址,checkout到本地殼工程的Lib庫下。
3)如果你不想每簡歷一個(gè)子工程蛤织,都要到Github或者GitLab上創(chuàng)建一個(gè)repository的話赴叹,又想把子工程push到殼工程的git上的話,可以先把子工程里的git刪除指蚜,這樣push上的殼工程代碼乞巧,就會(huì)帶上子工程了,等你需要單獨(dú)管理子工程的時(shí)候摊鸡,再把git加回去即可绽媒。
版本更新
1.代碼更新
cd 項(xiàng)目的目錄
git init
git add .
查看代碼的修改
git status
//modified 標(biāo)示修改的文件
//deleted標(biāo)示刪除的文件
// untracked files 未處理的文件 需要執(zhí)行 git add方法添加上去
提交代碼
git commit -m ‘注釋’ 注意添加注釋
同步代碼
git pull
把代碼推到服務(wù)器上
git push origin
git tag 0.1.0(最新的版本)
git push --tags
pod lib lint --allow-warnings --verbose
pod trunk push TRUNetworking.podspec --allow-warnings