mirror of
https://github.com/zebrajr/react.git
synced 2025-12-07 12:20:38 +01:00
* use different eslint config for es6 and es5 * remove confusing eslint/baseConfig.js & add more eslint setting for es5, es6 * more clear way to run eslint on es5 & es6 file * seperate ESNext, ES6, ES6 path, and use different lint config * rename eslint config file & update eslint rules * Undo yarn.lock changes * Rename a file * Remove unnecessary exceptions * Refactor a little bit * Refactor and tweak the logic * Minor issues
53 lines
1.3 KiB
JavaScript
53 lines
1.3 KiB
JavaScript
/**
|
|
* Copyright (c) 2013-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
'use strict';
|
|
|
|
module.exports = function(babel, options) {
|
|
const t = babel.types;
|
|
|
|
const DEV_EXPRESSION = t.identifier('__DEV__');
|
|
|
|
const SEEN_SYMBOL = Symbol('expression.seen');
|
|
|
|
return {
|
|
visitor: {
|
|
CallExpression: {
|
|
exit: function(path) {
|
|
const node = path.node;
|
|
|
|
// Ignore if it's already been processed
|
|
if (node[SEEN_SYMBOL]) {
|
|
return;
|
|
}
|
|
|
|
if (path.get('callee').isIdentifier({name: 'warning'})) {
|
|
node[SEEN_SYMBOL] = true;
|
|
|
|
// Turns this code:
|
|
//
|
|
// warning(condition, argument, argument);
|
|
//
|
|
// into this:
|
|
//
|
|
// if (__DEV__) {
|
|
// warning(condition, argument, argument);
|
|
// }
|
|
//
|
|
// The goal is to strip out warning calls entirely in production.
|
|
path.replaceWith(
|
|
t.ifStatement(
|
|
DEV_EXPRESSION,
|
|
t.blockStatement([t.expressionStatement(node)])
|
|
)
|
|
);
|
|
}
|
|
},
|
|
},
|
|
},
|
|
};
|
|
};
|