-
-
Notifications
You must be signed in to change notification settings - Fork 486
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(linter/eslint-plugin-promise): implement no-webpack-loader-syntax (
#4331) Rule detail: [link](https://github.com/import-js/eslint-plugin-import/blob/main/docs/rules/no-webpack-loader-syntax.md)
- Loading branch information
Showing
3 changed files
with
178 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
118 changes: 118 additions & 0 deletions
118
crates/oxc_linter/src/rules/import/no_webpack_loader_syntax.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
use oxc_ast::{ | ||
ast::{Argument, Expression}, | ||
AstKind, | ||
}; | ||
use oxc_diagnostics::OxcDiagnostic; | ||
use oxc_macros::declare_oxc_lint; | ||
use oxc_semantic::AstNode; | ||
use oxc_span::Span; | ||
|
||
use crate::{context::LintContext, rule::Rule}; | ||
|
||
fn no_named_as_default_diagnostic(x0: &str, span0: Span) -> OxcDiagnostic { | ||
OxcDiagnostic::warn(format!( | ||
"eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `{x0}`." | ||
)) | ||
.with_help("Do not use import syntax to configure webpack loaders") | ||
.with_label(span0) | ||
} | ||
|
||
#[derive(Debug, Default, Clone)] | ||
pub struct NoWebpackLoaderSyntax; | ||
|
||
declare_oxc_lint!( | ||
/// ### What it does | ||
/// | ||
/// Forbid Webpack loader syntax in imports. | ||
/// | ||
/// ### Why is this bad? | ||
/// | ||
/// This loader syntax is non-standard, so it couples the code to Webpack. The recommended way to | ||
/// specify Webpack loader configuration is in a [Webpack configuration file](https://webpack.js.org/concepts/loaders/#configuration). | ||
/// | ||
/// ### Example | ||
/// ```javascript | ||
/// import myModule from 'my-loader!my-module'; | ||
/// import theme from 'style!css!./theme.css'; | ||
/// | ||
/// var myModule = require('my-loader!./my-module'); | ||
/// var theme = require('style!css!./theme.css'); | ||
/// ``` | ||
NoWebpackLoaderSyntax, | ||
restriction, | ||
); | ||
|
||
impl Rule for NoWebpackLoaderSyntax { | ||
fn run<'a>(&self, node: &AstNode<'a>, ctx: &LintContext<'a>) { | ||
// not in top level | ||
if node.scope_id() != ctx.scopes().root_scope_id() { | ||
return; | ||
} | ||
|
||
match node.kind() { | ||
AstKind::CallExpression(call_expr) => { | ||
if let Expression::Identifier(identifier) = &call_expr.callee { | ||
if identifier.name != "require" { | ||
return; | ||
} | ||
|
||
if call_expr.arguments.len() != 1 { | ||
return; | ||
} | ||
|
||
let Argument::StringLiteral(ident) = &call_expr.arguments[0] else { | ||
return; | ||
}; | ||
|
||
if ident.value.contains('!') { | ||
ctx.diagnostic(no_named_as_default_diagnostic( | ||
ident.value.as_str(), | ||
ident.span, | ||
)); | ||
} | ||
} | ||
} | ||
AstKind::ImportDeclaration(import_decl) => { | ||
if import_decl.source.value.contains('!') { | ||
ctx.diagnostic(no_named_as_default_diagnostic( | ||
&import_decl.source.value, | ||
import_decl.source.span, | ||
)); | ||
} | ||
} | ||
_ => {} | ||
} | ||
} | ||
} | ||
|
||
#[test] | ||
fn test() { | ||
use crate::tester::Tester; | ||
|
||
let pass = vec![ | ||
"import _ from 'lodash'", | ||
"import find from 'lodash.find'", | ||
"import foo from './foo.css'", | ||
"import data from '@scope/my-package/data.json'", | ||
"var _ = require('lodash')", | ||
"var find = require('lodash.find')", | ||
"var foo = require('./foo')", | ||
"var foo = require('../foo')", | ||
"var foo = require('foo')", | ||
"var foo = require('./')", | ||
"var foo = require('@scope/foo')", | ||
]; | ||
|
||
let fail = vec![ | ||
"import _ from 'babel!lodash'", | ||
"import find from '-babel-loader!lodash.find'", | ||
"import foo from 'style!css!./foo.css'", | ||
"import data from 'json!@scope/my-package/data.json'", | ||
"var _ = require('babel!lodash')", | ||
"var find = require('-babel-loader!lodash.find')", | ||
"var foo = require('style!css!./foo.css')", | ||
"var data = require('json!@scope/my-package/data.json')", | ||
]; | ||
|
||
Tester::new(NoWebpackLoaderSyntax::NAME, pass, fail).test_and_snapshot(); | ||
} |
58 changes: 58 additions & 0 deletions
58
crates/oxc_linter/src/snapshots/no_webpack_loader_syntax.snap
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
--- | ||
source: crates/oxc_linter/src/tester.rs | ||
--- | ||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `babel!lodash`. | ||
╭─[no_webpack_loader_syntax.tsx:1:15] | ||
1 │ import _ from 'babel!lodash' | ||
· ────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders | ||
|
||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `-babel-loader!lodash.find`. | ||
╭─[no_webpack_loader_syntax.tsx:1:18] | ||
1 │ import find from '-babel-loader!lodash.find' | ||
· ─────────────────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders | ||
|
||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `style!css!./foo.css`. | ||
╭─[no_webpack_loader_syntax.tsx:1:17] | ||
1 │ import foo from 'style!css!./foo.css' | ||
· ───────────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders | ||
|
||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `json!@scope/my-package/data.json`. | ||
╭─[no_webpack_loader_syntax.tsx:1:18] | ||
1 │ import data from 'json!@scope/my-package/data.json' | ||
· ────────────────────────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders | ||
|
||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `babel!lodash`. | ||
╭─[no_webpack_loader_syntax.tsx:1:17] | ||
1 │ var _ = require('babel!lodash') | ||
· ────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders | ||
|
||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `-babel-loader!lodash.find`. | ||
╭─[no_webpack_loader_syntax.tsx:1:20] | ||
1 │ var find = require('-babel-loader!lodash.find') | ||
· ─────────────────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders | ||
|
||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `style!css!./foo.css`. | ||
╭─[no_webpack_loader_syntax.tsx:1:19] | ||
1 │ var foo = require('style!css!./foo.css') | ||
· ───────────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders | ||
|
||
⚠ eslint-plugin-import(no-webpack-loader-syntax): Unexpected `!` in `json!@scope/my-package/data.json`. | ||
╭─[no_webpack_loader_syntax.tsx:1:20] | ||
1 │ var data = require('json!@scope/my-package/data.json') | ||
· ────────────────────────────────── | ||
╰──── | ||
help: Do not use import syntax to configure webpack loaders |