| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 | /** * @fileoverview Rule to disallow async functions which have no `await` expression. * @author Toru Nagashima */"use strict";//------------------------------------------------------------------------------// Requirements//------------------------------------------------------------------------------const astUtils = require("./utils/ast-utils");//------------------------------------------------------------------------------// Helpers//------------------------------------------------------------------------------/** * Capitalize the 1st letter of the given text. * @param {string} text The text to capitalize. * @returns {string} The text that the 1st letter was capitalized. */function capitalizeFirstLetter(text) {    return text[0].toUpperCase() + text.slice(1);}//------------------------------------------------------------------------------// Rule Definition//------------------------------------------------------------------------------module.exports = {    meta: {        type: "suggestion",        docs: {            description: "disallow async functions which have no `await` expression",            category: "Best Practices",            recommended: false,            url: "https://eslint.org/docs/rules/require-await"        },        schema: [],        messages: {            missingAwait: "{{name}} has no 'await' expression."        }    },    create(context) {        const sourceCode = context.getSourceCode();        let scopeInfo = null;        /**         * Push the scope info object to the stack.         * @returns {void}         */        function enterFunction() {            scopeInfo = {                upper: scopeInfo,                hasAwait: false            };        }        /**         * Pop the top scope info object from the stack.         * Also, it reports the function if needed.         * @param {ASTNode} node The node to report.         * @returns {void}         */        function exitFunction(node) {            if (!node.generator && node.async && !scopeInfo.hasAwait && !astUtils.isEmptyFunction(node)) {                context.report({                    node,                    loc: astUtils.getFunctionHeadLoc(node, sourceCode),                    messageId: "missingAwait",                    data: {                        name: capitalizeFirstLetter(                            astUtils.getFunctionNameWithKind(node)                        )                    }                });            }            scopeInfo = scopeInfo.upper;        }        return {            FunctionDeclaration: enterFunction,            FunctionExpression: enterFunction,            ArrowFunctionExpression: enterFunction,            "FunctionDeclaration:exit": exitFunction,            "FunctionExpression:exit": exitFunction,            "ArrowFunctionExpression:exit": exitFunction,            AwaitExpression() {                if (!scopeInfo) {                    return;                }                scopeInfo.hasAwait = true;            },            ForOfStatement(node) {                if (!scopeInfo) {                    return;                }                if (node.await) {                    scopeInfo.hasAwait = true;                }            }        };    }};
 |