美文网首页
iOS SDK制作上传Pods的repo公共库管理包含.fram

iOS SDK制作上传Pods的repo公共库管理包含.fram

作者: shawnr | 来源:发表于2018-08-21 22:22 被阅读75次

    iOS SDK制作上传Pods的repo公共库管理

    开发SDK,并且SDK依赖别的未发布至pod库,需要依赖其他未发布至pod的SDK和.a等等,比较麻烦,所以SDK开发最好全部自己撸代码。
    网上查到的资料大部分不清楚,有的太老旧,
    所以在这儿整理下,加入自己的东西希望能有所帮助。环境 Xcode9.4.1,pod 1.5.3(关系不大)

    1. 发布pods的准备

    1. pod、github的账号,公司电脑的话可能还需要多.ssh账号的配置和管理,这些问题信息都有。

    2. 创建工程

    1. 进入指定文件夹使用pod命令创建模板工程
    pod lib create testSDK
    
    • 命令运行后会有一些配置项的选择如:

    What platform do you want to use?? [ iOS / macOS ]
    >
    What language do you want to use?? [ Swift / ObjC ]
    >
    等问题自己选择尽可以啦

    命令行生成模板工程.png

    2. pod工程的预览、.podspec文件的了解

    对于发布pod工程来说最重要的是.podspec文件的配置,该文件是管理pod版本,和能使别人搜索到你的SDK的关键

    1. 工程的结构:


      工程目录结构.png

    注意ReplaceMe.m文件,右键 Show in Finder,如果有Classes,assets文件夹拖入工程,否则创建Classes文件拖入工程


    添加文件的target选择.png
    1. .podspec文件的说明:
    s.name 是项目的名字
    s.version 是项目的版本控制,必须和tag一致(稍后提到)控制SDK的下载
    s.summary 项目的概要,最好修改下,否则pod验证时可能报错
    s.description 项目的描述,是概要的扩展,但是结构不可变,只能在TODO那一行增加东西,否则报错
    s.homepage 项目主页,必须为可以链接到的页面,能打开就行
    s.license 为协议,模板创建的不用改动
    s.author 不用改动
    s.source 这个也很关键,因为现在未提交至git库,所以没有链接,等提交后必须改动
    s.ios.deployment_target iOS开发的依赖版本
    s.source_files 为SDK库文件,打包SDK需要的.h、.m文件都在这里配置,稍后详细配置
    s.frameworks 所需依赖的系统库文件,只能是系统库,如:s.frameworks = 'AVFoundation', 'CoreMotion', 'CoreMedia'
    s.dependency 依赖的已经发布至pod库的第三方依赖,必须是已发布的,如:s.dependency 'AFNetworking'
    s.resources .bundle、.png文件等
    s.vendored_libraries 所需依赖的第三方库,未发布至pod仓库可以用此依赖,必须为.a的库
    s.vendored_frameworks 所需依赖的第三方库,未发布至pod仓库,为.framework库
    

    3. Github创建工程、并提交创建的工程至GitHub

    1. GitHub创建空仓库,license选None
    git创建工程.png
    1. 提交本地创建的工程至仓库
    git add .
    git commit -m ""
    git remote add origin https://github.com/xxx/xx.git
    git push -u origin master
    

    4. 配置.podspec文件

    • s.homepage默认的配置在浏览器中打不开所以选择git项目的链接 s.homepage = "https://github.com/xxx/xxxSDK"
    • s.source 项目已经提交到GitHub所以可以更改,一定腰围项目的git地址 s.source = { :git => 'https://github.com/edspayLei/XGCreditSDK.git', :tag => s.version.to_s }
    • s.summary 也必须修改
    • 接下来就要根据自己的项目进行特殊的配置啦。这里分情况介绍

    一、如果你准备pod的工程只是.h、.m以及一些图片资源的话。在ReplaceMe.m文件的位置,删除ReplaceMe.m文件,创建Classes,Resources文件夹,然后把用到的文件分别加入对应的文件夹
    • s.source_files = 'Classes/**/*.{h,m}'等,*是通配符,保证Classes 下的所有子文件中的.h、.m都能加载
    • s.resources = 'Resources/*.png'
    • s.dependency没有带s所以需要一个个的引用,还没有查复数的形式 s.dependency 'AFNetworking', '~> 3.2.1' s.dependency 'Masonry', '~> 1.1.0'

    注意文件的结构是相对于SDK文件夹的

    二、项目包含未发布至pod的第三方SDK、.a文件等的配置
    • s.vendored_libraries中加入依赖的和自己要发布的.a文件
      s.vendored_libraries = 'Classes/xxxSDK.a','Classes/xxxV2.2.1.a'
    • s.vendored_frameworks中加入依赖的和自己要发布的.framework文件:
      s.vendored_frameworks = 'Classes/xxx.framework', 'Classes/myself.framework'
    • .a库的特殊处理,因为s.vendored_libraries中引入的.a文件并不包含.a需要暴露出来的文件,所以需要在s.source_files中把要暴露的文件引用,注意相对目录,有图片资源的话处理方式相同

    要发布至pod的自己的.a或者.framework其实和依赖的未发布至pod的三方库处理方式相同

    5. 验证.podspec文件

    • 进入.podspec 所在的目录
    执行 pod lib lint
    
    • 错误处理


      pod lib lint 错误.png

    s.summary的错误,描述要修改下,git仓库地址链接错误,修改s.source = { :git => 'https://github.com/xxxx/xxxSDK.git', :tag => s.version.to_s }, 链接指向自己的SDK工程地址

    • 验证成功,几乎已经完成了,恭喜

    6. 提交到自己的GitHub,并验证

    • 首先确定版本,这里我的版本从'1.0.0'开始,修改s.version = '1.0.0'
    • 然后提交至自己的仓库
    git add .
    git commit -m ""
    git push origin master:master
    
    • 打tag 一定要和s.version = '1.0.0'相同,所以这里我们的tag为1.0.0
    git tag 1.0.0
    git push origin 1.0.0
    
    打tag.png
    • spec验证
    pod spec lint xxxSDK.podspec
    
    git URL错误的log.png

    错误处理

    分析是s.source 的问题,看链接是否为github的工程链接,修改
    改完之后重新提交github,这样我们的tag1.0.0就不行了,所以需要重新打tag,我们选用tag为@"1.1.0",重新开始提交到pod的步骤。

    验证通过的反馈:


    ![最后成功.png](https://img.haomeiwen.com/i1798452/4faf3c4af2c60edd.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

    7. 提交.podspec文件至pod库

    • 以上步骤都正确后,可以进行pod库的提交
    pod trunk push xxxSDK.podspec
    

    成功的反馈:

    • .podspec推送至pod库,提交成功之后的搜索
    pod search xxxSDK
    错误 [!] Unable to find a pod with name, author, summary, or descriptionmatching `LPodTest
    

    错误处理


    pod库需要更新.png
    1. pod setup (不行,实用方法二)
    2. pod repo update(不行,试用方法三)
    3. 前往这个路径下~/Library/Caches/CocoaPods删除search_index.json文件 , 或者使用终端命令删除:
    ```
    rm -rf  ~/Library/Caches/CocoaPods/search_index.json
    ```
    

    然后重新搜索

    删除本地pod索引库.png

    参考 ToSimple 参考链接 https://www.jianshu.com/p/41611b14942b

    相关文章

      网友评论

          本文标题:iOS SDK制作上传Pods的repo公共库管理包含.fram

          本文链接:https://www.haomeiwen.com/subject/bwssiftx.html