@gilbarbara/deep-equal
Version:
Tiny deep equal comparator
152 lines (149 loc) • 4.23 kB
JavaScript
;
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/index.ts
var src_exports = {};
__export(src_exports, {
default: () => equal
});
module.exports = __toCommonJS(src_exports);
// src/helpers.ts
function isOfType(type) {
return (value) => typeof value === type;
}
var isFunction = isOfType("function");
var isNull = (value) => {
return value === null;
};
var isRegex = (value) => {
return Object.prototype.toString.call(value).slice(8, -1) === "RegExp";
};
var isObject = (value) => {
return !isUndefined(value) && !isNull(value) && (isFunction(value) || typeof value === "object");
};
var isUndefined = isOfType("undefined");
// src/index.ts
function equalArray(left, right) {
const { length } = left;
if (length !== right.length) {
return false;
}
for (let index = length; index-- !== 0; ) {
if (!equal(left[index], right[index])) {
return false;
}
}
return true;
}
function equalArrayBuffer(left, right) {
if (left.byteLength !== right.byteLength) {
return false;
}
const view1 = new DataView(left.buffer);
const view2 = new DataView(right.buffer);
let index = left.byteLength;
while (index--) {
if (view1.getUint8(index) !== view2.getUint8(index)) {
return false;
}
}
return true;
}
function equalMap(left, right) {
if (left.size !== right.size) {
return false;
}
for (const index of left.entries()) {
if (!right.has(index[0])) {
return false;
}
}
for (const index of left.entries()) {
if (!equal(index[1], right.get(index[0]))) {
return false;
}
}
return true;
}
function equalSet(left, right) {
if (left.size !== right.size) {
return false;
}
for (const index of left.entries()) {
if (!right.has(index[0])) {
return false;
}
}
return true;
}
function equal(left, right) {
if (left === right) {
return true;
}
if (left && isObject(left) && right && isObject(right)) {
if (left.constructor !== right.constructor) {
return false;
}
if (Array.isArray(left) && Array.isArray(right)) {
return equalArray(left, right);
}
if (left instanceof Map && right instanceof Map) {
return equalMap(left, right);
}
if (left instanceof Set && right instanceof Set) {
return equalSet(left, right);
}
if (ArrayBuffer.isView(left) && ArrayBuffer.isView(right)) {
return equalArrayBuffer(left, right);
}
if (isRegex(left) && isRegex(right)) {
return left.source === right.source && left.flags === right.flags;
}
if (left.valueOf !== Object.prototype.valueOf) {
return left.valueOf() === right.valueOf();
}
if (left.toString !== Object.prototype.toString) {
return left.toString() === right.toString();
}
const leftKeys = Object.keys(left);
const rightKeys = Object.keys(right);
if (leftKeys.length !== rightKeys.length) {
return false;
}
for (let index = leftKeys.length; index-- !== 0; ) {
if (!Object.prototype.hasOwnProperty.call(right, leftKeys[index])) {
return false;
}
}
for (let index = leftKeys.length; index-- !== 0; ) {
const key = leftKeys[index];
if (key === "_owner" && left.$$typeof) {
continue;
}
if (!equal(left[key], right[key])) {
return false;
}
}
return true;
}
if (Number.isNaN(left) && Number.isNaN(right)) {
return true;
}
return left === right;
}
//# sourceMappingURL=index.js.map