写在前面
最近在开发SDK,然后发现这里面的学问大着呢。在开发SDK的时候,先得构想一下,作为开发者,怎么做才能开发方便,调试方便,导出SDK方便。
-
你需要了解的知识点:
上图中project就一个,没啥好说的但是targets就比较花里胡哨了
我刚开始接到这个项目是懵逼的,因为没有文档讲这些个target是干啥的,之间有啥关系。每target里需要的配置项有哪些。后来自己慢慢摸索才有了下面这一段的理解。至于为啥会有这些个target,其实稍微大点的项目,有了CI了之后,都会有8个左右的target。其目的就是为了打出不同的包(不同的编译选项)
- 第一个图标,就有点像靶子的那个红色圈圈的。这个是本文中提到的aggregate产生的,可以简单的理解为一个脚本,而这个脚本可以编译后面三个target里面的东西。
-
第二个图标,黄色的手提包。这个就是正常的framework产生的主target,可以理解为我们平时直接创建的APP项目里的那个主target(就是下图中的那个铅笔和尺子搭出的“A”图标)
- 第三个图标,一般都是test相关生成的,我目前没有关注。
- 第四个图标,像个房子一样的,这个是类似于framework的,在
addTarget-->cross platfrom
这一步就可以看到。
初步方案
- 分别是不同的工程,SDK是一个项目,调试查看SDK效果的代码又是一个项目,这样就和我们平时用别人的项目一样。
优点,工程之间完全隔离。业务代码和SDK没有任何关系、
缺点,每次修改了SDK里的代码后,调试成本变高了,要不停的导出framework然后放到Demo工程里看效果,且不能直接debug
- 基于上面的缺点,就有这个方法。如果可以在demo工程里直接调用SDK项目最新生成的framework多好啊。
优点,解决了上面说的缺点
缺点,由于是两个项目,在CI的时候,肯定是分两个Git仓库管理的,于是两个项目对应的Git一定要配置好,不然提交代码的时候头大,够吃一壶了
基于第二点方案,我们操作起来。
参看了iOS项目中SDK的开发与调试
这一篇,这里主要讲的是新增的方式。我是由于已经有了两个项目,分别是SDK的工程和demo的工程,所以这里主要记录怎么样把两个分开的工程整合到一个项目里,然后方便我们SDK的开发和调试
创建文件夹,里面创建xcworkspace文件,然后把SDK项目和demo项目拷贝到一起。如下图这样。
-
下一步把这两个目录里的xcproject文件直接拖到xcode打开的xcworkspace里,结果如下图
编译,没有问题就OK了,至此就是两个都加进来后,后面就是demo工程怎么引用SDK工程产出的framework了,这一点可以参考上面的那个帖子。
-
两个项目建立好关联后,应该是下面这个样子的(最后能运行的样子)
可以看到目录里有两个一样的framework,第一个是我们期望的把两个项目关联起来的那个动态库,第二个是我们通过addTarget-->cross platfrom -->aggregate和脚本的方式生成的。可以运行demo后分别对这两个framework文件 showInFinder 看文件的修改日期,就可以看到哪个是最新的framework,然后说明我们的修改有没有生效。
上图中,箭头所指的那个framework的路径应该就是前面我们脚本输出的目标路径。前后验证了,搞定,哈哈
总结
- 其中我遇到了一个问题,就是在修改了SDK的对外暴露的头文件的时候,不知道为啥,framework里新增的头文件不会出现在framework里的header文件夹里了。最后我是通过shift+command+option+k快捷键清理了下,然后就好了
- 为了确保demo工程里使用的framework是直接指向SDK产出framework目录,自己多操作下就知道了,哈哈哈哈