123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- /**
- * @fileoverview This rule warns about the usage of extra whitespaces between attributes
- * @author Armano
- */
- 'use strict'
- const path = require('path')
- /**
- * @param {RuleContext} context
- * @param {Token} node
- */
- const isProperty = (context, node) => {
- const sourceCode = context.getSourceCode()
- return node.type === 'Punctuator' && sourceCode.getText(node) === ':'
- }
- module.exports = {
- meta: {
- type: 'layout',
- docs: {
- description: 'disallow multiple spaces',
- categories: ['vue3-strongly-recommended', 'strongly-recommended'],
- url: 'https://eslint.vuejs.org/rules/no-multi-spaces.html'
- },
- fixable: 'whitespace',
- schema: [
- {
- type: 'object',
- properties: {
- ignoreProperties: {
- type: 'boolean'
- }
- },
- additionalProperties: false
- }
- ],
- messages: {
- multipleSpaces: "Multiple spaces found before '{{displayValue}}'.",
- useLatestParser:
- 'Use the latest vue-eslint-parser. See also https://eslint.vuejs.org/user-guide/#what-is-the-use-the-latest-vue-eslint-parser-error.'
- }
- },
- /**
- * @param {RuleContext} context - The rule context.
- * @returns {RuleListener} AST event handlers.
- */
- create(context) {
- const options = context.options[0] || {}
- const ignoreProperties = options.ignoreProperties === true
- return {
- Program(node) {
- if (context.parserServices.getTemplateBodyTokenStore == null) {
- const filename = context.getFilename()
- if (path.extname(filename) === '.vue') {
- context.report({
- loc: { line: 1, column: 0 },
- messageId: 'useLatestParser'
- })
- }
- return
- }
- if (!node.templateBody) {
- return
- }
- const sourceCode = context.getSourceCode()
- const tokenStore = context.parserServices.getTemplateBodyTokenStore()
- const tokens = tokenStore.getTokens(node.templateBody, {
- includeComments: true
- })
- let prevToken = /** @type {Token} */ (tokens.shift())
- for (const token of tokens) {
- const spaces = token.range[0] - prevToken.range[1]
- const shouldIgnore =
- ignoreProperties &&
- (isProperty(context, token) || isProperty(context, prevToken))
- if (
- spaces > 1 &&
- token.loc.start.line === prevToken.loc.start.line &&
- !shouldIgnore
- ) {
- context.report({
- node: token,
- loc: {
- start: prevToken.loc.end,
- end: token.loc.start
- },
- messageId: 'multipleSpaces',
- fix: (fixer) =>
- fixer.replaceTextRange(
- [prevToken.range[1], token.range[0]],
- ' '
- ),
- data: {
- displayValue: sourceCode.getText(token)
- }
- })
- }
- prevToken = token
- }
- }
- }
- }
- }
|