Compare commits
	
		
			4 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | b8fe1fabea | ||
|  | 0ab9f88603 | ||
|  | 17670e8e38 | ||
|  | 686f285a37 | 
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-monorepo", |   "name": "@antfu/eslint-config-monorepo", | ||||||
|   "version": "0.20.7", |   "version": "0.21.0", | ||||||
|   "private": true, |   "private": true, | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", |   "author": "Anthony Fu <anthonyfu117@hotmail.com> (https://github.com/antfu/)", | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config", |   "name": "@antfu/eslint-config", | ||||||
|   "version": "0.20.7", |   "version": "0.21.0", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |   "keywords": [], | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   | |||||||
| @@ -183,7 +183,15 @@ module.exports = { | |||||||
|     ], |     ], | ||||||
|     'object-curly-spacing': ['error', 'always'], |     'object-curly-spacing': ['error', 'always'], | ||||||
|     'no-return-await': 'off', |     'no-return-await': 'off', | ||||||
|     'space-before-function-paren': ['error', 'never'], |     'space-before-function-paren': [ | ||||||
|  |       'error', | ||||||
|  |       { | ||||||
|  |         anonymous: 'always', | ||||||
|  |         named: 'never', | ||||||
|  |         asyncArrow: 'always', | ||||||
|  |       }, | ||||||
|  |     ], | ||||||
|  |     'no-multiple-empty-lines': ['error', { max: 1, maxBOF: 0, maxEOF: 1 }], | ||||||
|  |  | ||||||
|     // es6 |     // es6 | ||||||
|     'no-var': 'error', |     'no-var': 'error', | ||||||
| @@ -292,8 +300,8 @@ module.exports = { | |||||||
|     'yml/no-empty-document': 'off', |     'yml/no-empty-document': 'off', | ||||||
|  |  | ||||||
|     // antfu |     // antfu | ||||||
|     'antfu/no-leading-newline': 'error', |  | ||||||
|     'antfu/if-newline': 'error', |     'antfu/if-newline': 'error', | ||||||
|  |     'antfu/import-dedupe': 'error', | ||||||
|     // 'antfu/prefer-inline-type-import': 'error', |     // 'antfu/prefer-inline-type-import': 'error', | ||||||
|   }, |   }, | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-basic", |   "name": "@antfu/eslint-config-basic", | ||||||
|   "version": "0.20.7", |   "version": "0.21.0", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |   "keywords": [], | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   | |||||||
| @@ -202,7 +202,14 @@ module.exports = { | |||||||
|     'semi': ['error', 'never'], |     'semi': ['error', 'never'], | ||||||
|     'semi-spacing': ['error', { before: false, after: true }], |     'semi-spacing': ['error', { before: false, after: true }], | ||||||
|     'space-before-blocks': ['error', 'always'], |     'space-before-blocks': ['error', 'always'], | ||||||
|     'space-before-function-paren': ['error', 'always'], |     'space-before-function-paren': [ | ||||||
|  |       'error', | ||||||
|  |       { | ||||||
|  |         'anonymous': 'always', | ||||||
|  |         'named': 'never', | ||||||
|  |         'asyncArrow': 'always' | ||||||
|  |       } | ||||||
|  |     ], | ||||||
|     'space-in-parens': ['error', 'never'], |     'space-in-parens': ['error', 'never'], | ||||||
|     'space-infix-ops': 'error', |     'space-infix-ops': 'error', | ||||||
|     'space-unary-ops': ['error', { words: true, nonwords: false }], |     'space-unary-ops': ['error', { words: true, nonwords: false }], | ||||||
|   | |||||||
| @@ -2,8 +2,5 @@ | |||||||
|   "extends": "@antfu", |   "extends": "@antfu", | ||||||
|   "plugins": [ |   "plugins": [ | ||||||
|     "antfu" |     "antfu" | ||||||
|   ], |   ] | ||||||
|   "rules": { |  | ||||||
|     "antfu/no-leading-newline": "error" |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "eslint-plugin-antfu", |   "name": "eslint-plugin-antfu", | ||||||
|   "version": "0.20.7", |   "version": "0.21.0", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "main": "./dist/index.cjs", |   "main": "./dist/index.cjs", | ||||||
|   "module": "./dist/index.mjs", |   "module": "./dist/index.mjs", | ||||||
|   | |||||||
| @@ -1,11 +1,11 @@ | |||||||
| import ifNewline from './rules/if-newline' | import ifNewline from './rules/if-newline' | ||||||
| import noLeadingNewline from './rules/no-leading-newline' | import importDedupe from './rules/import-dedupe' | ||||||
| import preferInlineTypeImport from './rules/prefer-inline-type-import' | import preferInlineTypeImport from './rules/prefer-inline-type-import' | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
|   rules: { |   rules: { | ||||||
|     'no-leading-newline': noLeadingNewline, |  | ||||||
|     'if-newline': ifNewline, |     'if-newline': ifNewline, | ||||||
|  |     'import-dedupe': importDedupe, | ||||||
|     'prefer-inline-type-import': preferInlineTypeImport, |     'prefer-inline-type-import': preferInlineTypeImport, | ||||||
|   }, |   }, | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,15 @@ | |||||||
| import { RuleTester } from '@typescript-eslint/utils/dist/ts-eslint' | import { RuleTester } from '@typescript-eslint/utils/dist/ts-eslint' | ||||||
| import { it } from 'vitest' | import { it } from 'vitest' | ||||||
| import rule, { RULE_NAME } from './no-leading-newline' | import rule, { RULE_NAME } from './import-dedupe' | ||||||
| 
 | 
 | ||||||
| const valids = [ | const valids = [ | ||||||
|   'import {} from \'foo\'', |   'import { a } from \'foo\'', | ||||||
|   `// comment
 |  | ||||||
| import {} from ''`,
 |  | ||||||
| ] | ] | ||||||
| const invalids = [ | const invalids = [ | ||||||
|   '\n\nimport {} from \'fo\'', |   [ | ||||||
|  |     'import { a, b, a, a, c, a } from \'foo\'', | ||||||
|  |     'import { a, b,   c,  } from \'foo\'', | ||||||
|  |   ], | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| it('runs', () => { | it('runs', () => { | ||||||
| @@ -19,9 +20,9 @@ it('runs', () => { | |||||||
|   ruleTester.run(RULE_NAME, rule, { |   ruleTester.run(RULE_NAME, rule, { | ||||||
|     valid: valids, |     valid: valids, | ||||||
|     invalid: invalids.map(i => ({ |     invalid: invalids.map(i => ({ | ||||||
|       code: i, |       code: i[0], | ||||||
|       output: i.trim(), |       output: i[1], | ||||||
|       errors: [{ messageId: 'noLeadingNewline' }], |       errors: [{ messageId: 'importDedupe' }, { messageId: 'importDedupe' }, { messageId: 'importDedupe' }], | ||||||
|     })), |     })), | ||||||
|   }) |   }) | ||||||
| }) | }) | ||||||
							
								
								
									
										55
									
								
								packages/eslint-plugin-antfu/src/rules/import-dedupe.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								packages/eslint-plugin-antfu/src/rules/import-dedupe.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | import { createEslintRule } from '../utils' | ||||||
|  |  | ||||||
|  | export const RULE_NAME = 'import-dedupe' | ||||||
|  | export type MessageIds = 'importDedupe' | ||||||
|  | export type Options = [] | ||||||
|  |  | ||||||
|  | export default createEslintRule<Options, MessageIds>({ | ||||||
|  |   name: RULE_NAME, | ||||||
|  |   meta: { | ||||||
|  |     type: 'problem', | ||||||
|  |     docs: { | ||||||
|  |       description: 'Fix duplication in imports', | ||||||
|  |       recommended: 'error', | ||||||
|  |     }, | ||||||
|  |     fixable: 'code', | ||||||
|  |     schema: [], | ||||||
|  |     messages: { | ||||||
|  |       importDedupe: 'Expect no duplication in imports', | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  |   defaultOptions: [], | ||||||
|  |   create: (context) => { | ||||||
|  |     return { | ||||||
|  |       ImportDeclaration(node) { | ||||||
|  |         if (node.specifiers.length <= 1) | ||||||
|  |           return | ||||||
|  |  | ||||||
|  |         const names = new Set<string>() | ||||||
|  |         node.specifiers.forEach((n) => { | ||||||
|  |           const id = n.local.name | ||||||
|  |           if (names.has(id)) { | ||||||
|  |             context.report({ | ||||||
|  |               node, | ||||||
|  |               loc: { | ||||||
|  |                 start: n.loc.end, | ||||||
|  |                 end: n.loc.start, | ||||||
|  |               }, | ||||||
|  |               messageId: 'importDedupe', | ||||||
|  |               fix(fixer) { | ||||||
|  |                 const s = n.range[0] | ||||||
|  |                 let e = n.range[1] | ||||||
|  |                 if (context.getSourceCode().text[e] === ',') | ||||||
|  |                   e += 1 | ||||||
|  |                 return fixer.removeRange([s, e]) | ||||||
|  |               }, | ||||||
|  |             }) | ||||||
|  |           } | ||||||
|  |           names.add(id) | ||||||
|  |         }) | ||||||
|  |  | ||||||
|  |         // console.log(node) | ||||||
|  |       }, | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  | }) | ||||||
| @@ -1,44 +0,0 @@ | |||||||
| import { createEslintRule } from '../utils' |  | ||||||
|  |  | ||||||
| export const RULE_NAME = 'no-leading-newline' |  | ||||||
| export type MessageIds = 'noLeadingNewline' |  | ||||||
| export type Options = [] |  | ||||||
|  |  | ||||||
| export default createEslintRule<Options, MessageIds>({ |  | ||||||
|   name: RULE_NAME, |  | ||||||
|   meta: { |  | ||||||
|     type: 'problem', |  | ||||||
|     docs: { |  | ||||||
|       description: 'Do not allow leading newline', |  | ||||||
|       recommended: 'error', |  | ||||||
|     }, |  | ||||||
|     fixable: 'whitespace', |  | ||||||
|     schema: [], |  | ||||||
|     messages: { |  | ||||||
|       noLeadingNewline: 'No leading newline allowed', |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
|   defaultOptions: [], |  | ||||||
|   create: (context) => { |  | ||||||
|     return { |  | ||||||
|       Program(node) { |  | ||||||
|         const code = context.getSourceCode() |  | ||||||
|         const match = code.text.match(/^[\s]+/)?.[0] || '' |  | ||||||
|         if (match.includes('\n')) { |  | ||||||
|           const line = match.split('\n') |  | ||||||
|           context.report({ |  | ||||||
|             node, |  | ||||||
|             loc: { |  | ||||||
|               start: { line: 0, column: 0 }, |  | ||||||
|               end: { line: line.length - 1, column: line[line.length - 1].length }, |  | ||||||
|             }, |  | ||||||
|             messageId: 'noLeadingNewline', |  | ||||||
|             fix(fixer) { |  | ||||||
|               return fixer.replaceTextRange([0, match.length], '') |  | ||||||
|             }, |  | ||||||
|           }) |  | ||||||
|         } |  | ||||||
|       }, |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| }) |  | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-react", |   "name": "@antfu/eslint-config-react", | ||||||
|   "version": "0.20.7", |   "version": "0.21.0", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |   "keywords": [], | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-ts", |   "name": "@antfu/eslint-config-ts", | ||||||
|   "version": "0.20.7", |   "version": "0.21.0", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |   "keywords": [], | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "@antfu/eslint-config-vue", |   "name": "@antfu/eslint-config-vue", | ||||||
|   "version": "0.20.7", |   "version": "0.21.0", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "keywords": [], |   "keywords": [], | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user