github-pages-deploy-action/node_modules/eslint/lib/rules/computed-property-spacing.js

205 lines
7.3 KiB
JavaScript
Raw Permalink Normal View History

2020-03-07 11:45:40 +08:00
/**
* @fileoverview Disallows or enforces spaces inside computed properties.
* @author Jamund Ferguson
*/
"use strict";
2020-03-31 20:40:00 +08:00
const astUtils = require("./utils/ast-utils");
2020-03-07 11:45:40 +08:00
//------------------------------------------------------------------------------
// Rule Definition
//------------------------------------------------------------------------------
module.exports = {
meta: {
type: "layout",
docs: {
description: "enforce consistent spacing inside computed property brackets",
category: "Stylistic Issues",
recommended: false,
url: "https://eslint.org/docs/rules/computed-property-spacing"
},
fixable: "whitespace",
schema: [
{
enum: ["always", "never"]
2020-03-31 20:40:00 +08:00
},
{
type: "object",
properties: {
enforceForClassMembers: {
type: "boolean",
2020-05-15 05:33:08 +08:00
default: true
2020-03-31 20:40:00 +08:00
}
},
additionalProperties: false
2020-03-07 11:45:40 +08:00
}
],
messages: {
unexpectedSpaceBefore: "There should be no space before '{{tokenValue}}'.",
unexpectedSpaceAfter: "There should be no space after '{{tokenValue}}'.",
missingSpaceBefore: "A space is required before '{{tokenValue}}'.",
missingSpaceAfter: "A space is required after '{{tokenValue}}'."
}
},
create(context) {
const sourceCode = context.getSourceCode();
const propertyNameMustBeSpaced = context.options[0] === "always"; // default is "never"
2020-05-15 05:33:08 +08:00
const enforceForClassMembers = !context.options[1] || context.options[1].enforceForClassMembers;
2020-03-07 11:45:40 +08:00
//--------------------------------------------------------------------------
// Helpers
//--------------------------------------------------------------------------
/**
* Reports that there shouldn't be a space after the first token
2020-03-31 20:40:00 +08:00
* @param {ASTNode} node The node to report in the event of an error.
* @param {Token} token The token to use for the report.
* @param {Token} tokenAfter The token after `token`.
2020-03-07 11:45:40 +08:00
* @returns {void}
*/
function reportNoBeginningSpace(node, token, tokenAfter) {
context.report({
node,
2020-05-15 05:33:08 +08:00
loc: { start: token.loc.end, end: tokenAfter.loc.start },
2020-03-07 11:45:40 +08:00
messageId: "unexpectedSpaceAfter",
data: {
tokenValue: token.value
},
fix(fixer) {
return fixer.removeRange([token.range[1], tokenAfter.range[0]]);
}
});
}
/**
* Reports that there shouldn't be a space before the last token
2020-03-31 20:40:00 +08:00
* @param {ASTNode} node The node to report in the event of an error.
* @param {Token} token The token to use for the report.
* @param {Token} tokenBefore The token before `token`.
2020-03-07 11:45:40 +08:00
* @returns {void}
*/
function reportNoEndingSpace(node, token, tokenBefore) {
context.report({
node,
2020-05-15 05:33:08 +08:00
loc: { start: tokenBefore.loc.end, end: token.loc.start },
2020-03-07 11:45:40 +08:00
messageId: "unexpectedSpaceBefore",
data: {
tokenValue: token.value
},
fix(fixer) {
return fixer.removeRange([tokenBefore.range[1], token.range[0]]);
}
});
}
/**
* Reports that there should be a space after the first token
2020-03-31 20:40:00 +08:00
* @param {ASTNode} node The node to report in the event of an error.
* @param {Token} token The token to use for the report.
2020-03-07 11:45:40 +08:00
* @returns {void}
*/
function reportRequiredBeginningSpace(node, token) {
context.report({
node,
2020-05-15 05:33:08 +08:00
loc: token.loc,
2020-03-07 11:45:40 +08:00
messageId: "missingSpaceAfter",
data: {
tokenValue: token.value
},
fix(fixer) {
return fixer.insertTextAfter(token, " ");
}
});
}
/**
* Reports that there should be a space before the last token
2020-03-31 20:40:00 +08:00
* @param {ASTNode} node The node to report in the event of an error.
* @param {Token} token The token to use for the report.
2020-03-07 11:45:40 +08:00
* @returns {void}
*/
function reportRequiredEndingSpace(node, token) {
context.report({
node,
2020-05-15 05:33:08 +08:00
loc: token.loc,
2020-03-07 11:45:40 +08:00
messageId: "missingSpaceBefore",
data: {
tokenValue: token.value
},
fix(fixer) {
return fixer.insertTextBefore(token, " ");
}
});
}
/**
* Returns a function that checks the spacing of a node on the property name
* that was passed in.
* @param {string} propertyName The property on the node to check for spacing
* @returns {Function} A function that will check spacing on a node
*/
function checkSpacing(propertyName) {
return function(node) {
if (!node.computed) {
return;
}
const property = node[propertyName];
2020-03-31 20:40:00 +08:00
const before = sourceCode.getTokenBefore(property, astUtils.isOpeningBracketToken),
first = sourceCode.getTokenAfter(before, { includeComments: true }),
after = sourceCode.getTokenAfter(property, astUtils.isClosingBracketToken),
last = sourceCode.getTokenBefore(after, { includeComments: true });
2020-03-07 11:45:40 +08:00
if (astUtils.isTokenOnSameLine(before, first)) {
if (propertyNameMustBeSpaced) {
if (!sourceCode.isSpaceBetweenTokens(before, first) && astUtils.isTokenOnSameLine(before, first)) {
reportRequiredBeginningSpace(node, before);
}
} else {
if (sourceCode.isSpaceBetweenTokens(before, first)) {
reportNoBeginningSpace(node, before, first);
}
}
}
if (astUtils.isTokenOnSameLine(last, after)) {
if (propertyNameMustBeSpaced) {
if (!sourceCode.isSpaceBetweenTokens(last, after) && astUtils.isTokenOnSameLine(last, after)) {
reportRequiredEndingSpace(node, after);
}
} else {
if (sourceCode.isSpaceBetweenTokens(last, after)) {
reportNoEndingSpace(node, after, last);
}
}
}
};
}
//--------------------------------------------------------------------------
// Public
//--------------------------------------------------------------------------
2020-03-31 20:40:00 +08:00
const listeners = {
2020-03-07 11:45:40 +08:00
Property: checkSpacing("key"),
MemberExpression: checkSpacing("property")
};
2020-03-31 20:40:00 +08:00
if (enforceForClassMembers) {
listeners.MethodDefinition = checkSpacing("key");
}
return listeners;
2020-03-07 11:45:40 +08:00
}
};