eigent/package/@stackframe/stack-shared/dist/utils/objects.js

228 lines
7.7 KiB
JavaScript

"use strict";
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/utils/objects.tsx
var objects_exports = {};
__export(objects_exports, {
deepFilterUndefined: () => deepFilterUndefined,
deepMerge: () => deepMerge,
deepPlainClone: () => deepPlainClone,
deepPlainEquals: () => deepPlainEquals,
deepSortKeys: () => deepSortKeys,
deleteKey: () => deleteKey,
filterUndefined: () => filterUndefined,
filterUndefinedOrNull: () => filterUndefinedOrNull,
get: () => get,
getOrUndefined: () => getOrUndefined,
has: () => has,
hasAndNotUndefined: () => hasAndNotUndefined,
isCloneable: () => isCloneable,
isNotNull: () => isNotNull,
isObjectLike: () => isObjectLike,
mapValues: () => mapValues,
omit: () => omit,
pick: () => pick,
set: () => set,
shallowClone: () => shallowClone,
sortKeys: () => sortKeys,
split: () => split,
typedAssign: () => typedAssign,
typedEntries: () => typedEntries,
typedFromEntries: () => typedFromEntries,
typedKeys: () => typedKeys,
typedValues: () => typedValues
});
module.exports = __toCommonJS(objects_exports);
var import_errors = require("./errors");
var import_functions = require("./functions");
var import_strings = require("./strings");
function isNotNull(value) {
return value !== null && value !== void 0;
}
function deepPlainEquals(obj1, obj2, options = {}) {
if (typeof obj1 !== typeof obj2) return false;
if (obj1 === obj2) return true;
switch (typeof obj1) {
case "object": {
if (!obj1 || !obj2) return false;
if (Array.isArray(obj1) || Array.isArray(obj2)) {
if (!Array.isArray(obj1) || !Array.isArray(obj2)) return false;
if (obj1.length !== obj2.length) return false;
return obj1.every((v, i) => deepPlainEquals(v, obj2[i], options));
}
const entries1 = Object.entries(obj1).filter(([k, v]) => !options.ignoreUndefinedValues || v !== void 0);
const entries2 = Object.entries(obj2).filter(([k, v]) => !options.ignoreUndefinedValues || v !== void 0);
if (entries1.length !== entries2.length) return false;
return entries1.every(([k, v1]) => {
const e2 = entries2.find(([k2]) => k === k2);
if (!e2) return false;
return deepPlainEquals(v1, e2[1], options);
});
}
case "undefined":
case "string":
case "number":
case "boolean":
case "bigint":
case "symbol":
case "function": {
return false;
}
default: {
throw new Error("Unexpected typeof " + typeof obj1);
}
}
}
function isCloneable(obj) {
return typeof obj !== "symbol" && typeof obj !== "function";
}
function shallowClone(obj) {
if (!isCloneable(obj)) throw new import_errors.StackAssertionError("shallowClone does not support symbols or functions", { obj });
if (Array.isArray(obj)) return obj.map(import_functions.identity);
return { ...obj };
}
function deepPlainClone(obj) {
if (typeof obj === "function") throw new import_errors.StackAssertionError("deepPlainClone does not support functions");
if (typeof obj === "symbol") throw new import_errors.StackAssertionError("deepPlainClone does not support symbols");
if (typeof obj !== "object" || !obj) return obj;
if (Array.isArray(obj)) return obj.map(deepPlainClone);
return Object.fromEntries(Object.entries(obj).map(([k, v]) => [k, deepPlainClone(v)]));
}
function deepMerge(baseObj, mergeObj) {
if ([baseObj, mergeObj, ...Object.values(baseObj), ...Object.values(mergeObj)].some((o) => !isCloneable(o))) throw new import_errors.StackAssertionError("deepMerge does not support functions or symbols", { baseObj, mergeObj });
const res = shallowClone(baseObj);
for (const [key, mergeValue] of Object.entries(mergeObj)) {
if (has(res, key)) {
const baseValue = get(res, key);
if (isObjectLike(baseValue) && isObjectLike(mergeValue)) {
set(res, key, deepMerge(baseValue, mergeValue));
continue;
}
}
set(res, key, mergeValue);
}
return res;
}
function typedEntries(obj) {
return Object.entries(obj);
}
function typedFromEntries(entries) {
return Object.fromEntries(entries);
}
function typedKeys(obj) {
return Object.keys(obj);
}
function typedValues(obj) {
return Object.values(obj);
}
function typedAssign(target, source) {
return Object.assign(target, source);
}
function filterUndefined(obj) {
return Object.fromEntries(Object.entries(obj).filter(([, v]) => v !== void 0));
}
function filterUndefinedOrNull(obj) {
return Object.fromEntries(Object.entries(obj).filter(([, v]) => v !== void 0 && v !== null));
}
function deepFilterUndefined(obj) {
return Object.fromEntries(Object.entries(obj).filter(([, v]) => v !== void 0).map(([k, v]) => [k, isObjectLike(v) ? deepFilterUndefined(v) : v]));
}
function pick(obj, keys) {
return Object.fromEntries(Object.entries(obj).filter(([k]) => keys.includes(k)));
}
function omit(obj, keys) {
if (!Array.isArray(keys)) throw new import_errors.StackAssertionError("omit: keys must be an array", { obj, keys });
return Object.fromEntries(Object.entries(obj).filter(([k]) => !keys.includes(k)));
}
function split(obj, keys) {
return [pick(obj, keys), omit(obj, keys)];
}
function mapValues(obj, fn) {
if (Array.isArray(obj)) {
return obj.map((v) => fn(v));
}
return Object.fromEntries(Object.entries(obj).map(([k, v]) => [k, fn(v)]));
}
function sortKeys(obj) {
if (Array.isArray(obj)) {
return [...obj];
}
return Object.fromEntries(Object.entries(obj).sort(([a], [b]) => (0, import_strings.stringCompare)(a, b)));
}
function deepSortKeys(obj) {
return sortKeys(mapValues(obj, (v) => isObjectLike(v) ? deepSortKeys(v) : v));
}
function set(obj, key, value) {
Object.defineProperty(obj, key, { value, writable: true, configurable: true, enumerable: true });
}
function get(obj, key) {
const descriptor = Object.getOwnPropertyDescriptor(obj, key);
if (!descriptor) throw new import_errors.StackAssertionError(`get: key ${String(key)} does not exist`, { obj, key });
return descriptor.value;
}
function getOrUndefined(obj, key) {
return has(obj, key) ? get(obj, key) : void 0;
}
function has(obj, key) {
return Object.prototype.hasOwnProperty.call(obj, key);
}
function hasAndNotUndefined(obj, key) {
return has(obj, key) && get(obj, key) !== void 0;
}
function deleteKey(obj, key) {
if (has(obj, key)) {
Reflect.deleteProperty(obj, key);
} else {
throw new import_errors.StackAssertionError(`deleteKey: key ${String(key)} does not exist`, { obj, key });
}
}
function isObjectLike(value) {
return (typeof value === "object" || typeof value === "function") && value !== null;
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
deepFilterUndefined,
deepMerge,
deepPlainClone,
deepPlainEquals,
deepSortKeys,
deleteKey,
filterUndefined,
filterUndefinedOrNull,
get,
getOrUndefined,
has,
hasAndNotUndefined,
isCloneable,
isNotNull,
isObjectLike,
mapValues,
omit,
pick,
set,
shallowClone,
sortKeys,
split,
typedAssign,
typedEntries,
typedFromEntries,
typedKeys,
typedValues
});
//# sourceMappingURL=objects.js.map