83 lines
2.9 KiB
JavaScript
83 lines
2.9 KiB
JavaScript
|
var Stack = require('./_Stack'),
|
||
|
equalArrays = require('./_equalArrays'),
|
||
|
equalByTag = require('./_equalByTag'),
|
||
|
equalObjects = require('./_equalObjects'),
|
||
|
getTag = require('./_getTag'),
|
||
|
isArray = require('./isArray'),
|
||
|
isHostObject = require('./_isHostObject'),
|
||
|
isTypedArray = require('./isTypedArray');
|
||
|
|
||
|
/** Used to compose bitmasks for comparison styles. */
|
||
|
var PARTIAL_COMPARE_FLAG = 2;
|
||
|
|
||
|
/** `Object#toString` result references. */
|
||
|
var argsTag = '[object Arguments]',
|
||
|
arrayTag = '[object Array]',
|
||
|
objectTag = '[object Object]';
|
||
|
|
||
|
/** Used for built-in method references. */
|
||
|
var objectProto = Object.prototype;
|
||
|
|
||
|
/** Used to check objects for own properties. */
|
||
|
var hasOwnProperty = objectProto.hasOwnProperty;
|
||
|
|
||
|
/**
|
||
|
* A specialized version of `baseIsEqual` for arrays and objects which performs
|
||
|
* deep comparisons and tracks traversed objects enabling objects with circular
|
||
|
* references to be compared.
|
||
|
*
|
||
|
* @private
|
||
|
* @param {Object} object The object to compare.
|
||
|
* @param {Object} other The other object to compare.
|
||
|
* @param {Function} equalFunc The function to determine equivalents of values.
|
||
|
* @param {Function} [customizer] The function to customize comparisons.
|
||
|
* @param {number} [bitmask] The bitmask of comparison flags. See `baseIsEqual`
|
||
|
* for more details.
|
||
|
* @param {Object} [stack] Tracks traversed `object` and `other` objects.
|
||
|
* @returns {boolean} Returns `true` if the objects are equivalent, else `false`.
|
||
|
*/
|
||
|
function baseIsEqualDeep(object, other, equalFunc, customizer, bitmask, stack) {
|
||
|
var objIsArr = isArray(object),
|
||
|
othIsArr = isArray(other),
|
||
|
objTag = arrayTag,
|
||
|
othTag = arrayTag;
|
||
|
|
||
|
if (!objIsArr) {
|
||
|
objTag = getTag(object);
|
||
|
objTag = objTag == argsTag ? objectTag : objTag;
|
||
|
}
|
||
|
if (!othIsArr) {
|
||
|
othTag = getTag(other);
|
||
|
othTag = othTag == argsTag ? objectTag : othTag;
|
||
|
}
|
||
|
var objIsObj = objTag == objectTag && !isHostObject(object),
|
||
|
othIsObj = othTag == objectTag && !isHostObject(other),
|
||
|
isSameTag = objTag == othTag;
|
||
|
|
||
|
if (isSameTag && !objIsObj) {
|
||
|
stack || (stack = new Stack);
|
||
|
return (objIsArr || isTypedArray(object))
|
||
|
? equalArrays(object, other, equalFunc, customizer, bitmask, stack)
|
||
|
: equalByTag(object, other, objTag, equalFunc, customizer, bitmask, stack);
|
||
|
}
|
||
|
if (!(bitmask & PARTIAL_COMPARE_FLAG)) {
|
||
|
var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),
|
||
|
othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');
|
||
|
|
||
|
if (objIsWrapped || othIsWrapped) {
|
||
|
var objUnwrapped = objIsWrapped ? object.value() : object,
|
||
|
othUnwrapped = othIsWrapped ? other.value() : other;
|
||
|
|
||
|
stack || (stack = new Stack);
|
||
|
return equalFunc(objUnwrapped, othUnwrapped, customizer, bitmask, stack);
|
||
|
}
|
||
|
}
|
||
|
if (!isSameTag) {
|
||
|
return false;
|
||
|
}
|
||
|
stack || (stack = new Stack);
|
||
|
return equalObjects(object, other, equalFunc, customizer, bitmask, stack);
|
||
|
}
|
||
|
|
||
|
module.exports = baseIsEqualDeep;
|