Skip to content
This repository has been archived by the owner on Jul 30, 2018. It is now read-only.

Commit

Permalink
Adding overwrite flag to has additions, issue #97 (#105)
Browse files Browse the repository at this point in the history
  • Loading branch information
rorticus authored Jul 31, 2017
1 parent a9a7662 commit c43ce8a
Showing 1 changed file with 21 additions and 21 deletions.
42 changes: 21 additions & 21 deletions src/support/has.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,17 +16,17 @@ add('es6-array', () => {
'find',
'copyWithin'
].every((key) => key in global.Array.prototype);
});
}, true);

add('es6-array-fill', () => {
if ('fill' in global.Array.prototype) {
/* Some versions of Safari do not properly implement this */
return (<any> [ 1 ]).fill(9, Number.POSITIVE_INFINITY)[0] === 1;
}
return false;
});
}, true);

add('es7-array', () => 'includes' in global.Array.prototype);
add('es7-array', () => 'includes' in global.Array.prototype, true);

/* Map */
add('es6-map', () => {
Expand All @@ -50,7 +50,7 @@ add('es6-map', () => {
}
}
return false;
});
}, true);

/* Math */
add('es6-math', () => {
Expand All @@ -72,15 +72,15 @@ add('es6-math', () => {
'cbrt',
'hypot'
].every((name) => typeof global.Math[name] === 'function');
});
}, true);

add('es6-math-imul', () => {
if ('imul' in global.Math) {
/* Some versions of Safari on ios do not properly implement this */
return (<any> Math).imul(0xffffffff, 5) === -5;
}
return false;
});
}, true);

/* Object */
add('es6-object', () => {
Expand All @@ -90,21 +90,21 @@ add('es6-object', () => {
'getOwnPropertySymbols',
'setPrototypeOf'
].every((name) => typeof global.Object[name] === 'function');
});
}, true);

add('es2017-object', () => {
return [
'values',
'entries',
'getOwnPropertyDescriptors'
].every((name) => typeof global.Object[name] === 'function');
});
}, true);

/* Observable */
add('es-observable', () => typeof global.Observable !== 'undefined');
add('es-observable', () => typeof global.Observable !== 'undefined', true);

/* Promise */
add('es6-promise', () => typeof global.Promise !== 'undefined' && has('es6-symbol'));
add('es6-promise', () => typeof global.Promise !== 'undefined' && has('es6-symbol'), true);

/* Set */
add('es6-set', () => {
Expand All @@ -114,7 +114,7 @@ add('es6-set', () => {
return set.has(1) && 'keys' in set && typeof set.keys === 'function' && has('es6-symbol');
}
return false;
});
}, true);

/* String */
add('es6-string', () => {
Expand All @@ -128,7 +128,7 @@ add('es6-string', () => {
'endsWith',
'includes'
].every((key) => typeof global.String.prototype[key] === 'function');
});
}, true);

add('es6-string-raw', () => {
function getCallSite(callSite: TemplateStringsArray, ...substitutions: any[]) {
Expand All @@ -146,17 +146,17 @@ add('es6-string-raw', () => {
}

return false;
});
}, true);

add('es2017-string', () => {
return [
'padStart',
'padEnd'
].every((key) => typeof global.String.prototype[key] === 'function');
});
}, true);

/* Symbol */
add('es6-symbol', () => typeof global.Symbol !== 'undefined' && typeof Symbol() === 'symbol');
add('es6-symbol', () => typeof global.Symbol !== 'undefined' && typeof Symbol() === 'symbol', true);

/* WeakMap */
add('es6-weakmap', () => {
Expand All @@ -169,13 +169,13 @@ add('es6-weakmap', () => {
return map.get(key1) === 1 && map.set(key2, 2) === map && has('es6-symbol');
}
return false;
});
}, true);

/* Miscellaneous features */
add('microtasks', () => has('es6-promise') || has('host-node') || has('dom-mutationobserver'));
add('postmessage', () => typeof global.postMessage === 'function');
add('raf', () => typeof global.requestAnimationFrame === 'function');
add('setimmediate', () => typeof global.setImmediate !== 'undefined');
add('microtasks', () => has('es6-promise') || has('host-node') || has('dom-mutationobserver'), true);
add('postmessage', () => typeof global.postMessage === 'function', true);
add('raf', () => typeof global.requestAnimationFrame === 'function', true);
add('setimmediate', () => typeof global.setImmediate !== 'undefined', true);

/* DOM Features */

Expand All @@ -196,4 +196,4 @@ add('dom-mutationobserver', () => {
return Boolean(observer.takeRecords().length);
}
return false;
});
}, true);

0 comments on commit c43ce8a

Please sign in to comment.