2016-02-08 15:00:42 -08:00
|
|
|
/**
|
|
|
|
* Copyright 2004-present Facebook. All Rights Reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/*eslint consistent-return: 0*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Transforms function properties of the `Symbol` into
|
|
|
|
* the presence check, and fallback string "@@<name>".
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
*
|
|
|
|
* Symbol.iterator;
|
|
|
|
*
|
|
|
|
* Transformed to:
|
|
|
|
*
|
|
|
|
* typeof Symbol.iterator === 'function' ? Symbol.iterator : '@@iterator';
|
|
|
|
*/
|
|
|
|
module.exports = function symbolMember(babel) {
|
|
|
|
const t = babel.types;
|
|
|
|
|
|
|
|
return {
|
|
|
|
visitor: {
|
|
|
|
MemberExpression(path) {
|
2016-11-23 09:27:36 -08:00
|
|
|
if (!isAppropriateMember(path)) {
|
2016-02-08 15:00:42 -08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-11-23 09:27:36 -08:00
|
|
|
let node = path.node;
|
|
|
|
|
2016-02-08 15:00:42 -08:00
|
|
|
path.replaceWith(
|
|
|
|
t.conditionalExpression(
|
|
|
|
t.binaryExpression(
|
|
|
|
'===',
|
2017-07-12 19:22:43 -07:00
|
|
|
t.unaryExpression(
|
|
|
|
'typeof',
|
|
|
|
t.identifier('Symbol'),
|
|
|
|
true
|
|
|
|
),
|
|
|
|
t.stringLiteral('function')
|
2016-02-08 15:00:42 -08:00
|
|
|
),
|
|
|
|
node,
|
2017-07-12 19:22:43 -07:00
|
|
|
t.stringLiteral(`@@${node.property.name}`)
|
|
|
|
)
|
2016-02-08 15:00:42 -08:00
|
|
|
);
|
|
|
|
|
|
|
|
// We should stop to avoid infinite recursion, since Babel
|
|
|
|
// traverses replaced path, and again would hit our transform.
|
|
|
|
path.stop();
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2016-11-23 09:27:36 -08:00
|
|
|
function isAppropriateMember(path) {
|
|
|
|
let node = path.node;
|
|
|
|
|
2017-07-12 19:22:43 -07:00
|
|
|
return path.parentPath.type !== 'AssignmentExpression' &&
|
2016-11-23 09:27:36 -08:00
|
|
|
node.object.type === 'Identifier' &&
|
2016-02-08 15:00:42 -08:00
|
|
|
node.object.name === 'Symbol' &&
|
2017-07-12 19:22:43 -07:00
|
|
|
node.property.type === 'Identifier';
|
2016-02-08 15:00:42 -08:00
|
|
|
}
|