Skip to content

Commit

Permalink
Allow skipping checks for dscanner.suspicious.unmodified with nolint
Browse files Browse the repository at this point in the history
  • Loading branch information
kubo39 committed May 5, 2024
1 parent 433d1eb commit 156b383
Showing 1 changed file with 17 additions and 3 deletions.
20 changes: 17 additions & 3 deletions src/dscanner/analysis/unmodified.d
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
module dscanner.analysis.unmodified;

import dscanner.analysis.base;
import dscanner.analysis.nolint;
import dscanner.utils : safeAccess;
import dsymbol.scope_ : Scope;
import std.container;
Expand Down Expand Up @@ -114,11 +115,15 @@ final class UnmodifiedFinder : BaseAnalyzer
if (canFindImmutableOrConst(dec))
{
isImmutable++;
dec.accept(this);
with (noLint.push(NoLintFactory.fromDeclaration(dec)))
dec.accept(this);
isImmutable--;
}
else
dec.accept(this);
{
with (noLint.push(NoLintFactory.fromDeclaration(dec)))
dec.accept(this);
}
}

override void visit(const IdentifierChain ic)
Expand Down Expand Up @@ -189,6 +194,8 @@ final class UnmodifiedFinder : BaseAnalyzer

private:

enum string KEY = "dscanner.suspicious.unmodified";

template PartsMightModify(T)
{
override void visit(const T t)
Expand Down Expand Up @@ -300,7 +307,7 @@ private:
{
immutable string errorMessage = "Variable " ~ vi.name
~ " is never modified and could have been declared const or immutable.";
addErrorMessage(vi.token, "dscanner.suspicious.unmodified", errorMessage);
addErrorMessage(vi.token, KEY, errorMessage);
}
tree = tree[0 .. $ - 1];
}
Expand Down Expand Up @@ -379,5 +386,12 @@ bool isValueTypeSimple(const Type type) pure nothrow @nogc
foo(i2);
}
}, sac);

assertAnalyzerWarnings(q{
@("nolint(dscanner.suspicious.unmodified)")
void foo(){
int i = 1;
}
}, sac);
}

0 comments on commit 156b383

Please sign in to comment.