Compare commits

...

8 Commits

Author SHA1 Message Date
Anthony Fu
b8fe1fabea release v0.21.0 2022-04-25 13:26:25 +08:00
Anthony Fu
0ab9f88603 feat(eslint-plugin): new import dedupe rule 2022-04-25 13:26:07 +08:00
liyujun
17670e8e38 fix: space-before-function-paren allows space in anonymous and asyncArrow function. (#84) 2022-04-25 01:02:25 +08:00
Coder Zhao
686f285a37 chore: replace no-leading-newline with no-multiple-empty-lines (#82) 2022-04-24 22:11:01 +08:00
Anthony Fu
2d9efd4df6 release v0.20.7 2022-04-23 09:23:16 +08:00
Anthony Fu
b8e6cdf047 chore: updete deps 2022-04-23 09:23:11 +08:00
Anthony Fu
50c962197b release v0.20.6 2022-04-17 13:17:38 +08:00
Anthony Fu
bf19dc0adb fix: indents 2022-04-17 13:17:35 +08:00
16 changed files with 427 additions and 387 deletions

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-monorepo", "name": "@antfu/eslint-config-monorepo",
"version": "0.20.5", "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/)",
@@ -12,7 +12,7 @@
"devDependencies": { "devDependencies": {
"@antfu/eslint-config": "*", "@antfu/eslint-config": "*",
"bumpp": "^7.1.1", "bumpp": "^7.1.1",
"eslint": "^8.12.0", "eslint": "^8.14.0",
"eslint-plugin-antfu": "workspace:*", "eslint-plugin-antfu": "workspace:*",
"typescript": "^4.6.3" "typescript": "^4.6.3"
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config", "name": "@antfu/eslint-config",
"version": "0.20.5", "version": "0.21.0",
"description": "", "description": "",
"keywords": [], "keywords": [],
"license": "MIT", "license": "MIT",
@@ -15,22 +15,22 @@
"dependencies": { "dependencies": {
"@antfu/eslint-config-react": "workspace:*", "@antfu/eslint-config-react": "workspace:*",
"@antfu/eslint-config-vue": "workspace:*", "@antfu/eslint-config-vue": "workspace:*",
"@typescript-eslint/eslint-plugin": "^5.17.0", "@typescript-eslint/eslint-plugin": "^5.20.0",
"@typescript-eslint/parser": "^5.17.0", "@typescript-eslint/parser": "^5.20.0",
"eslint-plugin-eslint-comments": "^3.2.0", "eslint-plugin-eslint-comments": "^3.2.0",
"eslint-plugin-html": "^6.2.0", "eslint-plugin-html": "^6.2.0",
"eslint-plugin-import": "^2.25.4", "eslint-plugin-import": "^2.26.0",
"eslint-plugin-jsonc": "^2.2.1", "eslint-plugin-jsonc": "^2.2.1",
"eslint-plugin-n": "^15.1.0", "eslint-plugin-n": "^15.1.0",
"eslint-plugin-promise": "^6.0.0", "eslint-plugin-promise": "^6.0.0",
"eslint-plugin-unicorn": "^41.0.1", "eslint-plugin-unicorn": "^42.0.0",
"eslint-plugin-vue": "^8.5.0", "eslint-plugin-vue": "^8.7.1",
"eslint-plugin-yml": "^0.14.0", "eslint-plugin-yml": "^0.14.0",
"jsonc-eslint-parser": "^2.1.0", "jsonc-eslint-parser": "^2.1.0",
"yaml-eslint-parser": "^0.5.0" "yaml-eslint-parser": "^0.5.0"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.12.0" "eslint": "^8.14.0"
}, },
"publishConfig": { "publishConfig": {
"access": "public" "access": "public"

View File

@@ -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',
}, },
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-basic", "name": "@antfu/eslint-config-basic",
"version": "0.20.5", "version": "0.21.0",
"description": "", "description": "",
"keywords": [], "keywords": [],
"license": "MIT", "license": "MIT",
@@ -19,18 +19,18 @@
"eslint-plugin-antfu": "workspace:*", "eslint-plugin-antfu": "workspace:*",
"eslint-plugin-eslint-comments": "^3.2.0", "eslint-plugin-eslint-comments": "^3.2.0",
"eslint-plugin-html": "^6.2.0", "eslint-plugin-html": "^6.2.0",
"eslint-plugin-import": "^2.25.4", "eslint-plugin-import": "^2.26.0",
"eslint-plugin-jsonc": "^2.2.1", "eslint-plugin-jsonc": "^2.2.1",
"eslint-plugin-markdown": "^2.2.1", "eslint-plugin-markdown": "^2.2.1",
"eslint-plugin-n": "^15.1.0", "eslint-plugin-n": "^15.1.0",
"eslint-plugin-promise": "^6.0.0", "eslint-plugin-promise": "^6.0.0",
"eslint-plugin-unicorn": "^41.0.1", "eslint-plugin-unicorn": "^42.0.0",
"eslint-plugin-yml": "^0.14.0", "eslint-plugin-yml": "^0.14.0",
"jsonc-eslint-parser": "^2.1.0", "jsonc-eslint-parser": "^2.1.0",
"yaml-eslint-parser": "^0.5.0" "yaml-eslint-parser": "^0.5.0"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.12.0" "eslint": "^8.14.0"
}, },
"publishConfig": { "publishConfig": {
"access": "public" "access": "public"

View File

@@ -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 }],

View File

@@ -2,8 +2,5 @@
"extends": "@antfu", "extends": "@antfu",
"plugins": [ "plugins": [
"antfu" "antfu"
], ]
"rules": {
"antfu/no-leading-newline": "error"
}
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "eslint-plugin-antfu", "name": "eslint-plugin-antfu",
"version": "0.20.5", "version": "0.21.0",
"license": "MIT", "license": "MIT",
"main": "./dist/index.cjs", "main": "./dist/index.cjs",
"module": "./dist/index.mjs", "module": "./dist/index.mjs",
@@ -22,10 +22,10 @@
"prepublishOnly": "nr build" "prepublishOnly": "nr build"
}, },
"dependencies": { "dependencies": {
"@typescript-eslint/utils": "^5.17.0" "@typescript-eslint/utils": "^5.20.0"
}, },
"devDependencies": { "devDependencies": {
"unbuild": "^0.7.0", "unbuild": "^0.7.4",
"vitest": "^0.8.2" "vitest": "^0.9.4"
} }
} }

