1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- 'use strict'
- const timers = require('timers')
- const util = require('util')
- process.atomBinding = require('@electron/internal/common/atom-binding-setup')(process.binding, process.type)
- // setImmediate and process.nextTick makes use of uv_check and uv_prepare to
- // run the callbacks, however since we only run uv loop on requests, the
- // callbacks wouldn't be called until something else activated the uv loop,
- // which would delay the callbacks for arbitrary long time. So we should
- // initiatively activate the uv loop once setImmediate and process.nextTick is
- // called.
- const wrapWithActivateUvLoop = function (func) {
- return wrap(func, function (func) {
- return function () {
- process.activateUvLoop()
- return func.apply(this, arguments)
- }
- })
- }
- function wrap (func, wrapper) {
- const wrapped = wrapper(func)
- if (func[util.promisify.custom]) {
- wrapped[util.promisify.custom] = wrapper(func[util.promisify.custom])
- }
- return wrapped
- }
- process.nextTick = wrapWithActivateUvLoop(process.nextTick)
- global.setImmediate = wrapWithActivateUvLoop(timers.setImmediate)
- global.clearImmediate = timers.clearImmediate
- if (process.type === 'browser') {
- // setTimeout needs to update the polling timeout of the event loop, when
- // called under Chromium's event loop the node's event loop won't get a chance
- // to update the timeout, so we have to force the node's event loop to
- // recalculate the timeout in browser process.
- global.setTimeout = wrapWithActivateUvLoop(timers.setTimeout)
- global.setInterval = wrapWithActivateUvLoop(timers.setInterval)
- }
- if (process.platform === 'win32') {
- // Always returns EOF for stdin stream.
- const { Readable } = require('stream')
- const stdin = new Readable()
- stdin.push(null)
- process.__defineGetter__('stdin', function () {
- return stdin
- })
- }
|