bc527f6b51
* refactor: bundle the browser and renderer process electron code * Bundles browser/init and renderer/init * Improves load performance of main process by ~40% * Improves load performance of renderer process by ~30% * Prevents users from importing our "requiring" our internal logic such as ipc-main-internal. This makes those message buses safer as they are less accessible, there is still some more work to be done though to lock down those buses completely. * The electron.asar file now only contains 2 files, as a future improvement maybe we can use atom_natives to ship these two files embedded in the binary * This also removes our dependency on browserify which had some strange edge cases that caused us to have to hack around require-order and stopped us using certain ES6/7 features we should have been able to use (async / await in some files in the sandboxed renderer init script) TLDR: Things are faster and better :) * fix: I really do not want to talk about it * chore: add performance improvements from debugging * fix: resolve the provided path so webpack thinks it is absolute * chore: fixup per PR review * fix: use webpacks ProvidePlugin to keep global, process and Buffer alive after deletion from global scope for use in internal code * fix: bundle worker/init as well to make node-in-workers work * chore: update wording as per feedback * chore: make the timers hack work when yarn is not used
48 lines
2.5 KiB
JavaScript
48 lines
2.5 KiB
JavaScript
'use strict'
|
|
|
|
// TODO: Updating this file also required updating the module-keys file
|
|
|
|
const features = process.electronBinding('features')
|
|
|
|
// Browser side modules, please sort alphabetically.
|
|
module.exports = [
|
|
{ name: 'app', loader: () => require('./app') },
|
|
{ name: 'autoUpdater', loader: () => require('./auto-updater') },
|
|
{ name: 'BrowserView', loader: () => require('./browser-view') },
|
|
{ name: 'BrowserWindow', loader: () => require('./browser-window') },
|
|
{ name: 'contentTracing', loader: () => require('./content-tracing') },
|
|
{ name: 'crashReporter', loader: () => require('./crash-reporter') },
|
|
{ name: 'dialog', loader: () => require('./dialog') },
|
|
{ name: 'globalShortcut', loader: () => require('./global-shortcut') },
|
|
{ name: 'ipcMain', loader: () => require('./ipc-main') },
|
|
{ name: 'inAppPurchase', loader: () => require('./in-app-purchase') },
|
|
{ name: 'Menu', loader: () => require('./menu') },
|
|
{ name: 'MenuItem', loader: () => require('./menu-item') },
|
|
{ name: 'net', loader: () => require('./net') },
|
|
{ name: 'netLog', loader: () => require('./net-log') },
|
|
{ name: 'Notification', loader: () => require('./notification') },
|
|
{ name: 'powerMonitor', loader: () => require('./power-monitor') },
|
|
{ name: 'powerSaveBlocker', loader: () => require('./power-save-blocker') },
|
|
{ name: 'protocol', loader: () => require('./protocol') },
|
|
{ name: 'screen', loader: () => require('./screen') },
|
|
{ name: 'session', loader: () => require('./session') },
|
|
{ name: 'systemPreferences', loader: () => require('./system-preferences') },
|
|
{ name: 'TopLevelWindow', loader: () => require('./top-level-window') },
|
|
{ name: 'TouchBar', loader: () => require('./touch-bar') },
|
|
{ name: 'Tray', loader: () => require('./tray') },
|
|
{ name: 'View', loader: () => require('./view') },
|
|
{ name: 'webContents', loader: () => require('./web-contents') },
|
|
{ name: 'WebContentsView', loader: () => require('./web-contents-view') }
|
|
]
|
|
|
|
if (features.isViewApiEnabled()) {
|
|
module.exports.push(
|
|
{ name: 'BoxLayout', loader: () => require('./views/box-layout') },
|
|
{ name: 'Button', loader: () => require('./views/button') },
|
|
{ name: 'LabelButton', loader: () => require('./views/label-button') },
|
|
{ name: 'LayoutManager', loader: () => require('./views/layout-manager') },
|
|
{ name: 'MdTextButton', loader: () => require('./views/md-text-button') },
|
|
{ name: 'ResizeArea', loader: () => require('./views/resize-area') },
|
|
{ name: 'TextField', loader: () => require('./views/text-field') }
|
|
)
|
|
}
|