|
@@ -1,8 +1,9 @@
|
|
|
-import * as timers from 'timers'
|
|
|
import * as util from 'util'
|
|
|
|
|
|
import { electronBindingSetup } from '@electron/internal/common/atom-binding-setup'
|
|
|
|
|
|
+const timers = require('timers')
|
|
|
+
|
|
|
process.electronBinding = electronBindingSetup(process._linkedBinding, process.type)
|
|
|
|
|
|
type AnyFn = (...args: any[]) => any
|
|
@@ -38,16 +39,20 @@ function wrap <T extends AnyFn> (func: T, wrapper: (fn: AnyFn) => T) {
|
|
|
|
|
|
process.nextTick = wrapWithActivateUvLoop(process.nextTick)
|
|
|
|
|
|
-global.setImmediate = wrapWithActivateUvLoop(timers.setImmediate)
|
|
|
+global.setImmediate = timers.setImmediate = wrapWithActivateUvLoop(timers.setImmediate)
|
|
|
global.clearImmediate = timers.clearImmediate
|
|
|
|
|
|
+// 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.
|
|
|
+timers.setTimeout = wrapWithActivateUvLoop(timers.setTimeout)
|
|
|
+timers.setInterval = wrapWithActivateUvLoop(timers.setInterval)
|
|
|
+
|
|
|
+// Only override the global setTimeout/setInterval impls in the browser process
|
|
|
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)
|
|
|
+ global.setTimeout = timers.setTimeout
|
|
|
+ global.setInterval = timers.setInterval
|
|
|
}
|
|
|
|
|
|
if (process.platform === 'win32') {
|