Summary:
Quick notes:
- This looks worse than it is. It adds mandatory parentheses to single argument lambdas. Lots of outrage on Twitter about it, personally I'm {emoji:1f937_200d_2642} about it.
- Space before function, e.g. `a = function ()` is now enforced. I like this because both were fine before.
- I added `eslint-config-prettier` to the config because otherwise a ton of rules conflict with eslint itself.
Close https://github.com/facebook/flipper/pull/915
Reviewed By: jknoxville
Differential Revision: D20594929
fbshipit-source-id: ca1c65376b90e009550dd6d1f4e0831d32cbff03
54 lines
1.4 KiB
JavaScript
54 lines
1.4 KiB
JavaScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
*/
|
|
|
|
module.exports = function (babel) {
|
|
const t = babel.types;
|
|
|
|
return {
|
|
name: 'infinity-import-react',
|
|
visitor: {
|
|
Program: {
|
|
exit(path, state) {
|
|
if (state.get('NEEDS_REACT')) {
|
|
path.unshiftContainer('body', [
|
|
t.variableDeclaration('var', [
|
|
t.variableDeclarator(
|
|
t.identifier('React'),
|
|
t.callExpression(t.identifier('require'), [
|
|
t.stringLiteral('react'),
|
|
]),
|
|
),
|
|
]),
|
|
]);
|
|
}
|
|
},
|
|
},
|
|
|
|
ReferencedIdentifier(path, state) {
|
|
// mark react as needing to be imported
|
|
if (path.node.name === 'React' && !path.scope.getBinding('React')) {
|
|
state.set('NEEDS_REACT', true);
|
|
}
|
|
|
|
// replace Buffer with require('buffer')
|
|
if (path.node.name === 'Buffer' && !path.scope.getBinding('Buffer')) {
|
|
path.replaceWith(
|
|
t.memberExpression(
|
|
t.callExpression(t.identifier('require'), [
|
|
t.stringLiteral('buffer'),
|
|
]),
|
|
t.identifier('Buffer'),
|
|
),
|
|
);
|
|
}
|
|
},
|
|
},
|
|
};
|
|
};
|