Refactor and optimize base equals

This commit is contained in:
Graeme 2014-12-13 11:59:37 -05:00
parent f193acf31b
commit 65df4d079e

View file

@ -113,12 +113,6 @@ Base.inject(/** @lends Base# */{
* arrays and properties of objects. * arrays and properties of objects.
*/ */
equals: function(obj1, obj2) { equals: function(obj1, obj2) {
function checkKeys(o1, o2) {
for (var i in o1)
if (o1.hasOwnProperty(i) && !o2.hasOwnProperty(i))
return false;
return true;
}
if (obj1 === obj2) if (obj1 === obj2)
return true; return true;
// Call #equals() on both obj1 and obj2 // Call #equals() on both obj1 and obj2
@ -126,28 +120,33 @@ Base.inject(/** @lends Base# */{
return obj1.equals(obj2); return obj1.equals(obj2);
if (obj2 && obj2.equals) if (obj2 && obj2.equals)
return obj2.equals(obj1); return obj2.equals(obj1);
// Compare arrays
if (Array.isArray(obj1) && Array.isArray(obj2)) { // Deep compare objects or arraays
if (obj1.length !== obj2.length)
return false;
for (var i = 0, l = obj1.length; i < l; i++) {
if (!Base.equals(obj1[i], obj2[i]))
return false;
}
return true;
}
// Compare objects // Compare objects
if (obj1 && typeof obj1 === 'object' if (obj1 && obj2 &&
&& obj2 && typeof obj2 === 'object') { typeof obj1 === 'object' &&
if (!checkKeys(obj1, obj2) || !checkKeys(obj2, obj1)) typeof obj2 === 'object') {
return false; // Compare arrays
for (var i in obj1) { if (Array.isArray(obj1) && Array.isArray(obj2)) {
if (obj1.hasOwnProperty(i) if (obj1.length !== obj2.length) return false;
&& !Base.equals(obj1[i], obj2[i])) for (var i = 0, l = obj1.length; i < l; i++) {
return false; if (!Base.equals(obj1[i], obj2[i])) return false;
}
} else {
// Deep compare objects.
var keys = Object.keys(obj1), key;
var length = keys.length;
// Ensure that both objects contain the same number of properties before comparing deep equality.
if (Object.keys(obj2).length !== length) return false;
while (length--) {
// Deep compare each member
key = keys[length];
if (!(obj2.hasOwnProperty(key) && Base.equals(obj1[key], obj2[key]))) return false;
}
} }
return true; return true;
} }
return false; return false;
}, },