se.bjurr.violations.lib.parsers.YAMLlintParser Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of violations-lib Show documentation
Show all versions of violations-lib Show documentation
Library for parsing report files from static code analyzis.
package se.bjurr.violations.lib.parsers;
import static java.lang.Integer.parseInt;
import static se.bjurr.violations.lib.model.SEVERITY.ERROR;
import static se.bjurr.violations.lib.model.SEVERITY.INFO;
import static se.bjurr.violations.lib.model.SEVERITY.WARN;
import static se.bjurr.violations.lib.model.Violation.violationBuilder;
import static se.bjurr.violations.lib.reports.Parser.YAMLLINT;
import static se.bjurr.violations.lib.util.Utils.isNullOrEmpty;
import static se.bjurr.violations.lib.util.ViolationParserUtils.getLines;
import java.util.List;
import java.util.Set;
import java.util.TreeSet;
import se.bjurr.violations.lib.ViolationsLogger;
import se.bjurr.violations.lib.model.SEVERITY;
import se.bjurr.violations.lib.model.Violation;
/**
* YAMLlint.
*
* yamllint -f parsable
*
*/
public class YAMLlintParser implements ViolationsParser {
@Override
public Set parseReportOutput(final String string, ViolationsLogger violationsLogger)
throws Exception {
final Set violations = new TreeSet<>();
final List> partsPerLine =
getLines(
string, "([^:]*):(\\d+):(\\d+):\\s?\\[(error|warning)\\]([^\\(]+)(\\(([^\\)]+)\\))?");
for (final List parts : partsPerLine) {
final String filename = parts.get(1).trim();
final Integer line = parseInt(parts.get(2));
final Integer column = parseInt(parts.get(3));
final String severity = parts.get(4).trim();
final String message = parts.get(5).trim();
String rule = null;
if (!isNullOrEmpty(parts.get(7))) {
rule = parts.get(7).trim();
}
violations.add( //
violationBuilder() //
.setParser(YAMLLINT) //
.setStartLine(line) //
.setColumn(column) //
.setFile(filename) //
.setSeverity(this.toSeverity(severity)) //
.setMessage(message) //
.setRule(rule) //
.build() //
);
}
return violations;
}
/**
*
*
*
* The different message types are:
* warning, for non critical syntax errors
* error, for more serious syntax problem
*
*/
public SEVERITY toSeverity(final String severity) {
if (severity.equalsIgnoreCase("error")) {
return ERROR;
}
if (severity.equalsIgnoreCase("warning")) {
return WARN;
}
return INFO;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy