parent
07adbc8e8a
commit
d5c964c68c
2 changed files with 17 additions and 13 deletions
|
@ -10,6 +10,7 @@ valueToMeta = (sender, value, optimizeSimpleObject=false) ->
|
||||||
meta.type = 'buffer' if Buffer.isBuffer value
|
meta.type = 'buffer' if Buffer.isBuffer value
|
||||||
meta.type = 'value' if value is null
|
meta.type = 'value' if value is null
|
||||||
meta.type = 'array' if Array.isArray value
|
meta.type = 'array' if Array.isArray value
|
||||||
|
meta.type = 'error' if value instanceof Error
|
||||||
meta.type = 'promise' if value? and value.constructor.name is 'Promise'
|
meta.type = 'promise' if value? and value.constructor.name is 'Promise'
|
||||||
|
|
||||||
# Treat simple objects as value.
|
# Treat simple objects as value.
|
||||||
|
@ -36,6 +37,8 @@ valueToMeta = (sender, value, optimizeSimpleObject=false) ->
|
||||||
meta.value = Array::slice.call value, 0
|
meta.value = Array::slice.call value, 0
|
||||||
else if meta.type is 'promise'
|
else if meta.type is 'promise'
|
||||||
meta.then = valueToMeta(sender, value.then.bind(value))
|
meta.then = valueToMeta(sender, value.then.bind(value))
|
||||||
|
else if meta.type is 'error'
|
||||||
|
meta.message = value.message
|
||||||
else
|
else
|
||||||
meta.type = 'value'
|
meta.type = 'value'
|
||||||
meta.value = value
|
meta.value = value
|
||||||
|
@ -43,8 +46,8 @@ valueToMeta = (sender, value, optimizeSimpleObject=false) ->
|
||||||
meta
|
meta
|
||||||
|
|
||||||
# Convert Error into meta data.
|
# Convert Error into meta data.
|
||||||
errorToMeta = (error) ->
|
exceptionToMeta = (error) ->
|
||||||
type: 'error', message: error.message, stack: (error.stack || error)
|
type: 'exception', message: error.message, stack: (error.stack || error)
|
||||||
|
|
||||||
# Convert array of meta data from renderer into array of real values.
|
# Convert array of meta data from renderer into array of real values.
|
||||||
unwrapArgs = (sender, args) ->
|
unwrapArgs = (sender, args) ->
|
||||||
|
@ -100,19 +103,19 @@ ipc.on 'ATOM_BROWSER_REQUIRE', (event, module) ->
|
||||||
try
|
try
|
||||||
event.returnValue = valueToMeta event.sender, process.mainModule.require(module)
|
event.returnValue = valueToMeta event.sender, process.mainModule.require(module)
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_GLOBAL', (event, name) ->
|
ipc.on 'ATOM_BROWSER_GLOBAL', (event, name) ->
|
||||||
try
|
try
|
||||||
event.returnValue = valueToMeta event.sender, global[name]
|
event.returnValue = valueToMeta event.sender, global[name]
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_CURRENT_WINDOW', (event) ->
|
ipc.on 'ATOM_BROWSER_CURRENT_WINDOW', (event) ->
|
||||||
try
|
try
|
||||||
event.returnValue = valueToMeta event.sender, event.sender.getOwnerBrowserWindow()
|
event.returnValue = valueToMeta event.sender, event.sender.getOwnerBrowserWindow()
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_CURRENT_WEB_CONTENTS', (event) ->
|
ipc.on 'ATOM_BROWSER_CURRENT_WEB_CONTENTS', (event) ->
|
||||||
event.returnValue = valueToMeta event.sender, event.sender
|
event.returnValue = valueToMeta event.sender, event.sender
|
||||||
|
@ -126,7 +129,7 @@ ipc.on 'ATOM_BROWSER_CONSTRUCTOR', (event, id, args) ->
|
||||||
obj = new (Function::bind.apply(constructor, [null].concat(args)))
|
obj = new (Function::bind.apply(constructor, [null].concat(args)))
|
||||||
event.returnValue = valueToMeta event.sender, obj
|
event.returnValue = valueToMeta event.sender, obj
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_FUNCTION_CALL', (event, id, args) ->
|
ipc.on 'ATOM_BROWSER_FUNCTION_CALL', (event, id, args) ->
|
||||||
try
|
try
|
||||||
|
@ -134,7 +137,7 @@ ipc.on 'ATOM_BROWSER_FUNCTION_CALL', (event, id, args) ->
|
||||||
func = objectsRegistry.get id
|
func = objectsRegistry.get id
|
||||||
callFunction event, func, global, args
|
callFunction event, func, global, args
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_MEMBER_CONSTRUCTOR', (event, id, method, args) ->
|
ipc.on 'ATOM_BROWSER_MEMBER_CONSTRUCTOR', (event, id, method, args) ->
|
||||||
try
|
try
|
||||||
|
@ -144,7 +147,7 @@ ipc.on 'ATOM_BROWSER_MEMBER_CONSTRUCTOR', (event, id, method, args) ->
|
||||||
obj = new (Function::bind.apply(constructor, [null].concat(args)))
|
obj = new (Function::bind.apply(constructor, [null].concat(args)))
|
||||||
event.returnValue = valueToMeta event.sender, obj
|
event.returnValue = valueToMeta event.sender, obj
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_MEMBER_CALL', (event, id, method, args) ->
|
ipc.on 'ATOM_BROWSER_MEMBER_CALL', (event, id, method, args) ->
|
||||||
try
|
try
|
||||||
|
@ -152,7 +155,7 @@ ipc.on 'ATOM_BROWSER_MEMBER_CALL', (event, id, method, args) ->
|
||||||
obj = objectsRegistry.get id
|
obj = objectsRegistry.get id
|
||||||
callFunction event, obj[method], obj, args
|
callFunction event, obj[method], obj, args
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_MEMBER_SET', (event, id, name, value) ->
|
ipc.on 'ATOM_BROWSER_MEMBER_SET', (event, id, name, value) ->
|
||||||
try
|
try
|
||||||
|
@ -160,14 +163,14 @@ ipc.on 'ATOM_BROWSER_MEMBER_SET', (event, id, name, value) ->
|
||||||
obj[name] = value
|
obj[name] = value
|
||||||
event.returnValue = null
|
event.returnValue = null
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_MEMBER_GET', (event, id, name) ->
|
ipc.on 'ATOM_BROWSER_MEMBER_GET', (event, id, name) ->
|
||||||
try
|
try
|
||||||
obj = objectsRegistry.get id
|
obj = objectsRegistry.get id
|
||||||
event.returnValue = valueToMeta event.sender, obj[name]
|
event.returnValue = valueToMeta event.sender, obj[name]
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
||||||
ipc.on 'ATOM_BROWSER_DEREFERENCE', (event, id) ->
|
ipc.on 'ATOM_BROWSER_DEREFERENCE', (event, id) ->
|
||||||
objectsRegistry.remove event.sender.getId(), id
|
objectsRegistry.remove event.sender.getId(), id
|
||||||
|
@ -177,4 +180,4 @@ ipc.on 'ATOM_BROWSER_GUEST_WEB_CONTENTS', (event, guestInstanceId) ->
|
||||||
guestViewManager = require './guest-view-manager'
|
guestViewManager = require './guest-view-manager'
|
||||||
event.returnValue = valueToMeta event.sender, guestViewManager.getGuest(guestInstanceId)
|
event.returnValue = valueToMeta event.sender, guestViewManager.getGuest(guestInstanceId)
|
||||||
catch e
|
catch e
|
||||||
event.returnValue = errorToMeta e
|
event.returnValue = exceptionToMeta e
|
||||||
|
|
|
@ -46,7 +46,8 @@ metaToValue = (meta) ->
|
||||||
when 'array' then (metaToValue(el) for el in meta.members)
|
when 'array' then (metaToValue(el) for el in meta.members)
|
||||||
when 'buffer' then new Buffer(meta.value)
|
when 'buffer' then new Buffer(meta.value)
|
||||||
when 'promise' then Promise.resolve(then: metaToValue(meta.then))
|
when 'promise' then Promise.resolve(then: metaToValue(meta.then))
|
||||||
when 'error'
|
when 'error' then new Error(meta.message)
|
||||||
|
when 'exception'
|
||||||
throw new Error("#{meta.message}\n#{meta.stack}")
|
throw new Error("#{meta.message}\n#{meta.stack}")
|
||||||
else
|
else
|
||||||
if meta.type is 'function'
|
if meta.type is 'function'
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue