• 源码目录结构
    • 源代码的结构
    • 其他目录的结构

    源码目录结构

    Electron 的源代码主要依据 Chromium 的拆分约定被拆成了许多部分。

    为了更好地理解源代码,您可能需要了解一下
    Chromium 的多进程架构。

    源代码的结构

    1. Electron
    2. ├──atom - Electron 的源代码
    3. | ├── app - 系统入口代码
    4. | ├── browser - 包含了主窗口、UI 和其他所有与主进程有关的东西,它会告诉渲染进程如何管理页面
    5. | | ├── lib - 主进程初始化代码中 JavaScript 部分的代码
    6. | | ├── ui - 不同平台上 UI 部分的实现
    7. | | | ├── cocoa - Cocoa 部分的源代码
    8. | | | ├── gtk - GTK+ 部分的源代码
    9. | | | └── win - Windows GUI 部分的源代码
    10. | | ├── default_app - 在没有指定 app 的情况下 Electron 启动时默认显示的页面
    11. | | ├── api - 主进程 API 的实现
    12. | | | └── lib - API 实现中 Javascript 部分的代码
    13. | | ├── net - 网络相关的代码
    14. | | ├── mac - Mac 有关的 Objective-C 代码
    15. | | └── resources - 图标,平台相关的文件等
    16. | ├── renderer - 运行在渲染进程中的代码
    17. | | ├── lib - 渲染进程初始化代码中 JavaScript 部分的代码
    18. | | └── api - 渲染进程 API 的实现
    19. | | └── lib - API 实现中 Javascript 部分的代码
    20. | └── common - 同时被主进程和渲染进程用到的代码,包括了一些用来将 node 的事件循环
    21. | | 整合到 Chromium 的事件循环中时用到的工具函数和代码
    22. | ├── lib - 同时被主进程和渲染进程使用到的 Javascript 初始化代码
    23. | └── api - 同时被主进程和渲染进程使用到的 API 的实现以及 Electron 内置模块的基础设施
    24. | └── lib - API 实现中 Javascript 部分的代码
    25. ├── chromium_src - Chromium 项目中拷贝来的代码
    26. ├── docs - 英语版本的文档
    27. ├── docs-translations - 各种语言版本的文档翻译
    28. ├── spec - 自动化测试
    29. ├── atom.gyp - Electron 的构建规则
    30. └── common.gypi - 为诸如 `node` `breakpad` 等其他组件准备的编译设置和构建规则

    其他目录的结构

    • script - 用于诸如构建、打包、测试等开发用途的脚本
    • tools - 在 gyp 文件中用到的工具脚本,但与 script 目录不同,
      该目录中的脚本不应该被用户直接调用
    • vendor - 第三方依赖项的源代码,为了防止人们将它与 Chromium 源码中的同名目录相混淆,
      在这里我们不使用 third_party 作为目录名
    • node_modules - 在构建中用到的第三方 node 模块
    • out - ninja 的临时输出目录
    • dist - 由脚本 script/create-dist.py 创建的临时发布目录
    • external_binaries - 下载的不支持通过 gyp 构建的预编译第三方框架