jiangchengfeiyi-xiaochengxu/node_modules/mathjs/lib/cjs/json/replacer.js
2025-01-02 11:13:50 +08:00

39 lines
1.1 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.createReplacer = void 0;
var _factory = require("../utils/factory.js");
const name = 'replacer';
const dependencies = [];
const createReplacer = exports.createReplacer = /* #__PURE__ */(0, _factory.factory)(name, dependencies, () => {
/**
* Stringify data types into their JSON representation.
* Most data types can be serialized using their `.toJSON` method,
* but not all, for example the number `Infinity`. For these cases you have
* to use the replacer. Example usage:
*
* JSON.stringify([2, Infinity], math.replacer)
*
* @param {string} key
* @param {*} value
* @returns {*} Returns the replaced object
*/
return function replacer(key, value) {
// the numeric values Infinitiy, -Infinity, and NaN cannot be serialized to JSON
if (typeof value === 'number' && (!isFinite(value) || isNaN(value))) {
return {
mathjs: 'number',
value: String(value)
};
}
if (typeof value === 'bigint') {
return {
mathjs: 'bigint',
value: String(value)
};
}
return value;
};
});