diff --git a/README.md b/README.md
index 2d5e3c4..a917419 100644
--- a/README.md
+++ b/README.md
@@ -1,30 +1,12 @@
-### 更新
-- 2020-11-02
-
- v0.3.0.11 支持纯Swift、纯Object-C、Swift-OC混编
-
-# Cocoapods-imy-bin
-
-关于 插件具体的架构部署实践和更详细的资源,可以参考
-
-> [iOS编译速度如何稳定提高10倍以上](https://juejin.im/post/5eccceb9f265da76f30e4e13)
->
-> [iOS美团同款"ZSource"二进制调试实现](https://juejin.im/post/5f066cfa5188252e893a136e)
->
-> [iOS教你如何像RN一样实时编译](https://juejin.im/post/6850037272415813645)
->
-> [Swift编译慢?请看这里,全套开源](https://juejin.im/post/6890419459639476237)
->
-> [OC-Demo](https://github.com/su350380433/cocoapods-imy-bin-demo)
->
-> [Swift-OC-Demo](https://github.com/su350380433/Swift-OC-Demo)
-
-
+# 只要两行代码,便可提升10倍以上编译速度
+
+
+
### 特色:
1. **无入侵、无感知、不影响现有业务,不影响现有代码框架、完全绿色产品~**
@@ -35,443 +17,40 @@
6. **支持 使用与不使用 use_frameworks!**
7. **少数支持swift项目二进制化编译的开源项目之一**
-## 一、概要
-
-
-cocoapods-imy-bin功能点:
-
- 1. 组件二进制化,`无入侵式`支持组件二进制化,完全自动化,无需手动操作。致力于解决Ci打包速度慢、研发编译慢等编译问题。
- 2. 本地配置文件 - `Podfile_local`
- 3. 二进制源码调试`pod bin code`,类似[美团 iOS 工程 zsource 命令背后的那些事儿](https://juejin.im/post/6847897745987125262)的效果。
- 4. 命令快捷键`pod bin imy`,如游戏快捷键,根据配置会在特定目录执行特定命令(如任意终端目录下,执行某个特定目录的pod update --no-repo-update命令),减少其他繁琐操作。支持任意个快捷键。
-
-cocoapods-imy-bin插件所关联的组件二进制化策略:
-
-预先将打包成 `.a` 的组件保存到静态服务器上,并在 `install` 时,去下载组件对应的二进制版本,以减少组件编译时间,达到加快 App 打包、组件发布等操作的目的。
-
-
-
-## 二、准备工作
-
-
-
-### 1、安装插件
-
-```shell
-sudo gem install cocoapods-imy-bin
-```
-
-
-
-## 三、使用二进制组件
-
-
-### 1、环境搭建
-
-
-
-[环境搭建详细教程](https://github.com/su350380433/cocoapods-imy-bin-demo)
-
-使用二进制时,本插件需要提供以下资源:
-
-- 静态资源服务器( [binary-server](https://github.com/su350380433/binary-server),附详细使用教程)
-- 二进制私有源仓库(保存组件二进制版本 podspec)
-
-
-
-### 2、初始化插件
-
-``` shell
-xx:Demo slj$ pod bin init
-
-====== dev 环境 ========
-
-开始设置二进制化初始信息.
-所有的信息都会保存在 /Users/slj/.cocoapods/bin_dev.yml 文件中.
-%w[bin_dev.yml bin_debug_iphoneos.yml bin_release_iphoneos.yml]
-你可以在对应目录下手动添加编辑该文件. 文件包含的配置信息样式如下:
-
----
-configuration_env: dev
-code_repo_url: git@github.com:su350380433/example_spec_source.git
-binary_repo_url: git@github.com:su350380433/example_spec_bin_dev.git
-binary_download_url: http://localhost:8080/frameworks/%s/%s/zip
-download_file_type: zip
-
-
-编译环境
-可选值:[ dev / debug_iphoneos / release_iphoneos ]
-旧值:dev
-```
-
-按提示输入`所属环境`、源码私有源、二进制私有源、二进制下载地址、下载文件类型后,插件就配置完成了。其中 `binary_download_url` 需要预留组件名称与组件版本占位符,插件内部会依次替换 `%s` 为相应组件的值。
-
-`cococapods-imy-bin` 也支持从 url 下载配置文件,方便对多台机器进行配置:
-
-```shell
-➜ ~ pod bin init --bin-url=https://github.com/su350380433/cocoapods-imy-bin-configs/raw/master/bin_dev.yml
-```
-
-配置文件模版内容如下,根据不同团队的需求定制即可:
-
-```shell
----
-configuration_env: dev
-code_repo_url: git@github.com:su350380433/example_spec_source.git
-binary_repo_url: git@github.com:su350380433/example_spec_bin_dev.git
-binary_download_url: http://localhost:8080/frameworks/%s/%s/zip
-download_file_type: zip
-
-```
-
-配置时,不需要手动添加源码和二进制私有源的 repo,插件在找不到对应 repo 时会主动 clone。
-
-记得启动 `sudo mongod`服务,静态资源服务。
-
-
-
-
-## 四、制作二进制组件
-
-
-
-[视频演示](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
-
-### 1、制作命令
-
-可以直接使用插件的 `pod bin auto`命令,在插件初始化配置完成后,目录下只要有包含podspec文件,根据podspec文件的version版本号会自动化执行build、组装二进制组件、制作二进制podspec、上传二进制文件、上传二进制podspec到私有源仓库。
-
-```shell
-pod bin auto
-```
-
-带上`—all-make`参数会把当前组件所依赖的组件都自动化制作成二进制组件。
-
-```shell
-pod bin local
-```
-
-pod bin local 是配合其他三方编译产物的命令,需要配置编译产物的目录。
-
-`BinArchive.json`是制作二进制的一些配置项,放在项目跟目录下:
-
-``` json
-{
- "//": "archive-white-pod-list 不制作二进制白名单,",
- "archive-white-pod-list" : [
- "YYTargetDemo",
- "YYModel"
- ],
- "//": "ignore-git-list 不制作二进制 所属git白名单,",
- "ignore-git-list": [
- "git@gitlab.xxx.com:Github-iOS"
- ],
- "//": "ignore-http-list 不制作二进制 所属https白名单,",
- "ignore-http-list": [
- "https://gitlab.xxx.com/Github-iOS"
- ],
- "//": "xcode_build_path 设置编译缓存完整路径, 默认地址如下",
- "xcode_build_path" : "xcode-build/Build/Intermediates.noindex/ArchiveIntermediates/#{target_name}/IntermediateBuildFilesPath/UninstalledProducts/iphoneos/",
-}
-```
-
-
-
-
-### 2. 二进制Podspec
-
-通过`pod bin auto`和`pod bin local`二进制Podspec 会自动生成、上传,无需关心。
-
-
-
-
-### 3、查看结果
-
-二进制存储服务:[http://localhost:8080/frameworks/](http://localhost:8080/frameworks/)(默认本地8080端口)
-
-二进制私有源参考:[https://github.com/su350380433/example_spec_bin_dev](https://github.com/su350380433/example_spec_bin_dev)(自定义)
-
-
-
-
-### 4、使用二进制
-
-
-
-[视频演示](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
-
-在Podfile文件中,加入这两行代码,对已经制作二进制的就会生效,自动转换二进制组件依赖。
-
-``` ruby
-plugin 'cocoapods-imy-bin'
-use_binaries!
-```
-
-
-
-
-## 五、扩展功能
-
-
-
-### 1、本地配置文件 - Podfile_local
-
-本地组件配置文件 Podfile_local,目前已支持Podfile下的大部分功能,可以把一些本地配置的语句放到Podfile_local。
-
-
-场景:
-
-1. 不希望把本地采用的源码/二进制配置、本地库传到远程仓库。
-2. 避免直接修改Podfile文件,引起更新代码时冲突、或者误提交。
-
-如Podfile本地库的写法:
-```ruby
-pod YYModel :path => '../' #提交的时候往往要修改回来才提交,操作繁琐
-```
-用法:
-
-在与Podfile同级目录下,新增一个`Podfile_local`文件
-
-```ruby
-#target 'Seeyou' do 不同的项目注意修改下Seeyou的值
-#:path => '../IMYYQHome',根据实际情况自行修改,与之前在podfile写法一致
-
-
- plugin 'cocoapods-imy-bin'
-#是否启用二进制插件,想开启把下面注释去掉
-# use_binaries!
-
-#设置使用【源码】版本的组件。
-#set_use_source_pods ['YYKit','SDWebImaage']
-
-#需要替换Podfile里面的组件才写到这里
-#在这里面的所写的组件库依赖,默认切换为【源码】依赖
-target 'Seeyou' do
- #本地库引用
- #pod 'YYModel', :path => '../YYModel'
-
- #覆盖、自定义组件
- #pod 'YYCache', :podspec => 'http://覆盖、自定义/'
-end
-```
-
-```ruby
-以前的 pod update --no-repo-update 命令加个前缀 `bin` 变成
-```
-
-```shell
-pod bin update --no-repo-update
-```
-or
-```shell
-pod bin install
-```
-
-支持 pod install/update 命令参数
-
-并将其加入 .gitignore ,再也不用担心我误提交或者冲突了,Podfile_local 中的配置选项优先级比 Podfile 高,支持和 Podfile 相同的配置语句,同时支持**pre_install** or **post_install**。
-
-
-如果您不习惯Podfile_local的使用方式,可以把命令写在Podfile里面,pod时不需要加bin,依旧是 pod update/install。
-
-
-
-
-### 2、二进制源码调试
-
-
-
-[视频演示](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
-
-在项目根目录下,输入命令:
-
-```ruby
-pod bin code YYModel
-```
-
-`YYModel`为需要源码调试的组件库名称。成功之后像平时一样单步调试,控制台打印变量。让我们同时拥有使用二进制的便利和源码调试的能力。
-
-``` shell
- $ pod bin code --help [11:37:50]
-Usage:
-
- $ pod bin code [NAME]
-
- 通过将二进制对应源码放置在临时目录中,让二进制出现断点时可以跳到对应的源码,方便调试。 在不删除二进制的情况下为某个组件添加源码调试能力,多个组件名称用空格分隔
-
-Options:
-
- --all-clean 删除所有已经下载的源码
- --clean 删除所有指定下载的源码
- --list 展示所有一级下载的源码以及其大小
- --source 源码路径,本地路径,会去自动链接本地源码
-```
-
-效果与演示参考[链接1](https://juejin.im/post/5eccceb9f265da76f30e4e13#heading-48)、[视频](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
-
-
-
-
-### 3、快捷键命令
-
-
-
-在任意的终端执行命令,都能执行特定目录下特定命令
-
-使用命令:
-
-```shell
-pod bin imy
-```
-
-or
-
-``` shell
-pod bin imy 2 #2 是自定义的快捷键
-```
-
-使用场景:
-
- 1. 在任意目录下,执行项目A的pod update --no-repo-update命令
-
-命令快捷键配置
-
-```shell
- $ pod bin inithk [11:37:58]
-
-开始设置快捷键 pod bin imy.
-所有的信息都会保存在 /Users/ci/.cocoapods/hot_key_1.yml 文件中.
-%w[hot_key.yaml]
-你可以在对应目录下手动添加编辑该文件. 文件包含的配置信息样式如下:
-
----
-hot_key_index: '1'
-hot_key_dir: '/User/ci/自定义目录'
-hot_key_cmd: pod bin update --no-repo-update
-
-
-快捷键
-可选值:[ 1 / 2 / 3... ]
-旧值:1
-```
-
-
-
-
-## 六、 DSL参数解释
-
-
-
-首先,开发者需要在 Podfile 中需要使用 `plugin 'cocoapods-imy-bin'` 语句引入插件
-
-```ruby
-plugin 'cocoapods-imy-bin'
-```
-
-顺带可以删除 Podfile 中的 source ,因为插件内部会自动帮你添加两个私有源。
-
-`cocoapods-bin `插件提供二进制相关的配置语句有 `use_binaries!`、`use_binaries_with_spec_selector!` 以及 `set_use_source_pods`,下面会分别介绍。
-
-##### use_binaries!
-
-全部组件使用二进制版本。
-
-支持传入布尔值控制是否使用二进制版本,比如 DEBUG 包使用二进制版本,正式包使用源码版本,Podfile 关联语句可以这样写:
-
-```ruby
-use_binaries! (ENV['DEBUG'].nil? || ENV['DEBUG'] == 'true')
-```
-
-##### set_use_source_pods
-
-设置使用源码版本的组件。
-
-实际开发中,可能需要查看 YYModel 组件的源码,这时候可以这么设置:
-
-```ruby
-set_use_source_pods ['YYModel']
-```
-
-如果 CocoaPods 版本为 1.5.3 ,终端会输出以下内容,表示 YYModel 的参照源从二进制私有源切换到了源码私有源:
-
-```ruby
-Analyzing dependencies
-Fetching podspec for `A` from `../`
-Downloading dependencies
-Using A (0.1.0)
-Installing YYModel 1.0.4.2 (source changed to `git@git.xxxxxx.net:ios/cocoapods-spec.git` from `git@git.xxxxxx.net:ios/cocoapods-spec-binary.git`)
-Generating Pods project
-Integrating client project
-Sending stats
-Pod installation complete! There is 1 dependency from the Podfile and 2 total pods installed.
-```
-
-##### use_binaries_with_spec_selector!
-
-过滤出需要使用二进制版本组件。
-
-假如开发者只需要 `YYModel` 的二进制版本,那么他可以在 Podfile 中添加以下代码:
-
-```ruby
-use_binaries_with_spec_selector! do |spec|
- spec.name == 'YYModel'
-end
-```
-
-**需要注意的是,如果组件有 subspec ,使用组件名作为判断条件应如下**:
-
-```ruby
-use_binaries_with_spec_selector! do |spec|
- spec.name.start_with? == '组件名'
-end
-```
-
-如果像上个代码块一样,**直接对比组件名,则插件会忽略此组件的所有 subspec,导致资源拉取错误**,这种场景下,最好通过 `set_use_source_pods` 语句配置依赖。
-
-一个实际应用是,三方组件采用二进制版本,团队编写的组件依旧采用源码版本。如果三方组件都在 `cocoapods-repo` 组下,就可以使用以下代码过滤出三方组件:
-
-```ruby
-use_binaries_with_spec_selector! do |spec|
- git = spec.source && spec.source['git']
- git && git.include?('cocoapods-repo')
-end
-```
-
-##### 切换Dev/Debug_iPhoneos/Release_iPhoneos环境初始化设置
+关于 插件具体的架构部署实践和更详细的资源,可以参考
-```shell
-#dev 初始化插件配置 默认dev环境
-pod bin init --bin-url=https://gitlab.xxx.com/cocoapods-imy-bin-config/raw/master/bin_dev.yml
+> [iOS编译速度如何稳定提高10倍以上](https://juejin.cn/post/6903407900006449160)
+>
+> [iOS美团同款"ZSource"二进制调试实现](https://juejin.im/post/5f066cfa5188252e893a136e)
+>
+> [iOS教你如何像RN一样实时编译](https://juejin.im/post/6850037272415813645)
+>
+> [Swift编译慢?请看这里,全套开源](https://juejin.im/post/6890419459639476237)
+>
+> [OC-Demo](https://github.com/su350380433/cocoapods-imy-bin-demo)
+>
+> [Swift-OC-Demo](https://github.com/su350380433/Swift-OC-Demo)
-#Debug_iPhoneos 初始化插件配置
-pod bin init --bin-url=https://gitlab.xxx.com/cocoapods-imy-bin-config/raw/master/bin_debug_iphoneos.yml
+
-#release_iPhoneos 初始化插件配置
-pod bin init --bin-url=https://gitlab.xxx.com/cocoapods-imy-bin-config/raw/master/bin_release_iphoneos.yml
-```
-使用时在podfile 或者 podfile_local指定设置
+### 更新
+- 2020-11-02
-```shell
-#在podfile 或者 podfile_local 文件下加这句话
-set_configuration_env('debug_iphoneos')
-```
+ v0.3.0.11 支持纯Swift、纯Object-C、Swift-OC混编
-##### 其他设置
-插件默认开启多线程下载组件资源,如果要禁用这个功能,Podfile 添加以下代码即可:
+## 一、使用教程
-```ruby
-install! 'cocoapods', { install_with_multi_threads: false }
-```
+[使用教程](./使用教程.md)
+
-
-## 七、感谢
+## 二、感谢
@@ -482,4 +61,3 @@ install! 'cocoapods', { install_with_multi_threads: false }
#### 您有什么更好的想法,可以提出来,我们一起来实现,共创一个强大的工具平台,同时也欢迎给我们提PR。
-加技术讨论群,微信号:su1231235 (备注 cocoapods-imy-bin加群)提问到issue
diff --git a/img/Podfile.png b/img/Podfile.png
new file mode 100644
index 0000000..e30a181
Binary files /dev/null and b/img/Podfile.png differ
diff --git a/img/time.png b/img/time.png
new file mode 100644
index 0000000..0529823
Binary files /dev/null and b/img/time.png differ
diff --git "a/\344\275\277\347\224\250\346\225\231\347\250\213.md" "b/\344\275\277\347\224\250\346\225\231\347\250\213.md"
new file mode 100644
index 0000000..391aba3
--- /dev/null
+++ "b/\344\275\277\347\224\250\346\225\231\347\250\213.md"
@@ -0,0 +1,419 @@
+## 一、概要
+
+
+cocoapods-imy-bin功能点:
+
+ 1. 组件二进制化,`无入侵式`支持组件二进制化,完全自动化,无需手动操作。致力于解决Ci打包速度慢、研发编译慢等编译问题。
+ 2. 本地配置文件 - `Podfile_local`
+ 3. 二进制源码调试`pod bin code`,类似[美团 iOS 工程 zsource 命令背后的那些事儿](https://juejin.im/post/6847897745987125262)的效果。
+ 4. 命令快捷键`pod bin imy`,如游戏快捷键,根据配置会在特定目录执行特定命令(如任意终端目录下,执行某个特定目录的pod update --no-repo-update命令),减少其他繁琐操作。支持任意个快捷键。
+
+cocoapods-imy-bin插件所关联的组件二进制化策略:
+
+预先将打包成 `.a` 的组件保存到静态服务器上,并在 `install` 时,去下载组件对应的二进制版本,以减少组件编译时间,达到加快 App 打包、组件发布等操作的目的。
+
+
+
+## 二、准备工作
+
+
+
+### 1、安装插件
+
+```shell
+sudo gem install cocoapods-imy-bin
+```
+
+
+
+## 三、使用二进制组件
+
+
+### 1、环境搭建
+
+
+
+[环境搭建详细教程](https://github.com/su350380433/cocoapods-imy-bin-demo)
+
+使用二进制时,本插件需要提供以下资源:
+
+- 静态资源服务器( [binary-server](https://github.com/su350380433/binary-server),附详细使用教程)
+- 二进制私有源仓库(保存组件二进制版本 podspec)
+
+
+
+### 2、初始化插件
+
+``` shell
+xx:Demo slj$ pod bin init
+
+====== dev 环境 ========
+
+开始设置二进制化初始信息.
+所有的信息都会保存在 /Users/slj/.cocoapods/bin_dev.yml 文件中.
+%w[bin_dev.yml bin_debug_iphoneos.yml bin_release_iphoneos.yml]
+你可以在对应目录下手动添加编辑该文件. 文件包含的配置信息样式如下:
+
+---
+configuration_env: dev
+code_repo_url: git@github.com:su350380433/example_spec_source.git
+binary_repo_url: git@github.com:su350380433/example_spec_bin_dev.git
+binary_download_url: http://localhost:8080/frameworks/%s/%s/zip
+download_file_type: zip
+
+
+编译环境
+可选值:[ dev / debug_iphoneos / release_iphoneos ]
+旧值:dev
+```
+
+按提示输入`所属环境`、源码私有源、二进制私有源、二进制下载地址、下载文件类型后,插件就配置完成了。其中 `binary_download_url` 需要预留组件名称与组件版本占位符,插件内部会依次替换 `%s` 为相应组件的值。
+
+`cococapods-imy-bin` 也支持从 url 下载配置文件,方便对多台机器进行配置:
+
+```shell
+➜ ~ pod bin init --bin-url=https://github.com/su350380433/cocoapods-imy-bin-configs/raw/master/bin_dev.yml
+```
+
+配置文件模版内容如下,根据不同团队的需求定制即可:
+
+```shell
+---
+configuration_env: dev
+code_repo_url: git@github.com:su350380433/example_spec_source.git
+binary_repo_url: git@github.com:su350380433/example_spec_bin_dev.git
+binary_download_url: http://localhost:8080/frameworks/%s/%s/zip
+download_file_type: zip
+
+```
+
+配置时,不需要手动添加源码和二进制私有源的 repo,插件在找不到对应 repo 时会主动 clone。
+
+记得启动 `sudo mongod`服务,静态资源服务。
+
+
+
+
+## 四、制作二进制组件
+
+
+
+[视频演示](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
+
+### 1、制作命令
+
+可以直接使用插件的 `pod bin auto`命令,在插件初始化配置完成后,目录下只要有包含podspec文件,根据podspec文件的version版本号会自动化执行build、组装二进制组件、制作二进制podspec、上传二进制文件、上传二进制podspec到私有源仓库。
+
+```shell
+pod bin auto
+```
+
+
+
+### 2. 二进制Podspec
+
+会自动生成、上传,无需关心。
+
+
+
+
+### 3、查看结果
+
+二进制存储服务:[http://localhost:8080/frameworks/](http://localhost:8080/frameworks/)(默认本地8080端口)
+
+二进制私有源参考:[https://github.com/su350380433/example_spec_bin_dev](https://github.com/su350380433/example_spec_bin_dev)(自定义)
+
+
+
+
+### 4、使用二进制
+
+
+
+[视频演示](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
+
+在Podfile文件中,加入这两行代码,对已经制作二进制的就会生效,自动转换二进制组件依赖。
+
+``` ruby
+plugin 'cocoapods-imy-bin'
+use_binaries!
+```
+
+
+
+
+## 五、扩展功能
+
+
+
+### 1、本地配置文件 - Podfile_local
+
+本地组件配置文件 Podfile_local,目前已支持Podfile下的大部分功能,可以把一些本地配置的语句放到Podfile_local。
+
+
+
+场景:
+
+1. 不希望把本地采用的源码/二进制配置、本地库传到远程仓库。
+2. 避免直接修改Podfile文件,引起更新代码时冲突、或者误提交。
+
+如Podfile本地库的写法:
+
+```ruby
+pod YYModel :path => '../' #提交的时候往往要修改回来才提交,操作繁琐
+```
+
+用法:
+
+在与Podfile同级目录下,新增一个`Podfile_local`文件
+
+```ruby
+#target 'Seeyou' do 不同的项目注意修改下Seeyou的值
+#:path => '../IMYYQHome',根据实际情况自行修改,与之前在podfile写法一致
+
+
+ plugin 'cocoapods-imy-bin'
+#是否启用二进制插件,想开启把下面注释去掉
+# use_binaries!
+
+#设置使用【源码】版本的组件。
+#set_use_source_pods ['YYKit','SDWebImaage']
+
+#需要替换Podfile里面的组件才写到这里
+#在这里面的所写的组件库依赖,默认切换为【源码】依赖
+target 'Seeyou' do
+ #本地库引用
+ #pod 'YYModel', :path => '../YYModel'
+
+ #覆盖、自定义组件
+ #pod 'YYCache', :podspec => 'http://覆盖、自定义/'
+end
+```
+
+```ruby
+以前的 pod update --no-repo-update 命令加个前缀 `bin` 变成
+```
+
+```shell
+pod bin update --no-repo-update
+```
+
+or
+
+```shell
+pod bin install
+```
+
+支持 pod install/update 命令参数
+
+并将其加入 .gitignore ,再也不用担心我误提交或者冲突了,Podfile_local 中的配置选项优先级比 Podfile 高,支持和 Podfile 相同的配置语句,同时支持**pre_install** or **post_install**。
+
+
+如果您不习惯Podfile_local的使用方式,可以把命令写在Podfile里面,pod时不需要加bin,依旧是 pod update/install。
+
+
+
+
+### 2、二进制源码调试
+
+
+
+[视频演示](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
+
+在项目根目录下,输入命令:
+
+```ruby
+pod bin code YYModel
+```
+
+`YYModel`为需要源码调试的组件库名称。成功之后像平时一样单步调试,控制台打印变量。让我们同时拥有使用二进制的便利和源码调试的能力。
+
+``` shell
+ $ pod bin code --help [11:37:50]
+Usage:
+
+ $ pod bin code [NAME]
+
+ 通过将二进制对应源码放置在临时目录中,让二进制出现断点时可以跳到对应的源码,方便调试。 在不删除二进制的情况下为某个组件添加源码调试能力,多个组件名称用空格分隔
+
+Options:
+
+ --all-clean 删除所有已经下载的源码
+ --clean 删除所有指定下载的源码
+ --list 展示所有一级下载的源码以及其大小
+ --source 源码路径,本地路径,会去自动链接本地源码
+```
+
+效果与演示参考[链接1](https://juejin.im/post/5eccceb9f265da76f30e4e13#heading-48)、[视频](https://github.com/MeetYouDevs/cocoapods-imy-bin/tree/master/%E6%BC%94%E7%A4%BA%E8%A7%86%E9%A2%91)
+
+
+
+
+### 3、快捷键命令
+
+
+
+在任意的终端执行命令,都能执行特定目录下特定命令
+
+使用命令:
+
+```shell
+pod bin imy
+```
+
+or
+
+``` shell
+pod bin imy 2 #2 是自定义的快捷键
+```
+
+使用场景:
+
+ 1. 在任意目录下,执行项目A的pod update --no-repo-update命令
+
+命令快捷键配置
+
+```shell
+ $ pod bin inithk [11:37:58]
+
+开始设置快捷键 pod bin imy.
+所有的信息都会保存在 /Users/ci/.cocoapods/hot_key_1.yml 文件中.
+%w[hot_key.yaml]
+你可以在对应目录下手动添加编辑该文件. 文件包含的配置信息样式如下:
+
+---
+hot_key_index: '1'
+hot_key_dir: '/User/ci/自定义目录'
+hot_key_cmd: pod bin update --no-repo-update
+
+
+快捷键
+可选值:[ 1 / 2 / 3... ]
+旧值:1
+```
+
+
+
+
+## 六、 DSL参数解释
+
+
+
+首先,开发者需要在 Podfile 中需要使用 `plugin 'cocoapods-imy-bin'` 语句引入插件
+
+```ruby
+plugin 'cocoapods-imy-bin'
+```
+
+顺带可以删除 Podfile 中的 source ,因为插件内部会自动帮你添加两个私有源。
+
+`cocoapods-bin `插件提供二进制相关的配置语句有 `use_binaries!`、`use_binaries_with_spec_selector!` 以及 `set_use_source_pods`,下面会分别介绍。
+
+##### use_binaries!
+
+全部组件使用二进制版本。
+
+支持传入布尔值控制是否使用二进制版本,比如 DEBUG 包使用二进制版本,正式包使用源码版本,Podfile 关联语句可以这样写:
+
+```ruby
+use_binaries! (ENV['DEBUG'].nil? || ENV['DEBUG'] == 'true')
+```
+
+##### set_use_source_pods
+
+设置使用源码版本的组件。
+
+实际开发中,可能需要查看 YYModel 组件的源码,这时候可以这么设置:
+
+```ruby
+set_use_source_pods ['YYModel']
+```
+
+如果 CocoaPods 版本为 1.5.3 ,终端会输出以下内容,表示 YYModel 的参照源从二进制私有源切换到了源码私有源:
+
+```ruby
+Analyzing dependencies
+Fetching podspec for `A` from `../`
+Downloading dependencies
+Using A (0.1.0)
+Installing YYModel 1.0.4.2 (source changed to `git@git.xxxxxx.net:ios/cocoapods-spec.git` from `git@git.xxxxxx.net:ios/cocoapods-spec-binary.git`)
+Generating Pods project
+Integrating client project
+Sending stats
+Pod installation complete! There is 1 dependency from the Podfile and 2 total pods installed.
+```
+
+##### use_binaries_with_spec_selector!
+
+过滤出需要使用二进制版本组件。
+
+假如开发者只需要 `YYModel` 的二进制版本,那么他可以在 Podfile 中添加以下代码:
+
+```ruby
+use_binaries_with_spec_selector! do |spec|
+ spec.name == 'YYModel'
+end
+```
+
+**需要注意的是,如果组件有 subspec ,使用组件名作为判断条件应如下**:
+
+```ruby
+use_binaries_with_spec_selector! do |spec|
+ spec.name.start_with? == '组件名'
+end
+```
+
+如果像上个代码块一样,**直接对比组件名,则插件会忽略此组件的所有 subspec,导致资源拉取错误**,这种场景下,最好通过 `set_use_source_pods` 语句配置依赖。
+
+一个实际应用是,三方组件采用二进制版本,团队编写的组件依旧采用源码版本。如果三方组件都在 `cocoapods-repo` 组下,就可以使用以下代码过滤出三方组件:
+
+```ruby
+use_binaries_with_spec_selector! do |spec|
+ git = spec.source && spec.source['git']
+ git && git.include?('cocoapods-repo')
+end
+```
+
+##### 切换Dev/Debug_iPhoneos/Release_iPhoneos环境初始化设置
+
+
+```shell
+#dev 初始化插件配置 默认dev环境
+pod bin init --bin-url=https://gitlab.xxx.com/cocoapods-imy-bin-config/raw/master/bin_dev.yml
+
+#Debug_iPhoneos 初始化插件配置
+pod bin init --bin-url=https://gitlab.xxx.com/cocoapods-imy-bin-config/raw/master/bin_debug_iphoneos.yml
+
+
+#release_iPhoneos 初始化插件配置
+pod bin init --bin-url=https://gitlab.xxx.com/cocoapods-imy-bin-config/raw/master/bin_release_iphoneos.yml
+```
+
+使用时在podfile 或者 podfile_local指定设置
+
+```shell
+#在podfile 或者 podfile_local 文件下加这句话
+set_configuration_env('debug_iphoneos')
+```
+
+##### 其他设置
+
+插件默认开启多线程下载组件资源,如果要禁用这个功能,Podfile 添加以下代码即可:
+
+```ruby
+install! 'cocoapods', { install_with_multi_threads: false }
+```
+
+
+
+
+## 七、感谢
+
+
+
+**[cocoapods-bin](https://github.com/tripleCC/cocoapods-bin)**
+
+[美团 iOS 工程 zsource 命令背后的那些事儿](https://tech.meituan.com/2019/08/08/the-things-behind-the-ios-project-zsource-command.html)
+
+#### 您有什么更好的想法,可以提出来,我们一起来实现,共创一个强大的工具平台,同时也欢迎给我们提PR。
+