iOS pods创建私有库

如何创建私有库

要创建私有Pod,首先我们需要两个私有仓库,code repo放私有Pod源码,spec repo放私有Pod的说明书(类似公有Pod的CocoaPods/Specs)。

repo简介

  • code repository:代码仓库,我们把项目代码上传到这个仓库。
  • spec repository:配置仓库,所有的配置按照包名、版本号分门别类的存放在这个仓库。这个仓库只用来存放.Podspec文件,不存放代码。


    image.png

步骤

  1. 如果之前已经有私有spec repo,无需再建。如果没有,需要新建。创建一个私有的Spec Repo,添加其到本地 - 在本地创建一个叫bbaseRouter的文件夹


    image.png

建立 本地代码仓库添加远程spec repo,可以理解为建立远程spec repo 的关联关系

pod repo add [Private Repo Name] [your_privateSpecs.git]
image.png

如果执行成功,之后便可以通过pod repo list命令查看本地Spec仓库列表,正常情况下会有一个公有的CocoaPods官方的master repo 和你的 privateSpecs repo,并可以看到它们在本地的存放路径(其实在~/.cocoapods/repos目录下)。

  1. 在想要创建的目录文件夹下,创建Pod私有库 (上图中以及包含该脚本)

    pod lib create BBaseRouter
    

    目录结构如下:

├── Example                              #demo APP
│   ├── BBaseRouter
│   ├── BBaseRouter.xcodeproj
│   ├── BBaseRouter.xcworkspace
│   ├── Podfile                             #demo APP 的依赖描述文件
│   ├── Pods                                #demo APP 的依赖文件
│   └── Tests
├── BBaseRouter                           #库目录
│   ├── Assets                              #资源文件
│   └── Classes                             #类文件
├── BBaseRouter.podspec                   #podspec文件
└── _Pods.xcodeproj -> Example/Pods/Pods.xcodeproj
主要有两部分组成:
* BBaseRouter: 组件源码
* Example:Demo 工程,会依赖 BBaseRouter 库到此 demo 工程,方便调试

>pod lib会从 github 下载模版工程,创建完成会自动打开 Example 下的BBaseRouter.xcworkspace,在 pod 的工程下有一个Development Pods目录,pod 把我们的源码做为 Demo 工程的一个 pod 库,这跟实际使用是一样的了,只不过我们要改源码。
  1. gitlab新建仓库;

  2. 将本地代码上传到gitlab

    • 首先进入刚才创建的仓库,即要上传代码的目录
cd BBaseRouter
* 执行git命令,此命令会在当前目录下创建一个.git文件夹
git init
* 将本地的仓库关联到gitlab上
git remote add origin https://gitee.com/lumic/BBaseRouter.git

* 将项目的所有文件添加到仓库中
```
//这个命令会把当前路径下的所有文件,添加到待上传的文件列表中。如果想添加某个特定的文件,只需把.换成特定的文件名即可.

git add .


    * 将add的文件commit到仓库
    ```
git commit -m "注释语句"
* 上传代码到gitlab远程仓库
```

git push -u origin master


    * 如果不小心将git远程地址配错了,再次配置提示以下错误:
    > fatal: 远程 origin 已经存在。

    此时只需要将远程配置删除,重新添加即可:
    ```
git remote rm origin
git remote add origin  https://gitlab.corp.cootek.com/pgd_portfolio/sdk/ios/bbaserouter.git
git push -u origin master

po
* 如果远程仓库已经有提交或者改动,本地仓库没有更新远程仓库的内容,需要将远程代码库与本地代码库同步一下
```
git pull origin master


    但是可能会出现“fatal:拒绝合并无关历史。”的错误 ,需要用
    ```
git pull origin master --allow-unrelated-histories
截屏2020-03-13下午2.51.04.png

截屏2020-03-13下午2.51.40.png

