This commit is contained in:
Lilith 2024-06-13 00:09:21 +02:00
parent eddf7cecb8
commit aea798d119
Signed by: lilith
GPG key ID: 8712A0F317C37175
16631 changed files with 1480363 additions and 257 deletions

View file

@ -0,0 +1,62 @@
/**
* @author Yosuke Ota <https://github.com/ota-meshi>
* See LICENSE file in root directory for full license.
*/
"use strict"
const { getSourceCode } = require("eslint-compat-utils")
module.exports = {
meta: {
docs: {
description: "disallow optional chaining.",
category: "ES2020",
recommended: false,
url: "http://eslint-community.github.io/eslint-plugin-es-x/rules/no-optional-chaining.html",
},
fixable: null,
messages: {
forbidden: "ES2020 optional chaining is forbidden.",
},
schema: [],
type: "problem",
},
create(context) {
const sourceCode = getSourceCode(context)
/**
* Checks if the given token is a `?.` token or not.
* @param {Token} token The token to check.
* @returns {boolean} `true` if the token is a `?.` token.
*/
function isQuestionDotToken(token) {
return (
token.value === "?." &&
(token.type === "Punctuator" || // espree has been parsed well.
// espree@7.1.0 doesn't parse "?." tokens well. Therefore, get the string from the source code and check it.
sourceCode.getText(token) === "?.")
)
}
return {
"CallExpression[optional=true]"(node) {
context.report({
node: sourceCode.getTokenAfter(
node.callee,
isQuestionDotToken,
),
messageId: "forbidden",
})
},
"MemberExpression[optional=true]"(node) {
context.report({
node: sourceCode.getTokenAfter(
node.object,
isQuestionDotToken,
),
messageId: "forbidden",
})
},
}
},
}