2015-01-30 01:10:49 +00:00
|
|
|
/**
|
2016-11-21 01:49:21 +00:00
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
2015-01-30 01:10:49 +00:00
|
|
|
*
|
2018-02-17 02:24:55 +00:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2015-11-13 03:35:13 +00:00
|
|
|
*
|
2018-05-11 02:06:46 +00:00
|
|
|
* @format
|
2015-01-30 01:10:49 +00:00
|
|
|
* @preventMunge
|
2018-06-20 07:35:29 +00:00
|
|
|
* @flow strict
|
2015-01-30 01:10:49 +00:00
|
|
|
*/
|
2018-05-11 02:06:46 +00:00
|
|
|
|
2016-11-21 01:49:21 +00:00
|
|
|
'use strict';
|
2015-01-30 01:10:49 +00:00
|
|
|
|
|
|
|
/**
|
2015-11-13 03:35:13 +00:00
|
|
|
* Checks whether a collection name (e.g. "Map" or "Set") has a native polyfill
|
|
|
|
* that is safe to be used.
|
2015-01-30 01:10:49 +00:00
|
|
|
*/
|
2017-07-24 14:09:37 +00:00
|
|
|
function _shouldActuallyPolyfillES6Collection(collectionName: string): boolean {
|
2018-05-10 22:44:52 +00:00
|
|
|
const Collection = global[collectionName];
|
2015-01-30 01:10:49 +00:00
|
|
|
if (Collection == null) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2015-11-13 03:35:13 +00:00
|
|
|
// The iterator protocol depends on `Symbol.iterator`. If a collection is
|
|
|
|
// implemented, but `Symbol` is not, it's going to break iteration because
|
|
|
|
// we'll be using custom "@@iterator" instead, which is not implemented on
|
|
|
|
// native collections.
|
|
|
|
if (typeof global.Symbol !== 'function') {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2018-05-10 22:44:52 +00:00
|
|
|
const proto = Collection.prototype;
|
2015-01-30 01:10:49 +00:00
|
|
|
|
2015-11-13 03:35:13 +00:00
|
|
|
// These checks are adapted from es6-shim: https://fburl.com/34437854
|
|
|
|
// NOTE: `isCallableWithoutNew` and `!supportsSubclassing` are not checked
|
|
|
|
// because they make debugging with "break on exceptions" difficult.
|
2018-05-11 02:06:46 +00:00
|
|
|
return (
|
|
|
|
Collection == null ||
|
2015-01-30 01:10:49 +00:00
|
|
|
typeof Collection !== 'function' ||
|
|
|
|
typeof proto.clear !== 'function' ||
|
|
|
|
new Collection().size !== 0 ||
|
|
|
|
typeof proto.keys !== 'function' ||
|
2018-05-11 02:06:46 +00:00
|
|
|
typeof proto.forEach !== 'function'
|
|
|
|
);
|
2015-01-30 01:10:49 +00:00
|
|
|
}
|
|
|
|
|
2018-05-11 02:06:46 +00:00
|
|
|
const cache: {[name: string]: boolean} = {};
|
2017-07-24 14:09:37 +00:00
|
|
|
|
2018-05-11 02:06:46 +00:00
|
|
|
/**
|
|
|
|
* Checks whether a collection name (e.g. "Map" or "Set") has a native polyfill
|
|
|
|
* that is safe to be used and caches this result.
|
|
|
|
* Make sure to make a first call to this function before a corresponding
|
|
|
|
* property on global was overriden in any way.
|
|
|
|
*/
|
2017-07-24 14:09:37 +00:00
|
|
|
function _shouldPolyfillES6Collection(collectionName: string) {
|
2018-05-11 02:06:46 +00:00
|
|
|
let result = cache[collectionName];
|
|
|
|
if (result !== undefined) {
|
2017-07-24 14:09:37 +00:00
|
|
|
return result;
|
2018-05-11 02:06:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
result = _shouldActuallyPolyfillES6Collection(collectionName);
|
|
|
|
cache[collectionName] = result;
|
|
|
|
return result;
|
2017-07-24 14:09:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = _shouldPolyfillES6Collection;
|