123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- 'use strict';
- const isNewExpressionWithParentheses = require('../utils/is-new-expression-with-parentheses.js');
- const {isParenthesized} = require('../utils/parentheses.js');
- function * fixReturnOrThrowStatementArgument(newExpression, sourceCode, fixer) {
- const {parent} = newExpression;
- if (
- (parent.type !== 'ReturnStatement' && parent.type !== 'ThrowStatement')
- || parent.argument !== newExpression
- || isParenthesized(newExpression, sourceCode)
- ) {
- return;
- }
- const returnStatement = parent;
- const returnToken = sourceCode.getFirstToken(returnStatement);
- const classNode = newExpression.callee;
- // Ideally, we should use first parenthesis of the `callee`, and should check spaces after the `new` token
- // But adding extra parentheses is harmless, no need to be too complicated
- if (returnToken.loc.start.line === classNode.loc.start.line) {
- return;
- }
- yield fixer.insertTextAfter(returnToken, ' (');
- yield fixer.insertTextAfter(newExpression, ')');
- }
- function * switchNewExpressionToCallExpression(node, sourceCode, fixer) {
- const [start] = node.range;
- let end = start + 3; // `3` = length of `new`
- const textAfter = sourceCode.text.slice(end);
- const [leadingSpaces] = textAfter.match(/^\s*/);
- end += leadingSpaces.length;
- yield fixer.removeRange([start, end]);
- if (!isNewExpressionWithParentheses(node, sourceCode)) {
- yield fixer.insertTextAfter(node, '()');
- }
- /*
- Remove `new` from this code will makes the function return `undefined`
- ```js
- () => {
- return new // comment
- Foo()
- }
- ```
- */
- yield * fixReturnOrThrowStatementArgument(node, sourceCode, fixer);
- }
- module.exports = switchNewExpressionToCallExpression;
|