View File

@@ -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,
}, },
} }

View File

@@ -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' }],
})), })),
}) })
}) })

View 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)
},
}
},
})

View File

@@ -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], '')
},
})
}
},
}
},
})

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-react", "name": "@antfu/eslint-config-react",
"version": "0.20.5", "version": "0.21.0",
"description": "", "description": "",
"keywords": [], "keywords": [],
"license": "MIT", "license": "MIT",
@@ -23,7 +23,7 @@
"eslint-plugin-react": "^7.29.4" "eslint-plugin-react": "^7.29.4"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.12.0", "eslint": "^8.14.0",
"react": "^18.0.0", "react": "^18.0.0",
"typescript": "^4.6.3" "typescript": "^4.6.3"
} }

View File

@@ -30,11 +30,39 @@ module.exports = {
'no-useless-constructor': 'off', 'no-useless-constructor': 'off',
'indent': 'off', 'indent': 'off',
'@typescript-eslint/indent': ['error', 2, { '@typescript-eslint/indent': ['error', 2, {
SwitchCase: 1,
VariableDeclarator: 1,
outerIIFEBody: 1,
MemberExpression: 1,
FunctionDeclaration: { parameters: 1, body: 1 },
FunctionExpression: { parameters: 1, body: 1 },
CallExpression: { arguments: 1 },
ArrayExpression: 1,
ObjectExpression: 1,
ImportDeclaration: 1,
flatTernaryExpressions: false,
ignoreComments: false,
ignoredNodes: [ ignoredNodes: [
'TemplateLiteral *',
'JSXElement',
'JSXElement > *',
'JSXAttribute', 'JSXAttribute',
'JSXIdentifier',
'JSXNamespacedName',
'JSXMemberExpression',
'JSXSpreadAttribute',
'JSXExpressionContainer',
'JSXOpeningElement',
'JSXClosingElement',
'JSXFragment',
'JSXOpeningFragment',
'JSXClosingFragment',
'JSXText',
'JSXEmptyExpression',
'JSXSpreadChild',
'TSTypeParameterInstantiation', 'TSTypeParameterInstantiation',
], ],
SwitchCase: 1, offsetTernaryExpressions: true,
}], }],
'no-unused-vars': 'off', 'no-unused-vars': 'off',
'@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }], '@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }],

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-ts", "name": "@antfu/eslint-config-ts",
"version": "0.20.5", "version": "0.21.0",
"description": "", "description": "",
"keywords": [], "keywords": [],
"license": "MIT", "license": "MIT",
@@ -18,10 +18,10 @@
}, },
"dependencies": { "dependencies": {
"@antfu/eslint-config-basic": "workspace:*", "@antfu/eslint-config-basic": "workspace:*",
"@typescript-eslint/eslint-plugin": "^5.17.0", "@typescript-eslint/eslint-plugin": "^5.20.0",
"@typescript-eslint/parser": "^5.17.0" "@typescript-eslint/parser": "^5.20.0"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.12.0" "eslint": "^8.14.0"
} }
} }

View File

@@ -1,6 +1,6 @@
{ {
"name": "@antfu/eslint-config-vue", "name": "@antfu/eslint-config-vue",
"version": "0.20.5", "version": "0.21.0",
"description": "", "description": "",
"keywords": [], "keywords": [],
"license": "MIT", "license": "MIT",
@@ -17,9 +17,9 @@
}, },
"dependencies": { "dependencies": {
"@antfu/eslint-config-ts": "workspace:*", "@antfu/eslint-config-ts": "workspace:*",
"eslint-plugin-vue": "^8.5.0" "eslint-plugin-vue": "^8.7.1"
}, },
"devDependencies": { "devDependencies": {
"eslint": "^8.12.0" "eslint": "^8.14.0"
} }
} }

586
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff