Code cleanup for remote module
This commit is contained in:
parent
88fc4e9d05
commit
647a0c4e2b
2 changed files with 14 additions and 21 deletions
|
@ -33,14 +33,13 @@ valueToMeta = (sender, value, optimizeSimpleObject=false) ->
|
||||||
# it.
|
# it.
|
||||||
meta.id = objectsRegistry.add sender.getId(), value
|
meta.id = objectsRegistry.add sender.getId(), value
|
||||||
|
|
||||||
meta.members = []
|
meta.members = ({name, type: typeof field} for name, field of value)
|
||||||
meta.members.push {name: prop, type: typeof field} for prop, field of value
|
|
||||||
else if meta.type is 'buffer'
|
else if meta.type is 'buffer'
|
||||||
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'
|
else if meta.type is 'error'
|
||||||
meta = errorValueToMeta(value, meta)
|
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
|
else
|
||||||
|
@ -49,12 +48,9 @@ valueToMeta = (sender, value, optimizeSimpleObject=false) ->
|
||||||
|
|
||||||
meta
|
meta
|
||||||
|
|
||||||
# Convert Error into meta data.
|
# Convert object to meta by value.
|
||||||
errorValueToMeta = (err, meta) ->
|
plainObjectToMeta = (obj) ->
|
||||||
Object.getOwnPropertyNames(err).reduce((obj, key) ->
|
Object.getOwnPropertyNames(obj).map (name) -> {name, value: obj[name]}
|
||||||
obj[key] = err[key]
|
|
||||||
obj
|
|
||||||
, meta)
|
|
||||||
|
|
||||||
# Convert Error into meta data.
|
# Convert Error into meta data.
|
||||||
exceptionToMeta = (error) ->
|
exceptionToMeta = (error) ->
|
||||||
|
|
|
@ -46,7 +46,7 @@ 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' then metaToError(meta)
|
when 'error' then metaToPlainObject 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}")
|
||||||
|
@ -110,16 +110,13 @@ metaToValue = (meta) ->
|
||||||
|
|
||||||
ret
|
ret
|
||||||
|
|
||||||
# Convert meta data from browser into Error.
|
# Construct a plain object from the meta.
|
||||||
metaToError = (meta) ->
|
metaToPlainObject = (meta) ->
|
||||||
Object.getOwnPropertyNames(meta).reduce((error, prop) ->
|
obj = switch meta.type
|
||||||
Object.defineProperty(error, prop, {
|
when 'error' then new Error
|
||||||
get: -> meta[prop],
|
else {}
|
||||||
enumerable: false,
|
obj[name] = value for {name, value} in meta.members
|
||||||
configurable: false
|
obj
|
||||||
})
|
|
||||||
error
|
|
||||||
, new Error())
|
|
||||||
|
|
||||||
# Browser calls a callback in renderer.
|
# Browser calls a callback in renderer.
|
||||||
ipc.on 'ATOM_RENDERER_CALLBACK', (id, args) ->
|
ipc.on 'ATOM_RENDERER_CALLBACK', (id, args) ->
|
||||||
|
|
Loading…
Reference in a new issue