refactor start
This commit is contained in:
parent
bd49791e06
commit
e46d25f0b7
16699 changed files with 2 additions and 1484887 deletions
61
home/ags/node_modules/eslint-plugin-promise/rules/prefer-await-to-then.js
generated
vendored
61
home/ags/node_modules/eslint-plugin-promise/rules/prefer-await-to-then.js
generated
vendored
|
|
@ -1,61 +0,0 @@
|
|||
/**
|
||||
* Rule: prefer-await-to-then
|
||||
* Discourage using then()/catch()/finally() and instead use async/await.
|
||||
*/
|
||||
|
||||
'use strict'
|
||||
|
||||
const { getAncestors, getScope } = require('./lib/eslint-compat')
|
||||
const getDocsUrl = require('./lib/get-docs-url')
|
||||
|
||||
module.exports = {
|
||||
meta: {
|
||||
type: 'suggestion',
|
||||
docs: {
|
||||
description:
|
||||
'Prefer `await` to `then()`/`catch()`/`finally()` for reading Promise values.',
|
||||
url: getDocsUrl('prefer-await-to-then'),
|
||||
},
|
||||
schema: [],
|
||||
},
|
||||
create(context) {
|
||||
/** Returns true if node is inside yield or await expression. */
|
||||
function isInsideYieldOrAwait(node) {
|
||||
return getAncestors(context, node).some((parent) => {
|
||||
return (
|
||||
parent.type === 'AwaitExpression' || parent.type === 'YieldExpression'
|
||||
)
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns true if node is created at the top-level scope.
|
||||
* Await statements are not allowed at the top level,
|
||||
* only within function declarations.
|
||||
*/
|
||||
function isTopLevelScoped(node) {
|
||||
return getScope(context, node).block.type === 'Program'
|
||||
}
|
||||
|
||||
return {
|
||||
'CallExpression > MemberExpression.callee'(node) {
|
||||
if (isTopLevelScoped(node) || isInsideYieldOrAwait(node)) {
|
||||
return
|
||||
}
|
||||
|
||||
// if you're a then/catch/finally expression then you're probably a promise
|
||||
if (
|
||||
node.property &&
|
||||
(node.property.name === 'then' ||
|
||||
node.property.name === 'catch' ||
|
||||
node.property.name === 'finally')
|
||||
) {
|
||||
context.report({
|
||||
node: node.property,
|
||||
message: 'Prefer await to then()/catch()/finally().',
|
||||
})
|
||||
}
|
||||
},
|
||||
}
|
||||
},
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue