Chrome浏览器组件是一个google的一个项目,它用来不断的模块化Chrome的代码。把整个content模块从src/chrome目录下抽取出来,尽管组件项目付出了不少努力,到目前为止,这个目录(src/chrome)仍然是最大的互相依赖的模块。因此,抽取src/chrome子模块仍然是google团队下一步的工作之一。
目标
众所周知,Chrome项目在过去几年中,无论是代码还是复杂度都增长了许多。对这个项目贡献代码的人员数量也增加了许多,而且,google也增加了许多目标平台以及配置,这些并没有在项目启动初期被他们预见到得到。对每个人来说,要理解整个架构变得越来越难,更别说所有代码了。
Chrome浏览器组件项目引入了模块化并强制执行,目标如下:
- 按比例增大架构,使得浏览器更适合需求变更,比如:使用src/chrome/browser模块的浏览器希望关掉或者重新实现某些模块,比如安卓上的Chrome;
- 通过进一步实现依赖关系图,我们想要实现的架构变得更清晰。那些依赖规则指出哪些子模块是允许的,哪些是不允许的。
- 大大简化了src/chrome子模块的依赖关系图,使他们不循环依赖;
- 通过增加许多独立的组件比如单元测试可执行程序来加速开发者的浏览器构建过程。减少最大组件的连接时间,例如browser组件。单元测试程序更小了,这有利于大家用gdb调试代码,或者通过printf快速便利代码。
- 上面提到的方法应该可以减少大家的担忧、也让google团队更容易合作,使得架构更不容易误解,同时不容易写出不好的架构来,通常也会使我们更高效。
设计
概览
1 把src/chrome目录提取出一个个的组件,这些组件变成了一个个的目标,他们有自己独立的单元测试目标,明确指定他们的依赖,没有循环依赖。
2 没有循环依赖
指的是组件并不认识自己的使用者(embedder)--嵌入组件的模块例如src/chrome。如果组件需要获得自己使用者的信息和服务,他们可以在初始化的时候获得,或者运行时通过抽象的client接口获得,这个client接口由组件定义、使用者(embedder)来实现。
3 组件在哪里?
在src/components/的子目录里。
- 注意: 一些模块更像一个抽象层--比如src/content、或者更像一个产品--比如src/chrome,这些模块应该有自己的顶级目录,而不应该放到src/components目录下。
4 Client接口在哪里?
他们的声明在每一个组件里,而实现在组件的使用者那里。