mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Remove Base.has() in favor of now supported Object#hasOwnProperty.
This commit is contained in:
parent
0eaabd667c
commit
9ec5ad29ef
1 changed files with 3 additions and 14 deletions
17
lib/bootstrap.js
vendored
17
lib/bootstrap.js
vendored
|
@ -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);
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in a new issue