2015-01-29 17:10:49 -08:00
|
|
|
/**
|
2016-11-20 17:49:21 -08:00
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
2015-01-29 17:10:49 -08:00
|
|
|
*
|
2018-02-16 18:24:55 -08: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-12 19:35:13 -08:00
|
|
|
*
|
2015-01-29 17:10:49 -08:00
|
|
|
* @preventMunge
|
2015-11-12 19:35:13 -08:00
|
|
|
* @flow
|
2015-01-29 17:10:49 -08:00
|
|
|
*/
|
2016-11-20 17:49:21 -08:00
|
|
|
'use strict';
|
2015-01-29 17:10:49 -08:00
|
|
|
|
|
|
|
/**
|
2015-11-12 19:35:13 -08:00
|
|
|
* Checks whether a collection name (e.g. "Map" or "Set") has a native polyfill
|
|
|
|
* that is safe to be used.
|
2015-01-29 17:10:49 -08:00
|
|
|
*/
|
2017-07-24 07:09:37 -07:00
|
|
|
function _shouldActuallyPolyfillES6Collection(collectionName: string): boolean {
|
2015-01-29 17:10:49 -08:00
|
|
|
var Collection = global[collectionName];
|
|
|
|
if (Collection == null) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2015-11-12 19:35:13 -08: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;
|
|
|
|
}
|
|
|
|
|
2015-01-29 17:10:49 -08:00
|
|
|
var proto = Collection.prototype;
|
|
|
|
|
2015-11-12 19:35:13 -08: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.
|
2015-01-29 17:10:49 -08:00
|
|
|
return Collection == null ||
|
|
|
|
typeof Collection !== 'function' ||
|
|
|
|
typeof proto.clear !== 'function' ||
|
|
|
|
new Collection().size !== 0 ||
|
|
|
|
typeof proto.keys !== 'function' ||
|
2015-11-12 19:35:13 -08:00
|
|
|
typeof proto.forEach !== 'function';
|
2015-01-29 17:10:49 -08:00
|
|
|
}
|
|
|
|
|
2017-07-24 07:09:37 -07:00
|
|
|
const cache: { [name: string]: bool } = {};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
function _shouldPolyfillES6Collection(collectionName: string) {
|
|
|
|
let result = cache[collectionName];
|
|
|
|
if (result !== undefined) {
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
result = _shouldActuallyPolyfillES6Collection(collectionName);
|
|
|
|
cache[collectionName] = result;
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = _shouldPolyfillES6Collection;
|