From c6208db025b25ce563fe7e7ea9736fe8b90cc6bb Mon Sep 17 00:00:00 2001 From: Graeme Date: Sat, 13 Dec 2014 11:47:03 -0500 Subject: [PATCH] Refactor Base._set --- src/core/Base.js | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/core/Base.js b/src/core/Base.js index 208eacca..95fff0b3 100644 --- a/src/core/Base.js +++ b/src/core/Base.js @@ -72,18 +72,18 @@ Base.inject(/** @lends Base# */{ * @return {Boolean} {@true if the object is a plain object} */ _set: function(props, exclude, dontCheck) { - if (props && (dontCheck || Base.isPlainObject(props))) { + if (dontCheck || Base.isPlainObject(props)) { // If props is a filtering object, we need to execute hasOwnProperty // on the original object (it's parent / prototype). See _filtered // inheritance trick in the argument reading code. - var orig = props._filtering || props; - for (var key in orig) { - if (orig.hasOwnProperty(key) && !(exclude && exclude[key])) { - var value = props[key]; + var keys = Object.keys(props._filtering || props); + for (var i = 0; i < keys.length; i++) { + var key = keys[i]; + if (!(exclude && exclude[key])) { // Due to the _filtered inheritance trick, undefined is used // to mask already consumed named arguments. - if (value !== undefined) - this[key] = value; + if (props[key] !== undefined) + this[key] = props[key]; } } return true;