Package org.jacoco.core.analysis
Class Analyzer
- java.lang.Object
-
- org.jacoco.core.analysis.Analyzer
-
public class Analyzer extends java.lang.ObjectAnAnalyzerinstance processes a set of Java class files and calculates coverage data for them. For each class file the result is reported to a givenICoverageVisitorinstance. In addition theAnalyzerrequires aExecutionDataStoreinstance that holds the execution data for the classes to analyze. TheAnalyzeroffers several methods to analyze classes from a variety of sources.
-
-
Constructor Summary
Constructors Constructor Description Analyzer(ExecutionDataStore executionData, ICoverageVisitor coverageVisitor)Creates a new analyzer reporting to the given output.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intanalyzeAll(java.io.File file)Analyzes all class files contained in the given file or folder.intanalyzeAll(java.io.InputStream input, java.lang.String location)Analyzes all classes found in the given input stream.intanalyzeAll(java.lang.String path, java.io.File basedir)Analyzes all classes from the given class path.voidanalyzeClass(byte[] buffer, java.lang.String location)Analyzes the class definition from a given in-memory buffer.voidanalyzeClass(java.io.InputStream input, java.lang.String location)Analyzes the class definition from a given input stream.voidanalyzeClass(org.objectweb.asm.ClassReader reader)Analyzes the class given as a ASM reader.
-
-
-
Constructor Detail
-
Analyzer
public Analyzer(ExecutionDataStore executionData, ICoverageVisitor coverageVisitor)
Creates a new analyzer reporting to the given output.- Parameters:
executionData- execution datacoverageVisitor- the output instance that will coverage data for every analyzed class
-
-
Method Detail
-
analyzeClass
public void analyzeClass(org.objectweb.asm.ClassReader reader)
Analyzes the class given as a ASM reader.- Parameters:
reader- reader with class definitions
-
analyzeClass
public void analyzeClass(byte[] buffer, java.lang.String location) throws java.io.IOExceptionAnalyzes the class definition from a given in-memory buffer.- Parameters:
buffer- class definitionslocation- a location description used for exception messages- Throws:
java.io.IOException- if the class can't be analyzed
-
analyzeClass
public void analyzeClass(java.io.InputStream input, java.lang.String location) throws java.io.IOExceptionAnalyzes the class definition from a given input stream. The providedInputStreamis not closed by this method.- Parameters:
input- stream to read class definition fromlocation- a location description used for exception messages- Throws:
java.io.IOException- if the stream can't be read or the class can't be analyzed
-
analyzeAll
public int analyzeAll(java.io.InputStream input, java.lang.String location) throws java.io.IOExceptionAnalyzes all classes found in the given input stream. The input stream may either represent a single class file, a ZIP archive, a Pack200 archive or a gzip stream that is searched recursively for class files. All other content types are ignored. The providedInputStreamis not closed by this method.- Parameters:
input- input datalocation- a location description used for exception messages- Returns:
- number of class files found
- Throws:
java.io.IOException- if the stream can't be read or a class can't be analyzed
-
analyzeAll
public int analyzeAll(java.io.File file) throws java.io.IOExceptionAnalyzes all class files contained in the given file or folder. Class files as well as ZIP files are considered. Folders are searched recursively.- Parameters:
file- file or folder to look for class files- Returns:
- number of class files found
- Throws:
java.io.IOException- if the file can't be read or a class can't be analyzed
-
analyzeAll
public int analyzeAll(java.lang.String path, java.io.File basedir) throws java.io.IOExceptionAnalyzes all classes from the given class path. Directories containing class files as well as archive files are considered.- Parameters:
path- path definitionbasedir- optional base directory, ifnullthe current working directory is used as the base for relative path entries- Returns:
- number of class files found
- Throws:
java.io.IOException- if a file can't be read or a class can't be analyzed
-
-