org.sonar.go.plugin.CyclomaticComplexityVisitor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sonar-go-plugin Show documentation
Show all versions of sonar-go-plugin Show documentation
SonarQube analyzer for Go language
/*
* SonarSource Go
* Copyright (C) 2018-2025 SonarSource SA
* mailto:info AT sonarsource DOT com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the Sonar Source-Available License Version 1, as published by SonarSource SA.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the Sonar Source-Available License for more details.
*
* You should have received a copy of the Sonar Source-Available License
* along with this program; if not, see https://sonarsource.com/license/ssal/
*/
package org.sonar.go.plugin;
import java.util.ArrayList;
import java.util.List;
import org.sonar.go.api.BinaryExpressionTree;
import org.sonar.go.api.FunctionDeclarationTree;
import org.sonar.go.api.HasTextRange;
import org.sonar.go.api.IfTree;
import org.sonar.go.api.LoopTree;
import org.sonar.go.api.MatchCaseTree;
import org.sonar.go.api.Tree;
import org.sonar.go.visitors.TreeContext;
import org.sonar.go.visitors.TreeVisitor;
public class CyclomaticComplexityVisitor extends TreeVisitor {
private List complexityTrees = new ArrayList<>();
public CyclomaticComplexityVisitor() {
register(FunctionDeclarationTree.class, (ctx, tree) -> {
if (tree.name() != null && tree.body() != null) {
complexityTrees.add(tree);
}
});
register(IfTree.class, (ctx, tree) -> complexityTrees.add(tree.ifKeyword()));
register(LoopTree.class, (ctx, tree) -> complexityTrees.add(tree));
register(MatchCaseTree.class, (ctx, tree) -> {
if (tree.expression() != null) {
complexityTrees.add(tree);
}
});
register(BinaryExpressionTree.class, (ctx, tree) -> {
if (tree.operator() == BinaryExpressionTree.Operator.CONDITIONAL_AND ||
tree.operator() == BinaryExpressionTree.Operator.CONDITIONAL_OR) {
complexityTrees.add(tree);
}
});
}
public List complexityTrees(Tree tree) {
this.complexityTrees = new ArrayList<>();
this.scan(new TreeContext(), tree);
return this.complexityTrees;
}
@Override
protected void before(TreeContext ctx, Tree root) {
complexityTrees = new ArrayList<>();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy