1 /******************************************************************************* 2 * Copyright (c) 2009, 2018 Mountainminds GmbH & Co. KG and Contributors 3 * All rights reserved. This program and the accompanying materials 4 * are made available under the terms of the Eclipse Public License v1.0 5 * which accompanies this distribution, and is available at 6 * http://www.eclipse.org/legal/epl-v10.html 7 * 8 * Contributors: 9 * Marc R. Hoffmann - initial API and implementation 10 * 11 *******************************************************************************/ 12 package org.jacoco.report; 13 14 import java.io.IOException; 15 16 import org.jacoco.core.analysis.IBundleCoverage; 17 18 /** 19 * Output-Interface for hierarchical report structures. To allow sequential 20 * processing and save memory the group structure has to be traversed in a 21 * "deep first" fashion. The interface is implemented by the report formatters 22 * and can be used to emit coverage report structures. 23 * 24 * The following constraints apply in using {@link IReportGroupVisitor} instances: 25 * 26 * <ul> 27 * <li>A visitor instance can be used to either submit bundles ( 28 * {@link #visitBundle(IBundleCoverage, ISourceFileLocator)}) or groups 29 * {@link #visitGroup(String)}). Bundles and groups are not allowed for the same 30 * visitor.</li> 31 * <li>When creating nested groups with {@link #visitGroup(String)} the 32 * hierarchy has to be processed in a "deep first" manner.</li> 33 * </ul> 34 */ 35 public interface IReportGroupVisitor { 36 37 /** 38 * Called to add a bundle to the the report. 39 * 40 * @param bundle 41 * a bundle to include in the report 42 * @param locator 43 * source locator for this bundle 44 * @throws IOException 45 * in case of IO problems with the report writer 46 */ visitBundle(IBundleCoverage bundle, ISourceFileLocator locator)47 void visitBundle(IBundleCoverage bundle, ISourceFileLocator locator) 48 throws IOException; 49 50 /** 51 * Called to add a new group to the report. The returned 52 * {@link IReportGroupVisitor} instance can be used to add nested bundles or 53 * groups. The content of the group has to be completed before this or any 54 * parent visitor can be used again ("deep first"). 55 * 56 * @param name 57 * name of the group 58 * @return visitor for the group's content 59 * @throws IOException 60 * in case of IO problems with the report writer 61 */ visitGroup(String name)62 IReportGroupVisitor visitGroup(String name) throws IOException; 63 64 } 65