mirror of
https://github.com/electron/electron.git
synced 2026-01-27 08:18:28 -05:00
* refactor: add error-utils.js
* fix exception handling for asyncWebFrameMethods
* remove dead code
* handle exceptions
* rename rehydratedError to deserializedError
* Revert "handle exceptions"
This reverts commit 396b179948.
36 lines
977 B
JavaScript
36 lines
977 B
JavaScript
'use strict'
|
|
|
|
const constructors = new Map([
|
|
[Error.name, Error],
|
|
[EvalError.name, EvalError],
|
|
[RangeError.name, RangeError],
|
|
[ReferenceError.name, ReferenceError],
|
|
[SyntaxError.name, SyntaxError],
|
|
[TypeError.name, TypeError],
|
|
[URIError.name, URIError]
|
|
])
|
|
|
|
exports.deserialize = function (error) {
|
|
if (error.__ELECTRON_SERIALIZED_ERROR__ && constructors.has(error.name)) {
|
|
const constructor = constructors.get(error.name)
|
|
const deserializedError = new constructor(error.message)
|
|
deserializedError.stack = error.stack
|
|
return deserializedError
|
|
}
|
|
return error
|
|
}
|
|
|
|
exports.serialize = function (error) {
|
|
if (error instanceof Error) {
|
|
// Errors get lost, because: JSON.stringify(new Error('Message')) === {}
|
|
// Take the serializable properties and construct a generic object
|
|
return {
|
|
message: error.message,
|
|
stack: error.stack,
|
|
name: error.name,
|
|
__ELECTRON_SERIALIZED_ERROR__: true
|
|
}
|
|
}
|
|
return error
|
|
}
|