Remove Base.has() in favor of now supported Object#hasOwnProperty.

This commit is contained in:
Jürg Lehni 2012-11-04 08:31:14 -08:00
parent 0eaabd667c
commit 9ec5ad29ef

17
lib/bootstrap.js vendored
View file

@ -14,13 +14,6 @@
var Base = new function() { // Bootstrap scope var Base = new function() { // Bootstrap scope
var hidden = /^(statics|generics|preserve|enumerable|prototype|toString|valueOf)$/, var hidden = /^(statics|generics|preserve|enumerable|prototype|toString|valueOf)$/,
proto = Object.prototype, proto = Object.prototype,
/**
* Private function that checks if an object contains a given property.
* Naming it 'has' causes problems on Opera when defining
* Object.prototype.has, as the local version then seems to be overriden
* by that. Giving it a idfferent name fixes it.
*/
has = proto.hasOwnProperty,
toString = proto.toString, toString = proto.toString,
proto = Array.prototype, proto = Array.prototype,
isArray = Array.isArray = Array.isArray || function(obj) { isArray = Array.isArray = Array.isArray || function(obj) {
@ -80,7 +73,7 @@ var Base = new function() { // Bootstrap scope
return get return get
? { get: get, set: obj.__lookupSetter__(name), enumerable: true, ? { get: get, set: obj.__lookupSetter__(name), enumerable: true,
configurable: true } configurable: true }
: has.call(obj, name) : obj.hasOwnProperty(name)
? { value: obj[name], enumerable: true, configurable: true, ? { value: obj[name], enumerable: true, configurable: true,
writable: true } writable: true }
: null; : null;
@ -113,7 +106,7 @@ var Base = new function() { // Bootstrap scope
// the property exists (name in dest) and store result in prev // the property exists (name in dest) and store result in prev
prev = preserve || func prev = preserve || func
? (val && val.get ? name in dest : dest[name]) : null; ? (val && val.get ? name in dest : dest[name]) : null;
if ((dontCheck || val !== undefined && has.call(src, name)) if ((dontCheck || val !== undefined && src.hasOwnProperty(name))
&& (!preserve || !prev)) { && (!preserve || !prev)) {
if (func) { if (func) {
if (prev && /\bthis\.base\b/.test(val)) { if (prev && /\bthis\.base\b/.test(val)) {
@ -181,7 +174,7 @@ var Base = new function() { // Bootstrap scope
if (src) { if (src) {
beans = []; beans = [];
for (var name in src) for (var name in src)
if (has.call(src, name) && !hidden.test(name)) if (src.hasOwnProperty(name) && !hidden.test(name))
field(name, null, true, generics); field(name, null, true, generics);
// IE (and some other browsers?) never enumerate these, even if // IE (and some other browsers?) never enumerate these, even if
// they are simply set on an object. Force their creation. Do not // they are simply set on an object. Force their creation. Do not
@ -346,10 +339,6 @@ var Base = new function() { // Bootstrap scope
describe: describe, describe: describe,
iterator: iterator, iterator: iterator,
has: function(obj, name) {
return has.call(obj, name);
},
check: function(obj) { check: function(obj) {
return !!(obj || obj === 0); return !!(obj || obj === 0);
}, },