Check if code is running in Electron renderer
process.
Electron code can run in either the main
process or
the renderer
process. This is the same as asking if
the code is running in a web page with access to the
DOM or not. Read more here: https://github.com/atom/electron/blob/master/docs/tutorial/quick-start.md
- Creating a single module that acts differently whether it's running in
main
orrenderer
. - Logging utility. One process (
main
) would be responsible for writing to log files, while renderers would send log data to themain
. Would allow your code to have onelog
method. - Testing. Your test code may behave differently if the DOM is available.
- Normalize
console.log
behavior.console.log
behavior is weird inrenderer
, this can easily be fixed.
npm i --save is-electron-renderer
You'll notice that when using console.log
in Electron that in the renderer
process
outputs some weird log level garbage to stderr
before your actual console message.
You can normalize this behavior:
console-hook.js:
// clean up Electron output
function hook () {
var isRenderer = require('is-electron-renderer')
var pre = '(' + (isRenderer ? 'RENDERER' : 'MAIN') + ') '
console.log = function (msg) {
process.stdout.write(pre + msg + '\n')
}
}
module.exports = {
hook: hook
}
index.js:
require('./console-hook').hook()
console.log('hello')
output (main):
(MAIN) hello
output (renderer):
(RENDERER) hello
var isRenderer = require('is-electron-renderer')
console.log(isRenderer)
// => (BOOLEAN)
MIT
Copyright 2015 JP Richardson