![截屏2020-03-13下午2.59.44.png](https://upload-images.jianshu.io/upload_images/616981-265042b42d267286.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
  1. 修改podspec文件的内容

除了采用pod 自动从 github 下载pod模版工程的方法,同样也可以基于原有的项目工程文件建立pod库。

操作方式:
在私有Pod代码所在文件夹下执行pod spec create your_podName,则就会在该目录下创建一个your_podName.podspec说明书文件,之后便可以编辑这个说明书文件了。

  1. 进入podfile目录,pod install检测demo的有效性

pod库的开发过程中,向Pod文件夹中添加库文件和资源,然后进入podfile文件所在的目录下执行pod install命令,pod组件已经在Pods子工程下Development Pods/目录中了,然后编辑demo工程,测试组件。新建的pod库没有在Pods目录下是因为本地测试的缘故。

  1. 提交源代码并打tag,检测podspec文件的有效性
 pod spec lint BBaseRouter.podspec --allow-warnings

 git tag -m "first release" 0.1.0
 git push --tags     #推送tag到远端仓库

因为podspec文件中获取Git版本控制的项目需要tag号,所以我们要打上一个tag。


截屏2020-03-13下午2.59.51.png

注意:这里tag必须跟podspec文件中的tag保持一致,因为CocoaPods是通过podspec文件中的tag去找源文件的,如果tag对应不起来就会验证失败。

  1. 验证podspec文件有效性

    有两种验证方式:

    • 本地验证:pod lib lint your_podName.podspec
    • 联网验证:pod spec lint your_podName.podspec
    pod lib lint
    pod lib lint 如果有警告,会导致无法通过,需要添加--allow-warnings,允许警告
    如果使用了c函数或静态库,需要添加--use-libraries
    如果同时依赖了公有库和私有库,你必须指定源才行,因为默认只会去公有源中查找对应的依赖,需要添加库的源--sources='https://xxxx'
    

验证通过后,代表这个podspec文件是合格的。


截屏2020-03-13下午2.59.44.png
  1. 向Spec Repo提交podspec(提交说明书文件到私有说明书库)
pod repo push bbaseRouter BBaseRouter.podspec
#前面是本地Repo名字(就是本地代码仓库文件夹名称) 后面是podspec名字 (spec的名称)
#同样的加上上面验证时使用到的可选参数
截屏2020-03-13下午3.01.55.png
  1. 私有组件库制作完成后,可以使用pod search命令验证一下。


    image.png

SubSpec:
配置subspec

  s.subspec 'Analytics' do |ss|
    ss.dependency 'UMengAnalytics', '~> 4.2.4'
    ss.source_files = 'BBaseRouter/Classes/Analytics/**/*'
    ss.public_header_files = 'BBaseRouter/Classes/Analytics/*.h'
  end

这里上传代码到远程分支。打tag,并pod repo push bbaseRouter BBaseRouter.podspec 。这里的tag需要和podspec中的版本保持一致

执行 pod lib lint 报错 我们使用pod lib lint --allow-warnings


image.png

在 pod repo push bbaseRouter BBaseRouter.podspec --allow-warnings


image.png
image.png

如何引入subspec,只需要在podfile文件中修改,这是后我们只会导入子subspec中的文件

source 'https://github.com/CocoaPods/Specs.git'
source 'https://gitee.com/lumic/BBaseRouterSpec.git'

use_frameworks!

platform :ios, '8.0'

target 'BBaseRouter_Example' do
#  pod 'BBaseRouter', :path => '../'

pod 'BBaseRouter/Analytics', '~> 0.2.0'

  target 'BBaseRouter_Tests' do
    inherit! :search_paths

    
  end
end

image.png

开发过程中,我们只要在Example文件中pod install 将代码拉到本地Development Pods中进行开发


image.png

PO:可能遇到错误

ERROR | [iOS] unknown: Encountered an unknown error (The 'Pods-App' target has transitive dependencies that include static binaries: (/private/var/folders/_r/rtmkt9590l7gkq8zscryyqz80000gn/T/CocoaPods-Lint-20180419-3650-1tkys6n-CBBase58/Pods/OpenSSL-Universal/lib-ios/libcrypto.a and /private/var/folders/_r/rtmkt9590l7gkq8zscryyqz80000gn/T/CocoaPods-Lint-20180419-3650-1tkys6n-CBBase58/Pods/OpenSSL-Universal/lib-ios/libssl.a)) during validation.

报错用这种命令:

pod lib lint --use-libraries

git报错:
[email protected]: Permission denied (publickey).
导致代码无法拉取,更新,可能是因为配置新的ssh导致,需要重新获取分支

 -> UBaseiOSBridge (0.0.3)
    - ERROR | [iOS] xcodebuild: Returned an unsuccessful exit code. You can use `--verbose` for more information.
    - NOTE  | xcodebuild:  note: Using new build system
    - NOTE  | [iOS] xcodebuild:  note: Planning build
    - NOTE  | [iOS] xcodebuild:  note: Constructing build description
    - NOTE  | [iOS] xcodebuild:  warning: The iOS Simulator deployment target 'IPHONEOS_DEPLOYMENT_TARGET' is set to 7.0, but the range of supported deployment target versi

解决办法

只要在验证后面加上 --skip-import-validation

如果本地有私有库的话,需要通过 --sources= 追加spec.git 的源去验证才可以
pod repo push --sources='https://github.com/CocoaPods/Specs.git,https://s/BBaseSpec.git,https://gitlab.corp.cootek.com/davinci/naga-ios-specs.git' ubase_repo UBaseiOSBridge.podspec --allow-warnings --use-libraries --use-modular-headers --skip-import-validation

pod lib lint --sources='https://github.com/CocoaPods/Specs.git,https://os/BBaseSpec.git,https://naga-ios-specs.git' --allow-warnings --use-libraries --use-modular-headers --skip-import-validation

git 异常报错

[!] Unable to find the `cootek-bbasespec` repo. If it has not yet been cloned, add it via `pod repo add`.

解决办法为:

//    $ pod repo add NAME URL [BRANCH]
pod repo add cootek-bbasespec [email protected]:pgd_portfolio/sdk/ios/BBaseSpec.git master


你可能感兴趣的:(iOS pods创建私有库)