2015-04-24 18:00:20 -07:00
|
|
|
/**
|
2018-09-11 15:27:47 -07:00
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
2015-04-24 18:00:20 -07:00
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2015-04-24 18:00:20 -07:00
|
|
|
*
|
2018-05-10 19:06:46 -07:00
|
|
|
* @format
|
2015-04-24 18:00:20 -07:00
|
|
|
* @flow
|
|
|
|
*/
|
2018-05-10 19:06:46 -07:00
|
|
|
|
2015-04-24 18:00:20 -07:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tries to stringify with JSON.stringify and toString, but catches exceptions
|
|
|
|
* (e.g. from circular objects) and always returns a string and never throws.
|
|
|
|
*/
|
|
|
|
function stringifySafe(arg: any): string {
|
2018-05-10 15:44:52 -07:00
|
|
|
let ret;
|
|
|
|
const type = typeof arg;
|
2015-04-24 18:00:20 -07:00
|
|
|
if (arg === undefined) {
|
|
|
|
ret = 'undefined';
|
|
|
|
} else if (arg === null) {
|
|
|
|
ret = 'null';
|
2015-05-04 18:34:29 -07:00
|
|
|
} else if (type === 'string') {
|
2015-04-24 18:00:20 -07:00
|
|
|
ret = '"' + arg + '"';
|
2015-05-04 18:34:29 -07:00
|
|
|
} else if (type === 'function') {
|
|
|
|
try {
|
|
|
|
ret = arg.toString();
|
|
|
|
} catch (e) {
|
|
|
|
ret = '[function unknown]';
|
|
|
|
}
|
2015-04-24 18:00:20 -07:00
|
|
|
} else {
|
|
|
|
// Perform a try catch, just in case the object has a circular
|
|
|
|
// reference or stringify throws for some other reason.
|
|
|
|
try {
|
|
|
|
ret = JSON.stringify(arg);
|
|
|
|
} catch (e) {
|
|
|
|
if (typeof arg.toString === 'function') {
|
|
|
|
try {
|
|
|
|
ret = arg.toString();
|
|
|
|
} catch (E) {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-05-04 18:34:29 -07:00
|
|
|
return ret || '["' + type + '" failed to stringify]';
|
2015-04-24 18:00:20 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = stringifySafe;
|