26 lines
829 B
JavaScript
26 lines
829 B
JavaScript
import {deserialize} from './deserialize.js';
|
|
import {serialize} from './serialize.js';
|
|
|
|
/**
|
|
* @typedef {Array<string,any>} Record a type representation
|
|
*/
|
|
|
|
/**
|
|
* Returns an array of serialized Records.
|
|
* @param {any} any a serializable value.
|
|
* @param {{transfer?: any[], json?: boolean, lossy?: boolean}?} options an object with
|
|
* a transfer option (ignored when polyfilled) and/or non standard fields that
|
|
* fallback to the polyfill if present.
|
|
* @returns {Record[]}
|
|
*/
|
|
export default typeof structuredClone === "function" ?
|
|
/* c8 ignore start */
|
|
(any, options) => (
|
|
options && ('json' in options || 'lossy' in options) ?
|
|
deserialize(serialize(any, options)) : structuredClone(any)
|
|
) :
|
|
(any, options) => deserialize(serialize(any, options));
|
|
/* c8 ignore stop */
|
|
|
|
export {deserialize, serialize};
|