2017-11-05 00:49:23 +00:00
|
|
|
// This is the basic initialization for the Electron MAIN process
|
|
|
|
|
2017-11-03 18:01:24 +00:00
|
|
|
// Make it possible to require("/lib/...") without specifying full path
|
2017-11-04 11:26:49 +00:00
|
|
|
require('app-module-path').addPath(__dirname);
|
2017-11-02 23:26:08 +00:00
|
|
|
|
2017-11-04 11:26:49 +00:00
|
|
|
const electronApp = require('electron').app;
|
2017-11-05 00:17:48 +00:00
|
|
|
const { ElectronAppWrapper } = require('./ElectronAppWrapper');
|
|
|
|
const { initBridge } = require('./bridge');
|
2017-11-14 10:53:18 +00:00
|
|
|
const { Logger } = require('lib/logger.js');
|
|
|
|
const { FsDriverNode } = require('lib/fs-driver-node.js');
|
2017-11-02 23:26:08 +00:00
|
|
|
|
2017-11-04 11:26:49 +00:00
|
|
|
process.on('unhandledRejection', (reason, p) => {
|
|
|
|
console.error('Unhandled promise rejection', p, 'reason:', reason);
|
|
|
|
process.exit(1);
|
|
|
|
});
|
|
|
|
|
2017-11-13 18:47:35 +00:00
|
|
|
// Flags are parsed properly in BaseApplication, however it's better to have
|
|
|
|
// the env as early as possible to enable debugging capabilities.
|
|
|
|
function envFromArgs(args) {
|
|
|
|
if (!args) return 'prod';
|
|
|
|
const envIndex = args.indexOf('--env');
|
|
|
|
const devIndex = args.indexOf('dev');
|
|
|
|
if (envIndex === devIndex - 1) return 'dev';
|
|
|
|
return 'prod';
|
|
|
|
}
|
|
|
|
|
2017-11-14 10:53:18 +00:00
|
|
|
Logger.fsDriver_ = new FsDriverNode();
|
|
|
|
|
2017-11-13 18:47:35 +00:00
|
|
|
const env = envFromArgs(process.argv);
|
|
|
|
|
|
|
|
const wrapper = new ElectronAppWrapper(electronApp, env);
|
2017-11-04 13:23:15 +00:00
|
|
|
|
2017-11-05 00:17:48 +00:00
|
|
|
initBridge(wrapper);
|
2017-11-04 13:23:15 +00:00
|
|
|
|
2017-11-05 00:17:48 +00:00
|
|
|
wrapper.start().catch((error) => {
|
|
|
|
console.error('Electron App fatal error:');
|
2017-11-04 11:26:49 +00:00
|
|
|
console.error(error);
|
2017-11-05 00:49:23 +00:00
|
|
|
});
|