二方库

作者: _哈哈哈哈哈哈 | 来源:发表于2022-02-22 12:05 被阅读0次

    制作https://www.cnblogs.com/163yun/p/9154793.html 

    ls 

    open a

    pod search WYLib

    git tag 0.1.0   git push --tags

    二方库的使用    

    注意WYLibLabel 一定要在class前面加上public 不然是读取不到的

    二方库的更新: pod install无法更新二方库 

    原因: pod install和pod update的区别

    pod install

    Analyzing dependencies

    Pre-downloading: `WYLib` from `git@github.com:ZWQ123456789aaabbb/WYLib.git`

    Downloading dependencies

    Installing WYLib (0.1.1)

    Generating Pods project

    Integrating client project

    [!] Please close any current Xcode sessions and use `MyTestPod.xcworkspace` for this project from now on.

    Pod installation complete! There is 1 dependency from the Podfile and 1 total pod installed.

    ➜  MyTestPod git:(main) ✗ pod install

    Analyzing dependencies

    Downloading dependencies

    Generating Pods project

    Integrating client project

    Pod installation complete! There is 1 dependency from the Podfile and 1 total pod installed.

    ➜  MyTestPod git:(main) ✗ pod update WYLib

    Updating local specs repositories

    Analyzing dependencies

    Pre-downloading: `WYLib` from `git@github.com:ZWQ123456789aaabbb/WYLib.git`

    Downloading dependencies

    Installing WYLib 0.1.1

    Generating Pods project

    Integrating client project

    Pod installation complete! There is 1 dependency from the Podfile and 1 total pod installed.

    pod install和pod update的区别:

    很多人认为pod install只在第一次使用cocoapod设置项目的时候使用,pod update是在设置完项目之后使用的,但事实不是这样

    那什么时候使用pod install,什么时候使用pod update:

    1. 当你需要向你的项目中安装/删除新的pod库时使用pod install。即使你之前已经有一个podfile并且执行了pod install

    2. 只有当你想要更新pod库版本(或者pod库没有升版本但是代码改动了) 才使用pod update

    pod install: 

    每次pod install命令运行的时光,pod install会为每一个它安装的pod库在podfile.lock文件中写入其版本号,并锁定这些版本号

    当你运行pod install的时候,它将只解决不在Podfile.lock中的pod库依赖关系

        对于在pod file.lock文件中的pod库,pod install会只下载pod file.lcok文件中指定的版本,而不会去检查这个库是否有新的版本 

       对于不在podfile.lock文件中的pod库,pod install会搜索pod库在podfile文件中指定的版本

    pod update: 

    当你运行pod update podName命令,cocoapods会在不考虑pod file.lock版本的情况下试着去查找podName的最新版本

    测试二方库的时候

    本地: pod 'WYLib', :path=>'/Users/ahs/WYLib'  (不需要branch)

    远端:  pod 'WYLib', :git => 'git@github.com:ZWQ123456789aaabbb/WYLib.git', :branch=> 'feature/btb-10809'

    什么时候使用本地什么时候使用远端:

    没啥区别,本地的更方便一点,不用每次二方库的代码都进行提交。但是如果有一个库依赖于这个二方库,你改动了,本地和远端不一样,它就不知道依赖于哪一个了

    所以还是远端吧

    我改了一个二方库,主要工程pod update确认没问题(有时候pod update失败,那就本地,然后用pod install(可能都不需要pod install: 如果没有增删文件就不需。改变二方库的代码是在example里的pod文件)), 提交合并到master/ 主工程: 

    合并后发布(ld) -> 升版本

    集成包的时候podfile和远端一致,有冲突以远端为准

    + GitHub ssh的形式

    创建私有库的过程: 

    1. 创建pod项目工程文件

    pod lib create WYLib

    创建一个新的git地址 将远程的WYLib和你刚才用命令创建的本地WYLib进行关联,并push, 然后打上tag,将tag推送到远端 git tag 0.1.0 git push --tags

    你的这个二方库创建的时候记得有example

    结构如下图:

    注意看二方库要暴露出的文件 所存放的路径是在classes下面

    如何添加文件

    在classed路径下新增一个文件夹 -> 然后你打开example,就可以看见那个文件夹(在pods路径下)

    如何修改文件

    打开example,看到pods下的文件直接修改就行。example项目里用到的二方库文件,点进去就是pods路径下的文件。是一一对应的

    还有就是用pod lib lint的方式创建更好,这样会自带example

    2. 创建一个新的podspec远程仓库

    pod repo add DemoSpecs 远程podspec地址 ->向本地添加一个自己的podspec 并和远程关联,这时候git@code.aihuishou.com:zhuwenqi/zhuspecs.git目录下还是空的,因为你还没有向你的spec repo提交.podspec文件

    显示:

    创建成功后进入 cd ~/.cocoapods  open .  ->就可以看到这个目录下有DemoSpecs

    3. 检查合法性

    在WYLib.podspec路径下:pod lib lint

    4. 向spec repo提交你的WYLib.podspec 

    pod repo push DemoSpecs  WYLib.podspec --allow-warnings

    这一步执行完毕在git@code.aihuishou.com:zhuwenqi/zhuspecs.git目录下可以看到WYLib 0.1.0的目录,点开目录是版本为0.1.0的WYLib.podspec

    -> 这时你的测试项目在pod install之前还需要pod repo update一下,你直接pod install也会提示你为pod install --repo-update 执行pod repo update之后可以看到WYLib 0.1.0 + WYLi b0.1.1的目录,点开WYLib0.1.1目录是版本为0.1.1的WYLib.podspec

    git@code.aihuishou.com:zhuwenqi/zhuspecs.git是你远程spec repo的地址 不是你远程要测试的项目的地址

    4. 使用私有podspec

    # Uncomment the next line to define a global platform for your project

    platform :ios, '9.0'

    source 'git@code.aihuishou.com:zhuwenqi/zhuspecs.git'

    target 'MyTestPod' do

    #pod 'WYLib', :git => 'git@github.com:ZWQ123456789aaabbb/WYLib.git'

    #pod 'WYLib', :path=>'/Users/ahs/WYLib'

    pod 'WYLib',  '0.2.4'

    end

    二方库的代码发生了改变 -》主工程是pod update还是pod install呢(引用方式为git地址的形式: #pod 'WYLib', :git => 'git@github.com:ZWQ123456789aaabbb/WYLib.git') 应该是podfile文件改变就是pod install,其他pod update(这时候如果用pod install可以吗,能成功把更改后的二方库代码拉取下来吗)。

    5. 为什么用source,也就是你的DemoSpecs仓库

    你看pjt的项目

    (master分支)所有的二方库的引入都是用版本号的形式,没有二方库的地址,如果没有source,怎么知道去哪里下载这个二方库呢。当然我们自己在需求分支上开发的时候可以用git地址形式+二方库的需求分支

    备注: 不要忘记souce

    还有就是pod install / pod update都是绝对路径

    pod repo的命令都是相对路径 -> 不是非要在哪个项目路径下执行,都可以

    相关文章

      网友评论

          本文标题:二方库

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