mirror of
https://github.com/swc-project/swc.git
synced 2024-11-24 02:06:08 +03:00
refactor(es/lints): Use util for parens (#4167)
This commit is contained in:
parent
589ff584e7
commit
2a9cb2d12a
@ -7,7 +7,7 @@ use swc_ecma_visit::{noop_visit_type, Visit, VisitWith};
|
||||
use crate::{
|
||||
config::{LintRuleReaction, RuleConfig},
|
||||
rule::{visitor_rule, Rule},
|
||||
rules::utils::{extract_arg_val, ArgValue},
|
||||
rules::utils::{extract_arg_val, unwrap_seqs_and_parens, ArgValue},
|
||||
};
|
||||
|
||||
const UNEXPECTED_REG_EXP_MESSAGE: &str =
|
||||
@ -97,8 +97,7 @@ impl PreferRegexLiterals {
|
||||
self.first_arg = Some(extract_arg_val(
|
||||
&self.top_level_ctxt,
|
||||
&self.top_level_declared_vars,
|
||||
expr.as_ref(),
|
||||
true,
|
||||
unwrap_seqs_and_parens(expr.as_ref()),
|
||||
));
|
||||
}
|
||||
|
||||
@ -106,8 +105,7 @@ impl PreferRegexLiterals {
|
||||
self.second_arg = Some(extract_arg_val(
|
||||
&self.top_level_ctxt,
|
||||
&self.top_level_declared_vars,
|
||||
expr.as_ref(),
|
||||
true,
|
||||
unwrap_seqs_and_parens(expr.as_ref()),
|
||||
));
|
||||
}
|
||||
}
|
||||
|
@ -12,7 +12,7 @@ use swc_ecma_visit::{noop_visit_type, Visit, VisitWith};
|
||||
use crate::{
|
||||
config::{LintRuleReaction, RuleConfig},
|
||||
rule::{visitor_rule, Rule},
|
||||
rules::utils::{extract_arg_val, ArgValue},
|
||||
rules::utils::{extract_arg_val, unwrap_seqs_and_parens, ArgValue},
|
||||
};
|
||||
|
||||
const OBJ_NAMES: &[&str] = &["Number", "globalThis"];
|
||||
@ -41,7 +41,7 @@ impl Default for RadixMode {
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct RadixConfig {
|
||||
mode: Option<RadixMode>,
|
||||
check_parens: Option<bool>,
|
||||
unwrap_parens_and_seqs: Option<bool>,
|
||||
}
|
||||
|
||||
pub fn radix(
|
||||
@ -66,7 +66,7 @@ struct Radix {
|
||||
top_level_declared_vars: AHashSet<Id>,
|
||||
|
||||
radix_mode: RadixMode,
|
||||
check_parens: bool,
|
||||
unwrap_parens_and_seqs: bool,
|
||||
|
||||
classes_depth: usize,
|
||||
objects_depth: usize,
|
||||
@ -87,7 +87,7 @@ impl Radix {
|
||||
top_level_declared_vars,
|
||||
|
||||
radix_mode: rule_config.mode.unwrap_or_default(),
|
||||
check_parens: rule_config.check_parens.unwrap_or(true),
|
||||
unwrap_parens_and_seqs: rule_config.unwrap_parens_and_seqs.unwrap_or(true),
|
||||
|
||||
classes_depth: 0,
|
||||
objects_depth: 0,
|
||||
@ -152,12 +152,13 @@ impl Radix {
|
||||
|
||||
match call_expr.args.get(1) {
|
||||
Some(ExprOrSpread { expr, .. }) => {
|
||||
match &extract_arg_val(
|
||||
&self.top_level_ctxt,
|
||||
&self.top_level_declared_vars,
|
||||
expr.as_ref(),
|
||||
self.check_parens,
|
||||
) {
|
||||
let expr = if self.unwrap_parens_and_seqs {
|
||||
unwrap_seqs_and_parens(expr.as_ref())
|
||||
} else {
|
||||
expr.as_ref()
|
||||
};
|
||||
|
||||
match &extract_arg_val(&self.top_level_ctxt, &self.top_level_declared_vars, expr) {
|
||||
ArgValue::Ident => {}
|
||||
ArgValue::Number(radix) => {
|
||||
if radix.fract() != 0.0 || !(2f64..=36f64).contains(radix) {
|
||||
|
@ -7,7 +7,7 @@ use swc_ecma_visit::{Visit, VisitWith};
|
||||
use crate::{
|
||||
config::{LintRuleReaction, RuleConfig},
|
||||
rule::{visitor_rule, Rule},
|
||||
rules::utils::{extract_arg_val, ArgValue},
|
||||
rules::utils::{extract_arg_val, unwrap_seqs_and_parens, ArgValue},
|
||||
};
|
||||
|
||||
const SYMBOL_EXPECTED_MESSAGE: &str = "Expected Symbol to have a description";
|
||||
@ -76,8 +76,7 @@ impl SymbolDescription {
|
||||
match extract_arg_val(
|
||||
&self.top_level_ctxt,
|
||||
&self.top_level_declared_vars,
|
||||
expr,
|
||||
true,
|
||||
unwrap_seqs_and_parens(expr),
|
||||
) {
|
||||
ArgValue::Str(_) => {}
|
||||
_ => {
|
||||
|
@ -56,22 +56,9 @@ pub fn extract_arg_val(
|
||||
top_level_ctxt: &SyntaxContext,
|
||||
top_level_declared_vars: &AHashSet<Id>,
|
||||
expr: &Expr,
|
||||
check_parens: bool,
|
||||
) -> ArgValue {
|
||||
match expr {
|
||||
Expr::Ident(_) => ArgValue::Ident,
|
||||
Expr::Paren(ParenExpr { expr, .. }) => {
|
||||
if check_parens {
|
||||
extract_arg_val(
|
||||
top_level_ctxt,
|
||||
top_level_declared_vars,
|
||||
expr.as_ref(),
|
||||
check_parens,
|
||||
)
|
||||
} else {
|
||||
ArgValue::Other
|
||||
}
|
||||
}
|
||||
Expr::Lit(Lit::Str(Str { value, .. })) => ArgValue::Str(value.clone()),
|
||||
Expr::Lit(Lit::Num(Number { value, .. })) => ArgValue::Number(*value),
|
||||
Expr::Lit(Lit::Regex(Regex { exp, flags, .. })) => ArgValue::RegExp {
|
||||
|
Loading…
Reference in New Issue
Block a user