aboutsummaryrefslogtreecommitdiff
path: root/org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java
diff options
context:
space:
mode:
authorNikolay Krasko <goodwinnk@gmail.com>2018-06-07 03:39:28 +0300
committerEvgeny Mandrikov <Godin@users.noreply.github.com>2018-06-07 02:39:28 +0200
commit281538bc74d9f09f5b0d83250a4435b5c2732e21 (patch)
tree7a0eef00d9e8fa644a97f65ccd1a31f010a57371 /org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java
parent1a56c9619e03ee3e4e1b539e592e7d8b51f53a7b (diff)
downloadjacoco-281538bc74d9f09f5b0d83250a4435b5c2732e21.tar.gz
Add filter for methods that Kotlin compiler generates (#689)
Diffstat (limited to 'org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java')
-rw-r--r--org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java46
1 files changed, 40 insertions, 6 deletions
diff --git a/org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java b/org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java
index afcf387e..e40b66dc 100644
--- a/org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java
+++ b/org.jacoco.core/src/org/jacoco/core/internal/analysis/ClassAnalyzer.java
@@ -11,22 +11,30 @@
*******************************************************************************/
package org.jacoco.core.internal.analysis;
+import java.util.HashSet;
+import java.util.Set;
+
import org.jacoco.core.analysis.IMethodCoverage;
import org.jacoco.core.internal.analysis.filter.Filters;
+import org.jacoco.core.internal.analysis.filter.IFilterContext;
import org.jacoco.core.internal.flow.ClassProbesVisitor;
import org.jacoco.core.internal.flow.MethodProbesVisitor;
import org.jacoco.core.internal.instr.InstrSupport;
+import org.objectweb.asm.AnnotationVisitor;
import org.objectweb.asm.FieldVisitor;
/**
* Analyzes the structure of a class.
*/
-public class ClassAnalyzer extends ClassProbesVisitor {
+public class ClassAnalyzer extends ClassProbesVisitor
+ implements IFilterContext {
private final ClassCoverageImpl coverage;
private final boolean[] probes;
private final StringPool stringPool;
+ private final Set<String> classAnnotations = new HashSet<String>();
+
/**
* Creates a new analyzer that builds coverage data for a class.
*
@@ -54,24 +62,32 @@ public class ClassAnalyzer extends ClassProbesVisitor {
}
@Override
+ public AnnotationVisitor visitAnnotation(final String desc,
+ final boolean visible) {
+ classAnnotations.add(desc);
+ return super.visitAnnotation(desc, visible);
+ }
+
+ @Override
public void visitSource(final String source, final String debug) {
coverage.setSourceFileName(stringPool.get(source));
}
@Override
public MethodProbesVisitor visitMethod(final int access, final String name,
- final String desc, final String signature, final String[] exceptions) {
+ final String desc, final String signature,
+ final String[] exceptions) {
InstrSupport.assertNotInstrumented(name, coverage.getName());
- return new MethodAnalyzer(coverage.getName(), coverage.getSuperName(),
- stringPool.get(name), stringPool.get(desc),
- stringPool.get(signature), probes, Filters.ALL) {
+ return new MethodAnalyzer(stringPool.get(name), stringPool.get(desc),
+ stringPool.get(signature), probes, Filters.ALL, this) {
@Override
public void visitEnd() {
super.visitEnd();
final IMethodCoverage methodCoverage = getCoverage();
- if (methodCoverage.getInstructionCounter().getTotalCount() > 0) {
+ if (methodCoverage.getInstructionCounter()
+ .getTotalCount() > 0) {
// Only consider methods that actually contain code
coverage.addMethod(methodCoverage);
}
@@ -91,4 +107,22 @@ public class ClassAnalyzer extends ClassProbesVisitor {
// nothing to do
}
+ // IFilterContext implementation
+
+ public String getClassName() {
+ return coverage.getName();
+ }
+
+ public String getSuperClassName() {
+ return coverage.getSuperName();
+ }
+
+ public Set<String> getClassAnnotations() {
+ return classAnnotations;
+ }
+
+ public String getSourceFileName() {
+ return coverage.getSourceFileName();
+ }
+
}