From c7b24eb9bd6098a095b0b557916a24e0763664e1 Mon Sep 17 00:00:00 2001 From: Thibault Czarniak Date: Wed, 11 Sep 2024 15:16:12 +0200 Subject: [PATCH] Added new rules --- rules/src/main/scala/fix/VarCouldBeVal.scala | 2 +- .../main/scala/fix/VariableShadowing.scala | 23 +++++++++---------- 2 files changed, 12 insertions(+), 13 deletions(-) diff --git a/rules/src/main/scala/fix/VarCouldBeVal.scala b/rules/src/main/scala/fix/VarCouldBeVal.scala index 070220a..c8e28ad 100644 --- a/rules/src/main/scala/fix/VarCouldBeVal.scala +++ b/rules/src/main/scala/fix/VarCouldBeVal.scala @@ -34,7 +34,7 @@ class VarCouldBeVal extends SemanticRule("VarCouldBeVal") { // Corresponds to compound assignments e.g. +=, -=, etc. case Term.ApplyInfix.After_4_6_0(Term.Name(name), Term.Name(op), _, _) if isAssignment(op) => vars.remove(name) } - vars.map(name => Patch.lint(diag(name._2))).asPatch + vars.map(name => Patch.lint(diag(name._2))).asPatch } // We first look at the templates (start of a definition) i.e. start of a scope (variables don't go outside) diff --git a/rules/src/main/scala/fix/VariableShadowing.scala b/rules/src/main/scala/fix/VariableShadowing.scala index 8fa8a29..4c9e42a 100644 --- a/rules/src/main/scala/fix/VariableShadowing.scala +++ b/rules/src/main/scala/fix/VariableShadowing.scala @@ -19,11 +19,10 @@ class VariableShadowing extends SemanticRule("VariableShadowing") { ) override def fix(implicit doc: SemanticDocument): Patch = { - def collect2(tree: Tree, vars: mutable.HashSet[String]) : List[Patch] = { + def collect2(tree: Tree, vars: mutable.HashSet[String]): List[Patch] = { val flagged = mutable.HashSet.empty[Position] var varsList = vars :: Nil - def collectInner(tree: Tree, flagged: mutable.HashSet[Position]): mutable.HashSet[Position] = { def updateVars(name: String, pos: Position): Unit = { if (exists(name)) flagged += pos @@ -60,29 +59,29 @@ class VariableShadowing extends SemanticRule("VariableShadowing") { } tree match { - case t @ (Term.Block(_) | Template.After_4_4_0(_, _, _, _, _) | Term.PartialFunction(_)) => ecle(t.children) - case Term.Function.After_4_6_0(_, body) => ece(body) - case Defn.Val(_, List(Pat.Var(name)), _, _) => updateVars(name.value, name.pos) - case Defn.Var.After_4_7_2(_, List(Pat.Var(name)), _, _) => updateVars(name.value, name.pos) + case t @ (Term.Block(_) | Template.After_4_4_0(_, _, _, _, _) | Term.PartialFunction(_)) => ecle(t.children) + case Term.Function.After_4_6_0(_, body) => ece(body) + case Defn.Val(_, List(Pat.Var(name)), _, _) => updateVars(name.value, name.pos) + case Defn.Var.After_4_7_2(_, List(Pat.Var(name)), _, _) => updateVars(name.value, name.pos) // Examine paramclauses e.g. def foo(a: Int) or class bar(b: Int) case Term.ParamClause(params, _) => params.foreach(p => updateVars(p.name.value, p.name.pos)) - case Defn.Def.After_4_7_3(_, _, paramClauseGroups, _ , body) => + case Defn.Def.After_4_7_3(_, _, paramClauseGroups, _, body) => enter() paramClauseHandler(paramClauseGroups) collectInner(body, flagged) exit() case Term.Match.After_4_4_5(_, cases, _) => cases.foreach { - case Case(Pat.Var(name @ Term.Name(_)), _, body) => enter(); updateVars(name.value, name.pos); collectInner(body, flagged); exit() - case Case(_, _, body) => ece(body) - case _ => () - } + case Case(Pat.Var(name @ Term.Name(_)), _, body) => enter(); updateVars(name.value, name.pos); collectInner(body, flagged); exit() + case Case(_, _, body) => ece(body) + case _ => () + } case other => ecle(other.children) } flagged } - collectInner(tree, flagged).map(p => Patch.lint(diag(p))).toList + collectInner(tree, flagged).map(p => Patch.lint(diag(p))).toList }