Change Base.isObject() to also check for instances of plain Base objects, and rename it to Base.isPlainObject().

This commit is contained in:
Jürg Lehni 2012-12-30 17:30:13 +01:00
parent 2abefee336
commit 24b5f870bd
5 changed files with 14 additions and 8 deletions

12
lib/bootstrap.js vendored
View file

@ -315,9 +315,15 @@ var Base = new function() { // Bootstrap scope
return create(ctor.prototype); return create(ctor.prototype);
}, },
isObject: function(obj) { /**
return obj !== null && typeof obj === 'object' * Returns true if obj is a plain JavaScript object literal, or a
&& Object.getPrototypeOf(obj) === Object.prototype; * plain Base object, as produced by Base.merge().
*/
isPlainObject: function(obj) {
var proto = obj !== null && typeof obj === 'object'
&& Object.getPrototypeOf(obj);
return proto && (proto === Object.prototype
|| proto === Base.prototype);
}, },
check: function(obj) { check: function(obj) {

View file

@ -38,7 +38,7 @@ var DomElement = new function() {
continue; continue;
} }
// Do we have attributes? // Do we have attributes?
if (Base.isObject(nodes[i])) if (Base.isPlainObject(nodes[i]))
DomElement.set(el, nodes[i++]); DomElement.set(el, nodes[i++]);
// Do we have children? // Do we have children?
if (Array.isArray(nodes[i])) if (Array.isArray(nodes[i]))

View file

@ -200,7 +200,7 @@ this.Base = Base.inject(/** @lends Base# */{
res = []; res = [];
for (var i = 0, l = obj.length; i < l; i++) for (var i = 0, l = obj.length; i < l; i++)
res[i] = Base.serialize(obj[i], true); res[i] = Base.serialize(obj[i], true);
} else if (Base.isObject(obj)) { } else if (Base.isPlainObject(obj)) {
res = {}; res = {};
for (var i in obj) for (var i in obj)
if (obj.hasOwnProperty(i)) if (obj.hasOwnProperty(i))
@ -235,7 +235,7 @@ this.Base = Base.inject(/** @lends Base# */{
res = Base.create(type); res = Base.create(type);
res.initialize.apply(res, args); res.initialize.apply(res, args);
} }
} else if (Base.isObject(obj)) { } else if (Base.isPlainObject(obj)) {
res = {}; res = {};
for (var key in obj) for (var key in obj)
res[key] = Base.deserialize(obj[key]); res[key] = Base.deserialize(obj[key]);

View file

@ -146,7 +146,7 @@ var PaperScript = this.PaperScript = new function() {
if (Array.isArray(value)) { if (Array.isArray(value)) {
for (var i = 0, l = value.length; i < l; i++) for (var i = 0, l = value.length; i < l; i++)
walkAst(value[i]); walkAst(value[i]);
} else if (Base.isObject(value)) { } else if (Base.isPlainObject(value)) {
walkAst(value); walkAst(value);
} }
} }

View file

@ -123,7 +123,7 @@ var Item = this.Item = Base.extend(Callback, /** @lends Item# */{
// one object literal describing all the properties to be set on the created // one object literal describing all the properties to be set on the created
// instance. // instance.
_setProperties: function(props) { _setProperties: function(props) {
if (Base.isObject(props)) if (Base.isPlainObject(props))
return this.set(props); return this.set(props);
}, },