116 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
/**
 | 
						|
 * @fileoverview Enforces or disallows inline comments.
 | 
						|
 * @author Greg Cochard
 | 
						|
 */
 | 
						|
"use strict";
 | 
						|
 | 
						|
const astUtils = require("./utils/ast-utils");
 | 
						|
 | 
						|
//------------------------------------------------------------------------------
 | 
						|
// Rule Definition
 | 
						|
//------------------------------------------------------------------------------
 | 
						|
 | 
						|
/** @type {import('../types').Rule.RuleModule} */
 | 
						|
module.exports = {
 | 
						|
	meta: {
 | 
						|
		type: "suggestion",
 | 
						|
 | 
						|
		defaultOptions: [{}],
 | 
						|
 | 
						|
		docs: {
 | 
						|
			description: "Disallow inline comments after code",
 | 
						|
			recommended: false,
 | 
						|
			frozen: true,
 | 
						|
			url: "https://eslint.org/docs/latest/rules/no-inline-comments",
 | 
						|
		},
 | 
						|
 | 
						|
		schema: [
 | 
						|
			{
 | 
						|
				type: "object",
 | 
						|
				properties: {
 | 
						|
					ignorePattern: {
 | 
						|
						type: "string",
 | 
						|
					},
 | 
						|
				},
 | 
						|
				additionalProperties: false,
 | 
						|
			},
 | 
						|
		],
 | 
						|
 | 
						|
		messages: {
 | 
						|
			unexpectedInlineComment: "Unexpected comment inline with code.",
 | 
						|
		},
 | 
						|
	},
 | 
						|
 | 
						|
	create(context) {
 | 
						|
		const sourceCode = context.sourceCode;
 | 
						|
		const [{ ignorePattern }] = context.options;
 | 
						|
		const customIgnoreRegExp =
 | 
						|
			ignorePattern && new RegExp(ignorePattern, "u");
 | 
						|
 | 
						|
		/**
 | 
						|
		 * Will check that comments are not on lines starting with or ending with code
 | 
						|
		 * @param {ASTNode} node The comment node to check
 | 
						|
		 * @private
 | 
						|
		 * @returns {void}
 | 
						|
		 */
 | 
						|
		function testCodeAroundComment(node) {
 | 
						|
			const startLine = String(sourceCode.lines[node.loc.start.line - 1]),
 | 
						|
				endLine = String(sourceCode.lines[node.loc.end.line - 1]),
 | 
						|
				preamble = startLine.slice(0, node.loc.start.column).trim(),
 | 
						|
				postamble = endLine.slice(node.loc.end.column).trim(),
 | 
						|
				isPreambleEmpty = !preamble,
 | 
						|
				isPostambleEmpty = !postamble;
 | 
						|
 | 
						|
			// Nothing on both sides
 | 
						|
			if (isPreambleEmpty && isPostambleEmpty) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
 | 
						|
			// Matches the ignore pattern
 | 
						|
			if (customIgnoreRegExp && customIgnoreRegExp.test(node.value)) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
 | 
						|
			// JSX Exception
 | 
						|
			if (
 | 
						|
				(isPreambleEmpty || preamble === "{") &&
 | 
						|
				(isPostambleEmpty || postamble === "}")
 | 
						|
			) {
 | 
						|
				const enclosingNode = sourceCode.getNodeByRangeIndex(
 | 
						|
					node.range[0],
 | 
						|
				);
 | 
						|
 | 
						|
				if (
 | 
						|
					enclosingNode &&
 | 
						|
					enclosingNode.type === "JSXEmptyExpression"
 | 
						|
				) {
 | 
						|
					return;
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
			// Don't report ESLint directive comments
 | 
						|
			if (astUtils.isDirectiveComment(node)) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
 | 
						|
			context.report({
 | 
						|
				node,
 | 
						|
				messageId: "unexpectedInlineComment",
 | 
						|
			});
 | 
						|
		}
 | 
						|
 | 
						|
		//--------------------------------------------------------------------------
 | 
						|
		// Public
 | 
						|
		//--------------------------------------------------------------------------
 | 
						|
 | 
						|
		return {
 | 
						|
			Program() {
 | 
						|
				sourceCode
 | 
						|
					.getAllComments()
 | 
						|
					.filter(token => token.type !== "Shebang")
 | 
						|
					.forEach(testCodeAroundComment);
 | 
						|
			},
 | 
						|
		};
 | 
						|
	},
 | 
						|
};
 |