Optimize remote.require('electron')

This commit is contained in:
Cheng Zhao 2015-11-12 20:30:40 +08:00
parent 1d1f911b09
commit 8b2942c279
4 changed files with 38 additions and 4 deletions

View file

@ -1,6 +1,9 @@
# Import common modules. # Import common modules.
module.exports = require '../../../../common/api/lib/exports/electron' module.exports = require '../../../../common/api/lib/exports/electron'
v8Util = process.atomBinding 'v8_util'
v8Util.setHiddenValue module.exports, 'electronModule', true
Object.defineProperties module.exports, Object.defineProperties module.exports,
# Browser side modules, please sort with alphabet order. # Browser side modules, please sort with alphabet order.
app: app:

View file

@ -1,5 +1,7 @@
{ipcMain} = require 'electron'
path = require 'path' path = require 'path'
electron = require 'electron'
{ipcMain} = electron
objectsRegistry = require './objects-registry' objectsRegistry = require './objects-registry'
v8Util = process.atomBinding 'v8_util' v8Util = process.atomBinding 'v8_util'
@ -14,7 +16,11 @@ valueToMeta = (sender, value, optimizeSimpleObject=false) ->
meta.type = 'array' if Array.isArray value meta.type = 'array' if Array.isArray value
meta.type = 'error' if value instanceof Error meta.type = 'error' if value instanceof Error
meta.type = 'date' if value instanceof Date meta.type = 'date' if value instanceof Date
meta.type = 'promise' if value? and value.constructor.name is 'Promise' meta.type = 'promise' if value?.constructor.name is 'Promise'
# require('electron').
if meta.type is 'object' and v8Util.getHiddenValue value, 'electronModule'
meta.type = 'electronModule'
# Treat simple objects as value. # Treat simple objects as value.
if optimizeSimpleObject and meta.type is 'object' and v8Util.getHiddenValue value, 'simple' if optimizeSimpleObject and meta.type is 'object' and v8Util.getHiddenValue value, 'simple'
@ -43,6 +49,8 @@ valueToMeta = (sender, value, optimizeSimpleObject=false) ->
meta.members = plainObjectToMeta value meta.members = plainObjectToMeta value
else if meta.type is 'date' else if meta.type is 'date'
meta.value = value.getTime() meta.value = value.getTime()
else if meta.type is 'electronModule'
meta.members = (name for name of value)
else else
meta.type = 'value' meta.type = 'value'
meta.value = value meta.value = value
@ -122,6 +130,12 @@ ipcMain.on 'ATOM_BROWSER_REQUIRE', (event, module) ->
catch e catch e
event.returnValue = exceptionToMeta e event.returnValue = exceptionToMeta e
ipcMain.on 'ATOM_BROWSER_GET_BUILTIN', (event, module) ->
try
event.returnValue = valueToMeta event.sender, electron[module]
catch e
event.returnValue = exceptionToMeta e
ipcMain.on 'ATOM_BROWSER_GLOBAL', (event, name) -> ipcMain.on 'ATOM_BROWSER_GLOBAL', (event, name) ->
try try
event.returnValue = valueToMeta event.sender, global[name] event.returnValue = valueToMeta event.sender, global[name]

View file

@ -4,7 +4,7 @@ Object.defineProperties exports,
# Must be enumerable, otherwise it woulde be invisible to remote module. # Must be enumerable, otherwise it woulde be invisible to remote module.
enumerable: true enumerable: true
get: -> require '../clipboard' get: -> require '../clipboard'
crashRepoter: crashReporter:
enumerable: true enumerable: true
get: -> require '../crash-reporter' get: -> require '../crash-reporter'
nativeImage: nativeImage:

View file

@ -18,7 +18,7 @@ wrapArgs = (args, visited=[]) ->
type: 'array', value: wrapArgs(value, visited) type: 'array', value: wrapArgs(value, visited)
else if Buffer.isBuffer value else if Buffer.isBuffer value
type: 'buffer', value: Array::slice.call(value, 0) type: 'buffer', value: Array::slice.call(value, 0)
else if value? and value.constructor.name is 'Promise' else if value?.constructor.name is 'Promise'
type: 'promise', then: valueToMeta(value.then.bind(value)) type: 'promise', then: valueToMeta(value.then.bind(value))
else if value? and typeof value is 'object' and v8Util.getHiddenValue value, 'atomId' else if value? and typeof value is 'object' and v8Util.getHiddenValue value, 'atomId'
type: 'remote-object', id: v8Util.getHiddenValue value, 'atomId' type: 'remote-object', id: v8Util.getHiddenValue value, 'atomId'
@ -49,6 +49,15 @@ metaToValue = (meta) ->
when 'date' then new Date(meta.value) when 'date' then new Date(meta.value)
when 'exception' when 'exception'
throw new Error("#{meta.message}\n#{meta.stack}") throw new Error("#{meta.message}\n#{meta.stack}")
when 'electronModule'
# require('electron').
ret = {}
for member in meta.members
do (member) ->
Object.defineProperty ret, member,
enumerable: true
get: -> exports.getBuiltin member
ret
else else
if meta.type is 'function' if meta.type is 'function'
# A shadow class to represent the remote function object. # A shadow class to represent the remote function object.
@ -135,6 +144,14 @@ exports.require = (module) ->
meta = ipcRenderer.sendSync 'ATOM_BROWSER_REQUIRE', module meta = ipcRenderer.sendSync 'ATOM_BROWSER_REQUIRE', module
moduleCache[module] = metaToValue meta moduleCache[module] = metaToValue meta
# Alias to remote.require('electron').xxx.
builtinCache = {}
exports.getBuiltin = (module) ->
return builtinCache[module] if builtinCache[module]?
meta = ipcRenderer.sendSync 'ATOM_BROWSER_GET_BUILTIN', module
builtinCache[module] = metaToValue meta
# Get current BrowserWindow object. # Get current BrowserWindow object.
windowCache = null windowCache = null
exports.getCurrentWindow = -> exports.getCurrentWindow = ->