org.codenarc.results.FileResults.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of CodeNarc Show documentation
Show all versions of CodeNarc Show documentation
The CodeNarc project provides a static analysis tool for Groovy code.
/*
* Copyright 2008 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.codenarc.results
/**
* Represents the results of applying a set of rules against a single sourcefile
*
* @author Chris Mair
*/
class FileResults implements Results {
private final String path
private final List violations
FileResults(String path, List violations) {
this.path = path
this.violations = violations
}
/**
* @return the path to the file or directory associated with these results
*/
String getPath() {
path
}
/**
* @return true (this object represents the results for a single file)
*/
boolean isFile() {
true
}
/**
* Return an empty List
* @return the List of child Results objects; may be empty
*/
List getChildren() {
Collections.EMPTY_LIST
}
/**
* @return the List of all violations
*/
List getViolations() {
new ArrayList(violations)
}
/**
* @param recursive - true if the returned count should include subdirectories as well; defaults to true
* @return the number of violations with the specified priority
*/
@Override
int getNumberOfViolationsWithPriority(int priority, boolean recursive=true) {
violations.sum(0) { violation -> violation.rule.priority == priority ? 1 : 0 }
}
/**
* Return the total number of (Groovy) files analyzed
* @param recursive - true if the returned count should include subdirectories as well
* @return the total number of files (with or without violations)
*/
@Override
int getTotalNumberOfFiles(boolean recursive=true) {
1
}
/**
* Return 1 if these results include at least one violation
* @param maxPriority - the maximum priority level; ignore violations with priority greater than this
* @param recursive - ignored; defaults to true
* @return the number of files containing violations
*/
@Override
int getNumberOfFilesWithViolations(int maxPriority, boolean recursive=true) {
violations.find { v -> v.rule.priority <= maxPriority } ? 1 : 0
}
/**
* Return the Results object with the specified path.
* @param path - the path to search for
* @return this Results object if the path matches, otherwise null
*/
Results findResultsForPath(String path) {
this.path == path ? this : null
}
String toString() {
"FileResults($path) $violations"
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy