@d3lm/lint-preset 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/rules/block-scoped-case.ts","../src/rules/comment-preceding-blank-line.ts","../src/rules/comment-syntax.ts","../src/rules/newline-around-multiline.ts","../src/rules/no-implicit-object-return.ts","../src/rules/index.ts"],"sourcesContent":["import type { Rule } from 'eslint';\n\nconst leadingWhitespace = (line: string) => /^[ \\t]*/.exec(line)?.[0].length ?? 0;\n\nconst rule: Rule.RuleModule = {\n meta: {\n type: 'suggestion',\n docs: {\n description: 'Require case clauses to use block scope (braces).',\n },\n fixable: 'code',\n schema: [],\n messages: {\n missingBlock: 'Case clause should be wrapped in a block (braces).',\n },\n },\n create(context) {\n const sourceCode = context.sourceCode;\n\n return {\n SwitchCase(node) {\n const { consequent } = node;\n\n if (consequent.length === 0) {\n return;\n }\n\n // already wrapped in a single BlockStatement\n if (consequent.length === 1 && consequent[0].type === 'BlockStatement') {\n return;\n }\n\n context.report({\n node,\n messageId: 'missingBlock',\n fix(fixer) {\n const caseKeyword = sourceCode.getFirstToken(node);\n\n if (!caseKeyword) {\n return [];\n }\n\n const colonToken = sourceCode.getTokenAfter(\n node.test ? (node.test as Rule.Node) : caseKeyword,\n (token) => token.value === ':',\n );\n\n if (!colonToken) {\n return [];\n }\n\n const lastConsequent = consequent.at(-1);\n const lastToken = sourceCode.getLastToken(lastConsequent as Rule.Node);\n\n if (!lastToken) {\n return [];\n }\n\n const caseIndent = ' '.repeat(caseKeyword.loc.start.column);\n const bodyIndent = caseIndent + ' ';\n\n const text = sourceCode.getText();\n const bodyText = text.slice(colonToken.range[1], lastToken.range[1]);\n\n const lines = bodyText.split('\\n');\n\n /**\n * Lines after the colon line keep their relative nesting; we only shift\n * them so the shallowest one lands at the desired body indent.\n */\n const restLines = lines.slice(1);\n const restIndents = restLines.filter((line) => line.trim() !== '').map((line) => leadingWhitespace(line));\n const indentDelta = restIndents.length > 0 ? bodyIndent.length - Math.min(...restIndents) : 0;\n\n const bodyLines: string[] = [];\n\n // code sharing the colon line (e.g. `case 1: foo()`) must be preserved\n const firstLine = lines[0].trim();\n\n if (firstLine) {\n bodyLines.push(bodyIndent + firstLine);\n }\n\n for (const line of restLines) {\n if (line.trim() === '') {\n bodyLines.push('');\n continue;\n }\n\n const lead = leadingWhitespace(line);\n const newIndent = Math.max(0, lead + indentDelta);\n\n bodyLines.push(' '.repeat(newIndent) + line.slice(lead));\n }\n\n while (bodyLines.length > 0 && bodyLines[0] === '') {\n bodyLines.shift();\n }\n\n while (bodyLines.length > 0 && bodyLines.at(-1) === '') {\n bodyLines.pop();\n }\n\n const result = ` {\\n${bodyLines.join('\\n')}\\n${caseIndent}}`;\n\n return fixer.replaceTextRange([colonToken.range[1], lastToken.range[1]], result);\n },\n });\n },\n };\n },\n};\n\nexport default rule;\n","import type { Rule } from 'eslint';\n\ninterface Comment {\n type: string;\n value: string;\n range?: [number, number];\n loc?: Rule.Node['loc'];\n}\n\ninterface RuleOptions {\n allowInObjects?: boolean;\n allowInArrays?: boolean;\n allowInInterfaces?: boolean;\n}\n\nconst rule: Rule.RuleModule = {\n meta: {\n type: 'layout',\n docs: {\n description:\n 'Require a blank line before comments, with an exception for comments inside chained member-call expressions.',\n },\n fixable: 'whitespace',\n schema: [\n {\n type: 'object',\n properties: {\n allowInObjects: {\n type: 'boolean',\n },\n allowInArrays: {\n type: 'boolean',\n },\n allowInInterfaces: {\n type: 'boolean',\n },\n },\n additionalProperties: false,\n },\n ],\n messages: {\n missingBlankLine: 'Expected blank line before comment.',\n },\n },\n create(context) {\n const sourceCode = context.sourceCode;\n\n const options = (context.options[0] as RuleOptions | undefined) ?? {};\n\n const allowInObjects = options.allowInObjects ?? false;\n const allowInArrays = options.allowInArrays ?? false;\n const allowInInterfaces = options.allowInInterfaces ?? false;\n\n function isChainedCallContext(comment: Comment): boolean {\n if (!comment.range) {\n return false;\n }\n\n let current = (sourceCode.getNodeByRangeIndex(comment.range[0]) ?? undefined) as Rule.Node | undefined;\n\n while (current?.type === 'CallExpression' || current?.type === 'MemberExpression') {\n if (current.type === 'CallExpression' && current.callee.type === 'MemberExpression') {\n return true;\n }\n\n current = current.parent as Rule.Node | undefined;\n }\n\n return false;\n }\n\n function isCommentAllowedByEnclosure(comment: Comment): boolean {\n if (!comment.range) {\n return false;\n }\n\n const node = sourceCode.getNodeByRangeIndex(comment.range[0]) as Rule.Node | null;\n\n if (!node) {\n return false;\n }\n\n // TS-specific node types aren't part of the ESTree `Rule.Node` union\n const type = node.type as string;\n\n if (allowInObjects && (type === 'ObjectExpression' || type === 'ObjectPattern')) {\n return true;\n }\n\n if (allowInArrays && (type === 'ArrayExpression' || type === 'ArrayPattern')) {\n return true;\n }\n\n if (allowInInterfaces && (type === 'TSInterfaceBody' || type === 'TSTypeLiteral')) {\n return true;\n }\n\n return false;\n }\n\n function isAtBlockStart(comment: Comment): boolean {\n const tokenBefore = sourceCode.getTokenBefore(comment as unknown as Rule.Node, {\n includeComments: false,\n });\n\n if (!tokenBefore) {\n return true;\n }\n\n return ['{', '(', '['].includes(tokenBefore.value);\n }\n\n return {\n Program() {\n const comments = sourceCode.getAllComments();\n\n for (const comment of comments) {\n if (!comment.loc || !comment.range) {\n continue;\n }\n\n const commentLine = comment.loc.start.line;\n\n if (commentLine <= 1) {\n continue;\n }\n\n if (isAtBlockStart(comment)) {\n continue;\n }\n\n if (isChainedCallContext(comment)) {\n continue;\n }\n\n if (isCommentAllowedByEnclosure(comment)) {\n continue;\n }\n\n const tokenBefore = sourceCode.getTokenBefore(comment as unknown as Rule.Node, {\n includeComments: true,\n });\n\n if (!tokenBefore?.loc) {\n continue;\n }\n\n const linesBetween = commentLine - tokenBefore.loc.end.line;\n\n if (linesBetween >= 2) {\n continue;\n }\n\n if (linesBetween === 0) {\n continue;\n }\n\n /*\n * Insert the blank line before the comment's leading indentation so the\n * comment keeps its position instead of being dedented.\n */\n const commentStart = comment.range[0];\n const lineStart = sourceCode.getText().lastIndexOf('\\n', commentStart - 1) + 1;\n\n context.report({\n loc: comment.loc,\n messageId: 'missingBlankLine',\n fix(fixer) {\n return fixer.insertTextBeforeRange([lineStart, lineStart], '\\n');\n },\n });\n }\n },\n };\n },\n};\n\nexport default rule;\n","import type { AST, Rule } from 'eslint';\n\ninterface CommentLike {\n readonly type: string;\n readonly value: string;\n readonly range?: [number, number];\n readonly loc?: Rule.Node['loc'];\n}\n\ninterface LineOptions {\n readonly requireLeadingSpace: boolean;\n readonly requireLowercase: boolean;\n readonly forbidTrailingPunctuation: boolean;\n readonly allowedEndings: readonly string[];\n}\n\ninterface BlockOptions {\n readonly requireCapital: boolean;\n readonly requireTrailingPunctuation: boolean;\n readonly enforceOpening: boolean;\n readonly enforceClosing: boolean;\n readonly requireSpaceAfterStar: boolean;\n readonly requireParagraphCapital: boolean;\n readonly paragraphEndings: readonly string[];\n readonly requireJSDocSpacing: boolean;\n readonly enforceParamStyle: boolean;\n}\n\ninterface ResolvedOptions {\n readonly ignoredWords: ReadonlySet<string>;\n readonly ignoredPatterns: readonly RegExp[];\n readonly ignoreUrls: boolean;\n readonly ignoreDirectives: boolean;\n readonly line: LineOptions;\n readonly block: BlockOptions;\n}\n\ntype MessageId =\n | 'lineLeadingSpace'\n | 'lineLowercase'\n | 'lineTrailingPunctuation'\n | 'blockCapital'\n | 'blockTrailingPunctuation'\n | 'blockSingleLineJSDoc'\n | 'blockOpening'\n | 'blockClosing'\n | 'blockEmptyLineBeforeClose'\n | 'blockLineSpaceAfterStar'\n | 'blockParagraphCapital'\n | 'blockParagraphEnding'\n | 'blockJSDocBlankLine'\n | 'paramMissingDash'\n | 'paramDescriptionPeriod';\n\ntype AnyComment = CommentLike | AST.Token;\n\nconst URL_PATTERN = /\\bhttps?:\\/\\//;\n\nconst DIRECTIVE_PATTERN =\n /^\\s*(?:eslint(?:-[a-z-]+)?\\b|@ts-[a-z-]+|@(?:jsx|jsxFrag|jsxImportSource|jsxRuntime)\\b|istanbul\\s|c8\\s|v8\\s|prettier-ignore\\b|stylelint-[a-z-]+|webpack[A-Z][a-zA-Z]*|#(?:region|endregion)\\b|type\\s*:)/;\n\nconst TAG_PATTERN = /^\\s*(?:TODO|FIXME|HACK|NOTE|BUG|XXX|SAFETY|WARNING|INFO|OPTIMIZE|REVIEW|PERF|DEPRECATED)\\b/i;\n\nconst FIRST_WORD_PATTERN = /^\\s*([A-Za-z_$][\\w$]*)/;\nconst ALL_CAPS_WORD = /^[A-Z][A-Z0-9_]*$/;\n\nconst JSDOC_TAG_LINE = /^\\s*\\*\\s*@[A-Za-z]/;\nconst SINGLE_LINE_JSDOC_TAG = /^@[A-Za-z][\\w-]*$/;\nconst PARAM_DESC_RE = /^@param\\s+(?:\\{[^}]*\\}\\s+)?(\\S+)\\s+(.*\\S)\\s*$/;\nconst BLOCK_LINE_WITH_TEXT = /^(\\s*\\*)(\\s*)(\\S.*?)\\s*$/;\nconst BLOCK_LINE_EMPTY = /^\\s*\\*\\s*$/;\nconst CODE_FENCE_LINE = /^\\s*\\*\\s*```/;\n\nconst DEFAULT_LINE_ENDINGS = Object.freeze(['etc.', '...', 'e.g.', 'i.e.']);\nconst DEFAULT_PARAGRAPH_ENDINGS = Object.freeze(['.', '!', '?', ':', ';', '`', ')', ']', '}']);\n\nconst DEFAULT_OPTIONS: ResolvedOptions = {\n ignoredWords: new Set<string>(),\n ignoredPatterns: [],\n ignoreUrls: true,\n ignoreDirectives: true,\n line: {\n requireLeadingSpace: true,\n requireLowercase: true,\n forbidTrailingPunctuation: true,\n allowedEndings: DEFAULT_LINE_ENDINGS,\n },\n block: {\n requireCapital: true,\n requireTrailingPunctuation: true,\n enforceOpening: false,\n enforceClosing: false,\n requireSpaceAfterStar: true,\n requireParagraphCapital: true,\n paragraphEndings: DEFAULT_PARAGRAPH_ENDINGS,\n requireJSDocSpacing: true,\n enforceParamStyle: true,\n },\n};\n\nfunction isUpperCase(char: string): boolean {\n return char !== char.toLowerCase() && char === char.toUpperCase();\n}\n\nfunction isLowerCase(char: string): boolean {\n return char !== char.toUpperCase() && char === char.toLowerCase();\n}\n\nfunction isTrailingPunctuation(char: string): boolean {\n return char === '.' || char === '!' || char === '?' || char === ';' || char === ':';\n}\n\nfunction isBlockEndingPunctuation(char: string): boolean {\n return (\n char === '.' ||\n char === '!' ||\n char === '?' ||\n char === ';' ||\n char === ':' ||\n char === ')' ||\n char === ']' ||\n char === '}' ||\n char === '`' ||\n char === '>'\n );\n}\n\nfunction indexOfLastNonSpace(value: string): number {\n for (let index = value.length - 1; index >= 0; index -= 1) {\n const char = value.codePointAt(index);\n\n if (char !== 0x20 && char !== 0x09 && char !== 0x0a && char !== 0x0d) {\n return index;\n }\n }\n\n return -1;\n}\n\nfunction endsWithAny(value: string, endings: readonly string[]): boolean {\n for (const ending of endings) {\n if (value.endsWith(ending)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction resolveOptions(raw: unknown): ResolvedOptions {\n if (!raw || typeof raw !== 'object') {\n return DEFAULT_OPTIONS;\n }\n\n const input = raw as Record<string, unknown>;\n const line = (input.line ?? {}) as Partial<LineOptions>;\n const block = (input.block ?? {}) as Partial<BlockOptions>;\n\n const patterns = Array.isArray(input.ignoredPatterns)\n ? (input.ignoredPatterns as string[]).map((source) => new RegExp(source))\n : DEFAULT_OPTIONS.ignoredPatterns;\n\n return {\n ignoredWords: new Set(Array.isArray(input.ignoredWords) ? (input.ignoredWords as string[]) : []),\n ignoredPatterns: patterns,\n ignoreUrls: (input.ignoreUrls as boolean | undefined) ?? DEFAULT_OPTIONS.ignoreUrls,\n ignoreDirectives: (input.ignoreDirectives as boolean | undefined) ?? DEFAULT_OPTIONS.ignoreDirectives,\n line: { ...DEFAULT_OPTIONS.line, ...line },\n block: { ...DEFAULT_OPTIONS.block, ...block },\n };\n}\n\nfunction shouldSkipComment(value: string, options: ResolvedOptions): boolean {\n const trimmed = value.trim();\n\n if (!trimmed) {\n return true;\n }\n\n if (options.ignoreDirectives && (DIRECTIVE_PATTERN.test(trimmed) || TAG_PATTERN.test(trimmed))) {\n return true;\n }\n\n if (options.ignoreUrls && URL_PATTERN.test(trimmed)) {\n return true;\n }\n\n for (const pattern of options.ignoredPatterns) {\n if (pattern.test(trimmed)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction checkLineComment(context: Rule.RuleContext, comment: AnyComment, options: ResolvedOptions): void {\n const { line } = options;\n const raw = comment.value;\n const loc = comment.loc;\n const range = comment.range;\n\n if (!loc || !range) {\n return;\n }\n\n const rangeStart = range[0];\n\n if (line.requireLeadingSpace && raw.length > 0) {\n const first = raw.codePointAt(0);\n\n // allow \"///\" banner comments and tab-indented comments\n if (first !== 0x20 && first !== 0x2f && first !== 0x09) {\n context.report({\n loc,\n messageId: 'lineLeadingSpace',\n fix: (fixer) => fixer.insertTextAfterRange([rangeStart, rangeStart + 2], ' '),\n });\n }\n }\n\n const trimmed = raw.trim();\n\n if (!trimmed) {\n return;\n }\n\n const firstWordMatch = FIRST_WORD_PATTERN.exec(trimmed);\n\n if (firstWordMatch && line.requireLowercase) {\n const word = firstWordMatch[1];\n const firstChar = word[0];\n\n if (isUpperCase(firstChar) && !ALL_CAPS_WORD.test(word) && !options.ignoredWords.has(word)) {\n context.report({\n loc,\n messageId: 'lineLowercase',\n fix: (fixer) => {\n const offset = rangeStart + 2 + raw.indexOf(firstChar);\n\n return fixer.replaceTextRange([offset, offset + 1], firstChar.toLowerCase());\n },\n });\n }\n }\n\n if (line.forbidTrailingPunctuation && !endsWithAny(trimmed, line.allowedEndings)) {\n const lastChar = trimmed.at(-1) ?? '';\n\n if (isTrailingPunctuation(lastChar)) {\n context.report({\n loc,\n messageId: 'lineTrailingPunctuation',\n fix: (fixer) => {\n const offset = rangeStart + 2 + indexOfLastNonSpace(raw);\n\n return fixer.removeRange([offset, offset + 1]);\n },\n });\n }\n }\n}\n\nfunction checkSingleLineBlock(context: Rule.RuleContext, comment: AnyComment, options: ResolvedOptions): void {\n const { block } = options;\n const raw = comment.value;\n const loc = comment.loc;\n const range = comment.range;\n\n if (!loc || !range) {\n return;\n }\n\n const trimmed = raw.trim();\n\n if (!trimmed) {\n return;\n }\n\n if (raw.startsWith('*')) {\n const inner = raw.slice(1).trim();\n\n if (!inner) {\n return;\n }\n\n if (SINGLE_LINE_JSDOC_TAG.test(inner)) {\n return;\n }\n\n const sourceCode = context.sourceCode;\n const sourceLine = sourceCode.lines[loc.start.line - 1] ?? '';\n const prefix = sourceLine.slice(0, loc.start.column);\n const canFix = /^\\s*$/.test(prefix);\n\n context.report({\n loc,\n messageId: 'blockSingleLineJSDoc',\n fix: canFix ? (fixer) => fixer.replaceTextRange(range, `/**\\n${prefix} * ${inner}\\n${prefix} */`) : undefined,\n });\n\n return;\n }\n\n const rangeStart = range[0];\n const firstWordMatch = FIRST_WORD_PATTERN.exec(trimmed);\n\n if (firstWordMatch && block.requireCapital) {\n const word = firstWordMatch[1];\n const firstChar = word[0];\n\n if (isLowerCase(firstChar) && !ALL_CAPS_WORD.test(word) && !options.ignoredWords.has(word)) {\n context.report({\n loc,\n messageId: 'blockCapital',\n fix: (fixer) => {\n const offset = rangeStart + 2 + raw.indexOf(firstChar);\n\n return fixer.replaceTextRange([offset, offset + 1], firstChar.toUpperCase());\n },\n });\n }\n }\n\n if (block.requireTrailingPunctuation) {\n const lastChar = trimmed.at(-1) ?? '';\n\n if (!isBlockEndingPunctuation(lastChar)) {\n context.report({\n loc,\n messageId: 'blockTrailingPunctuation',\n fix: (fixer) => {\n const offset = rangeStart + 2 + indexOfLastNonSpace(raw);\n\n return fixer.insertTextAfterRange([offset, offset + 1], '.');\n },\n });\n }\n }\n}\n\nfunction offsetOfLine(comment: AnyComment, lines: readonly string[], lineIndex: number): number {\n const range = comment.range;\n\n if (!range) {\n return 0;\n }\n\n // base = range start + length of `/*`, then cumulative line lengths plus their '\\n' separators\n let offset = range[0] + 2;\n\n for (let index = 0; index < lineIndex; index += 1) {\n offset += lines[index].length + 1;\n }\n\n return offset;\n}\n\nfunction skipParagraphFirstWord(text: string, options: ResolvedOptions): boolean {\n const match = FIRST_WORD_PATTERN.exec(text);\n\n if (!match) {\n return true;\n }\n\n const word = match[1];\n\n return ALL_CAPS_WORD.test(word) || options.ignoredWords.has(word);\n}\n\nfunction reportParagraphEnding(\n context: Rule.RuleContext,\n comment: AnyComment,\n text: string,\n options: ResolvedOptions,\n): void {\n const { block } = options;\n const loc = comment.loc;\n\n if (!loc) {\n return;\n }\n\n for (const ending of block.paragraphEndings) {\n if (text.endsWith(ending)) {\n return;\n }\n }\n\n context.report({\n loc,\n messageId: 'blockParagraphEnding',\n data: { endings: `[${block.paragraphEndings.join(' ')}]` },\n });\n}\n\nfunction checkParameterLine(\n context: Rule.RuleContext,\n comment: AnyComment,\n lines: readonly string[],\n lineIndex: number,\n text: string,\n starSegment: string,\n spaces: string,\n): void {\n const loc = comment.loc;\n\n if (!loc) {\n return;\n }\n\n const match = PARAM_DESC_RE.exec(text);\n\n if (!match) {\n return;\n }\n\n const descPart = match[2];\n const textStart = offsetOfLine(comment, lines, lineIndex) + starSegment.length + spaces.length;\n\n if (!descPart.startsWith('- ')) {\n const prefixMatch = /^@param\\s+(?:\\{[^}]*\\}\\s+)?\\S+\\s+/.exec(text);\n\n if (!prefixMatch) {\n return;\n }\n\n const descStartOffset = textStart + prefixMatch[0].length;\n\n context.report({\n loc,\n messageId: 'paramMissingDash',\n fix: (fixer) => fixer.insertTextBeforeRange([descStartOffset, descStartOffset + 1], '- '),\n });\n\n return;\n }\n\n const description = descPart.slice(2).trim();\n\n if (!description) {\n return;\n }\n\n if (!description.endsWith('.')) {\n const textEndOffset = textStart + text.length;\n\n context.report({\n loc,\n messageId: 'paramDescriptionPeriod',\n fix: (fixer) => fixer.insertTextAfterRange([textEndOffset - 1, textEndOffset], '.'),\n });\n }\n}\n\nfunction checkMultiLineBlock(context: Rule.RuleContext, comment: AnyComment, options: ResolvedOptions): void {\n const { block } = options;\n const loc = comment.loc;\n const range = comment.range;\n\n if (!loc || !range) {\n return;\n }\n\n const lines = comment.value.split('\\n');\n const firstLine = lines[0];\n const lastLine = lines.at(-1) ?? '';\n\n if (block.enforceOpening) {\n const opening = firstLine.trim();\n\n if (opening !== '' && opening !== '*') {\n context.report({ loc, messageId: 'blockOpening' });\n\n return;\n }\n }\n\n if (block.enforceClosing) {\n if (lastLine.trim() !== '') {\n context.report({ loc, messageId: 'blockClosing' });\n\n return;\n }\n\n if (lines.length >= 3 && BLOCK_LINE_EMPTY.test(lines.at(-2) ?? '')) {\n context.report({ loc, messageId: 'blockEmptyLineBeforeClose' });\n }\n }\n\n let insideCodeBlock = false;\n let paragraphStart = true;\n let previousText: string | undefined;\n\n for (let index = 1; index < lines.length - 1; index += 1) {\n const line = lines[index];\n\n if (CODE_FENCE_LINE.test(line)) {\n insideCodeBlock = !insideCodeBlock;\n paragraphStart = true;\n previousText = undefined;\n\n continue;\n }\n\n if (insideCodeBlock) {\n continue;\n }\n\n if (BLOCK_LINE_EMPTY.test(line)) {\n if (previousText !== undefined && block.requireParagraphCapital) {\n reportParagraphEnding(context, comment, previousText, options);\n }\n\n paragraphStart = true;\n previousText = undefined;\n\n continue;\n }\n\n const match = BLOCK_LINE_WITH_TEXT.exec(line);\n\n if (!match) {\n continue;\n }\n\n const [, starSegment, spaces, text] = match;\n\n if (block.requireSpaceAfterStar && spaces.length === 0) {\n const lineOffset = offsetOfLine(comment, lines, index);\n const starEnd = lineOffset + starSegment.length;\n\n context.report({\n loc,\n messageId: 'blockLineSpaceAfterStar',\n fix: (fixer) => fixer.insertTextAfterRange([starEnd - 1, starEnd], ' '),\n });\n\n continue;\n }\n\n if (block.requireJSDocSpacing && JSDOC_TAG_LINE.test(line) && previousText !== undefined) {\n const previousLine = lines[index - 1];\n\n if (!BLOCK_LINE_EMPTY.test(previousLine) && !JSDOC_TAG_LINE.test(previousLine)) {\n context.report({ loc, messageId: 'blockJSDocBlankLine' });\n }\n }\n\n if (paragraphStart && block.requireParagraphCapital && !JSDOC_TAG_LINE.test(line)) {\n const firstChar = text[0];\n\n if (firstChar && isLowerCase(firstChar) && !skipParagraphFirstWord(text, options)) {\n const lineOffset = offsetOfLine(comment, lines, index);\n const charOffset = lineOffset + starSegment.length + spaces.length;\n\n context.report({\n loc,\n messageId: 'blockParagraphCapital',\n fix: (fixer) => fixer.replaceTextRange([charOffset, charOffset + 1], firstChar.toUpperCase()),\n });\n }\n }\n\n paragraphStart = false;\n\n if (block.enforceParamStyle && /^@param\\s/.test(text)) {\n checkParameterLine(context, comment, lines, index, text, starSegment, spaces);\n previousText = undefined;\n } else {\n previousText = text;\n }\n }\n\n if (previousText !== undefined && block.requireParagraphCapital) {\n reportParagraphEnding(context, comment, previousText, options);\n }\n}\n\nconst messages: Record<MessageId, string> = {\n lineLeadingSpace: 'Line comment should start with a space.',\n lineLowercase: 'Line comment should start with a lowercase letter.',\n lineTrailingPunctuation: 'Line comment should not end with punctuation.',\n blockCapital: 'Block comment should start with an uppercase letter.',\n blockTrailingPunctuation: 'Block comment should end with punctuation.',\n blockSingleLineJSDoc: 'JSDoc-style block comments (/** ... */) must span multiple lines.',\n blockOpening: \"Block comment should start with '/**\\\\n *' (or '/*\\\\n *').\",\n blockClosing: \"Block comment should end with '\\\\n */'.\",\n blockEmptyLineBeforeClose: 'Block comment should not end with an empty line.',\n blockLineSpaceAfterStar: \"Each line of a block comment requires a space after '*'.\",\n blockParagraphCapital: 'Paragraph should start with an uppercase letter.',\n blockParagraphEnding: 'Paragraph should end with one of {{endings}}.',\n blockJSDocBlankLine: 'Insert a blank line before JSDoc tags.',\n paramMissingDash: \"@param should use ' - ' between name and description.\",\n paramDescriptionPeriod: '@param description should end with a period.',\n};\n\nconst rule: Rule.RuleModule = {\n meta: {\n type: 'suggestion',\n docs: {\n description:\n 'Enforce comment casing, punctuation, and JSDoc/paragraph structure for line, single-line block, and multi-line block comments.',\n },\n fixable: 'code',\n schema: [\n {\n type: 'object',\n additionalProperties: false,\n properties: {\n ignoredWords: {\n type: 'array',\n items: { type: 'string' },\n uniqueItems: true,\n },\n ignoredPatterns: {\n type: 'array',\n items: { type: 'string' },\n uniqueItems: true,\n },\n ignoreUrls: { type: 'boolean' },\n ignoreDirectives: { type: 'boolean' },\n line: {\n type: 'object',\n additionalProperties: false,\n properties: {\n requireLeadingSpace: { type: 'boolean' },\n requireLowercase: { type: 'boolean' },\n forbidTrailingPunctuation: { type: 'boolean' },\n allowedEndings: {\n type: 'array',\n items: { type: 'string' },\n uniqueItems: true,\n },\n },\n },\n block: {\n type: 'object',\n additionalProperties: false,\n properties: {\n requireCapital: { type: 'boolean' },\n requireTrailingPunctuation: { type: 'boolean' },\n enforceOpening: { type: 'boolean' },\n enforceClosing: { type: 'boolean' },\n requireSpaceAfterStar: { type: 'boolean' },\n requireParagraphCapital: { type: 'boolean' },\n paragraphEndings: {\n type: 'array',\n items: { type: 'string' },\n uniqueItems: true,\n },\n requireJSDocSpacing: { type: 'boolean' },\n enforceParamStyle: { type: 'boolean' },\n },\n },\n },\n },\n ],\n messages,\n },\n create(context) {\n const sourceCode = context.sourceCode;\n const options = resolveOptions(context.options[0]);\n\n return {\n Program() {\n const comments = sourceCode.getAllComments();\n\n for (const comment of comments) {\n if (shouldSkipComment(comment.value, options)) {\n continue;\n }\n\n if (comment.type === 'Line') {\n checkLineComment(context, comment, options);\n\n continue;\n }\n\n if (comment.value.includes('\\n')) {\n checkMultiLineBlock(context, comment, options);\n } else {\n checkSingleLineBlock(context, comment, options);\n }\n }\n },\n };\n },\n};\n\nexport default rule;\n","import type { Rule } from 'eslint';\n\nfunction isAlwaysPadded(node: Rule.Node) {\n /*\n * Class methods and static blocks always get blank lines between\n * siblings, even when single-line, so they never feel crammed together.\n */\n return node.type === 'MethodDefinition' || node.type === 'StaticBlock';\n}\n\nfunction isImportOrExport(node: Rule.Node) {\n /*\n * Imports and re-exports are grouped together with no blank lines between\n * them, so this rule ignores them entirely, both as a subject and as a\n * neighbor. Declared exports (export const/function/class) still pad like\n * regular code, since they contain real multiline bodies.\n */\n if (node.type === 'ImportDeclaration' || node.type === 'ExportAllDeclaration') {\n return true;\n }\n\n return node.type === 'ExportNamedDeclaration' && !node.declaration;\n}\n\nconst rule: Rule.RuleModule = {\n meta: {\n type: 'layout',\n docs: {\n description:\n 'Require blank lines around multiline statements, class methods, static blocks, and switch case bodies.',\n },\n fixable: 'whitespace',\n schema: [],\n messages: {\n missingBlankBefore: 'Expected blank line before this.',\n missingBlankAfter: 'Expected blank line after this.',\n },\n },\n create(context) {\n const sourceCode = context.sourceCode;\n\n function checkBody(body: Rule.Node[], options: { alwaysPadMembers?: boolean } = {}) {\n for (let index = 0; index < body.length; index++) {\n const node = body[index];\n\n if (!node.loc || isImportOrExport(node)) {\n continue;\n }\n\n const isMultiline = node.loc.start.line !== node.loc.end.line;\n const forceByKind = options.alwaysPadMembers === true && isAlwaysPadded(node);\n const needsPadding = isMultiline || forceByKind;\n\n if (!needsPadding) {\n continue;\n }\n\n if (index > 0) {\n const previous = body[index - 1];\n\n if (previous.loc && !isImportOrExport(previous)) {\n const linesBetween = node.loc.start.line - previous.loc.end.line;\n\n if (linesBetween < 2) {\n context.report({\n node,\n messageId: 'missingBlankBefore',\n fix(fixer) {\n const previousToken = sourceCode.getLastToken(previous);\n\n if (!previousToken) {\n return null;\n }\n\n return fixer.insertTextAfter(previousToken, '\\n');\n },\n });\n }\n }\n }\n\n if (index < body.length - 1) {\n const next = body[index + 1];\n\n if (next.loc && !isImportOrExport(next)) {\n const linesBetween = next.loc.start.line - node.loc.end.line;\n\n if (linesBetween < 2) {\n context.report({\n node,\n messageId: 'missingBlankAfter',\n fix(fixer) {\n const lastToken = sourceCode.getLastToken(node);\n\n if (!lastToken) {\n return null;\n }\n\n return fixer.insertTextAfter(lastToken, '\\n');\n },\n });\n }\n }\n }\n }\n }\n\n return {\n Program(node) {\n checkBody(node.body as Rule.Node[]);\n },\n BlockStatement(node) {\n checkBody(node.body as Rule.Node[]);\n },\n StaticBlock(node) {\n checkBody(node.body as Rule.Node[]);\n },\n SwitchCase(node) {\n checkBody(node.consequent as Rule.Node[]);\n },\n ClassBody(node) {\n checkBody(node.body as Rule.Node[], { alwaysPadMembers: true });\n },\n };\n },\n};\n\nexport default rule;\n","import type { Rule } from 'eslint';\n\nconst rule: Rule.RuleModule = {\n meta: {\n type: 'suggestion',\n docs: {\n description:\n 'Disallow returning an object literal from an arrow function concise body (e.g. `() => ({})`); require a block body with an explicit return.',\n },\n fixable: 'code',\n schema: [],\n messages: {\n implicitObjectReturn:\n 'Avoid returning an object literal directly from an arrow function; use a block body with an explicit return.',\n },\n },\n create(context) {\n const sourceCode = context.sourceCode;\n\n return {\n ArrowFunctionExpression(node) {\n const body = node.body;\n\n // only concise bodies that resolve straight to an object literal\n if (!node.expression || body.type !== 'ObjectExpression') {\n return;\n }\n\n context.report({\n node: body,\n messageId: 'implicitObjectReturn',\n fix(fixer) {\n const arrowToken = sourceCode.getTokenBefore(body, (token) => token.value === '=>');\n\n // an object concise body is always parenthesized, otherwise it parses as a block\n const openParen = sourceCode.getTokenBefore(body);\n const closeParen = sourceCode.getTokenAfter(body);\n\n if (!arrowToken || openParen?.value !== '(' || closeParen?.value !== ')') {\n return null;\n }\n\n const objectText = sourceCode.getText(body);\n\n return fixer.replaceTextRange([arrowToken.range[1], closeParen.range[1]], ` { return ${objectText}; }`);\n },\n });\n },\n };\n },\n};\n\nexport default rule;\n","import type { ESLint } from 'eslint';\n\nimport blockScopedCase from './block-scoped-case.js';\nimport commentPrecedingBlankLine from './comment-preceding-blank-line.js';\nimport commentSyntax from './comment-syntax.js';\nimport newlineAroundMultiline from './newline-around-multiline.js';\nimport noImplicitObjectReturn from './no-implicit-object-return.js';\n\nexport const customRules: ESLint.Plugin = {\n meta: {\n name: '@d3lm/lint-preset-rules',\n version: '0.1.0',\n },\n rules: {\n 'newline-around-multiline': newlineAroundMultiline,\n 'block-scoped-case': blockScopedCase,\n 'comment-syntax': commentSyntax,\n 'comment-preceding-blank-line': commentPrecedingBlankLine,\n 'no-implicit-object-return': noImplicitObjectReturn,\n },\n};\n\nexport default customRules;\n"],"mappings":"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","names":["rule","rule","rule","rule"]}
@@ -0,0 +1,46 @@
1
+ interface ReactRuleOptions {
2
+ fastRefresh?: boolean;
3
+ performance?: boolean;
4
+ }
5
+ type ReactConfigOptions = boolean | ReactRuleOptions;
6
+
7
+ interface JavaScriptRuleOptions {
8
+ preventAbbreviations?: {
9
+ allowList?: string[];
10
+ inheritAllowList?: boolean;
11
+ replacements?: Record<string, Record<string, boolean> | false>;
12
+ inheritReplacements?: boolean;
13
+ };
14
+ }
15
+
16
+ interface TypeScriptRuleOptions extends JavaScriptRuleOptions {
17
+ namingConvention?: {
18
+ variable?: {
19
+ inheritFormat?: boolean;
20
+ format?: string[];
21
+ exceptions?: string[];
22
+ };
23
+ parameter?: {
24
+ inheritFormat?: boolean;
25
+ format?: string[];
26
+ exceptions?: string[];
27
+ };
28
+ typeLike?: {
29
+ inheritFormat?: boolean;
30
+ format?: string[];
31
+ exceptions?: string[];
32
+ };
33
+ memberLike?: {
34
+ inheritFormat?: boolean;
35
+ format?: string[];
36
+ exceptions?: string[];
37
+ };
38
+ function?: {
39
+ inheritFormat?: boolean;
40
+ format?: string[];
41
+ exceptions?: string[];
42
+ };
43
+ };
44
+ }
45
+
46
+ export type { JavaScriptRuleOptions as J, ReactConfigOptions as R, TypeScriptRuleOptions as T };
@@ -0,0 +1,46 @@
1
+ interface ReactRuleOptions {
2
+ fastRefresh?: boolean;
3
+ performance?: boolean;
4
+ }
5
+ type ReactConfigOptions = boolean | ReactRuleOptions;
6
+
7
+ interface JavaScriptRuleOptions {
8
+ preventAbbreviations?: {
9
+ allowList?: string[];
10
+ inheritAllowList?: boolean;
11
+ replacements?: Record<string, Record<string, boolean> | false>;
12
+ inheritReplacements?: boolean;
13
+ };
14
+ }
15
+
16
+ interface TypeScriptRuleOptions extends JavaScriptRuleOptions {
17
+ namingConvention?: {
18
+ variable?: {
19
+ inheritFormat?: boolean;
20
+ format?: string[];
21
+ exceptions?: string[];
22
+ };
23
+ parameter?: {
24
+ inheritFormat?: boolean;
25
+ format?: string[];
26
+ exceptions?: string[];
27
+ };
28
+ typeLike?: {
29
+ inheritFormat?: boolean;
30
+ format?: string[];
31
+ exceptions?: string[];
32
+ };
33
+ memberLike?: {
34
+ inheritFormat?: boolean;
35
+ format?: string[];
36
+ exceptions?: string[];
37
+ };
38
+ function?: {
39
+ inheritFormat?: boolean;
40
+ format?: string[];
41
+ exceptions?: string[];
42
+ };
43
+ };
44
+ }
45
+
46
+ export type { JavaScriptRuleOptions as J, ReactConfigOptions as R, TypeScriptRuleOptions as T };
package/package.json ADDED
@@ -0,0 +1,83 @@
1
+ {
2
+ "name": "@d3lm/lint-preset",
3
+ "version": "1.0.0",
4
+ "description": "Opinionated Oxlint + ESLint preset. Oxlint handles non-type-aware rules, while ESLint layers only type-aware rules not covered by Oxlint on top.",
5
+ "license": "MIT",
6
+ "type": "module",
7
+ "exports": {
8
+ "./eslint": {
9
+ "types": "./dist/eslint.d.ts",
10
+ "import": "./dist/eslint.js",
11
+ "require": "./dist/eslint.cjs"
12
+ },
13
+ "./oxlint": {
14
+ "types": "./dist/oxlint.d.ts",
15
+ "import": "./dist/oxlint.js",
16
+ "require": "./dist/oxlint.cjs"
17
+ },
18
+ "./rules": {
19
+ "types": "./dist/rules.d.ts",
20
+ "import": "./dist/rules.js",
21
+ "require": "./dist/rules.cjs"
22
+ }
23
+ },
24
+ "files": [
25
+ "dist"
26
+ ],
27
+ "keywords": [
28
+ "eslint",
29
+ "eslint-plugin",
30
+ "code-style",
31
+ "linting",
32
+ "oxlint"
33
+ ],
34
+ "publishConfig": {
35
+ "access": "public"
36
+ },
37
+ "peerDependencies": {
38
+ "@stylistic/eslint-plugin": ">=5.0.0",
39
+ "@typescript-eslint/eslint-plugin": ">=8.0.0",
40
+ "eslint": ">=9.0.0",
41
+ "eslint-config-prettier": ">=10.0.0",
42
+ "eslint-plugin-jsdoc": ">=62.0.0",
43
+ "eslint-plugin-oxlint": ">=1.60.0",
44
+ "eslint-plugin-prettier": ">=5.0.0",
45
+ "eslint-plugin-react-hooks": ">=7.0.0",
46
+ "eslint-plugin-unicorn": ">=64.0.0",
47
+ "oxlint": ">=1.60.0",
48
+ "oxlint-tsgolint": ">=0.21.1",
49
+ "typescript-eslint": ">=8.0.0"
50
+ },
51
+ "peerDependenciesMeta": {
52
+ "eslint-plugin-react-hooks": {
53
+ "optional": true
54
+ }
55
+ },
56
+ "devDependencies": {
57
+ "@stylistic/eslint-plugin": "^5.10.0",
58
+ "@types/common-tags": "^1.8.4",
59
+ "@types/eslint": "^9.6.1",
60
+ "@types/node": "^25.9.2",
61
+ "common-tags": "^1.8.2",
62
+ "eslint": "^10.2.0",
63
+ "eslint-config-prettier": "^10.1.8",
64
+ "eslint-plugin-jsdoc": "^62.9.0",
65
+ "eslint-plugin-oxlint": "^1.60.0",
66
+ "eslint-plugin-prettier": "^5.5.5",
67
+ "eslint-plugin-react-hooks": "^7.1.1",
68
+ "eslint-plugin-unicorn": "^64.0.0",
69
+ "oxlint": "^1.60.0",
70
+ "oxlint-tsgolint": "^0.21.1",
71
+ "tsup": "^8.5.1",
72
+ "typescript": "^6.0.2",
73
+ "typescript-eslint": "^8.32.1",
74
+ "vitest": "^4.1.4"
75
+ },
76
+ "scripts": {
77
+ "build": "tsup",
78
+ "test": "vitest run",
79
+ "test:watch": "vitest",
80
+ "lint": "pnpm run build && oxlint && eslint",
81
+ "lint:fix": "pnpm run build && oxlint --fix && eslint --fix"
82
+ }
83
+ }