1 /*******************************************************************************
2  * Copyright (c) 2009, 2015 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 com.vladium.emma.rt;
13 
14 import java.io.File;
15 import java.io.FileOutputStream;
16 import java.io.IOException;
17 import java.io.OutputStream;
18 
19 /**
20  * Compatibility layer for the EMMA runtime which allows to trigger dumps
21  * through EMMA APIs. Note that even this class emulates an EMMA API the files
22  * written are in JaCoCo execution data format.
23  *
24  * @deprecated Use {@link org.jacoco.agent.rt.IAgent} instead.
25  */
26 @Deprecated
27 public final class RT {
28 
RT()29 	private RT() {
30 	}
31 
32 	/**
33 	 * Writes the current execution data to the given file in JaCoCo execution
34 	 * data format.
35 	 *
36 	 * @param outFile
37 	 *            file to write execution data to
38 	 * @param merge
39 	 *            if <code>true</code>, execution data is appended to an
40 	 *            existing file
41 	 * @param stopDataCollection
42 	 *            ignored
43 	 * @throws IOException
44 	 *             in case of problems with the file output
45 	 */
46 	@SuppressWarnings("unused")
dumpCoverageData(final File outFile, final boolean merge, final boolean stopDataCollection)47 	public static void dumpCoverageData(final File outFile,
48 			final boolean merge, final boolean stopDataCollection)
49 			throws IOException {
50 		final OutputStream out = new FileOutputStream(outFile, merge);
51 		try {
52 			out.write(org.jacoco.agent.rt.RT.getAgent().getExecutionData(false));
53 		} finally {
54 			out.close();
55 		}
56 	}
57 
58 	/**
59 	 * Writes the current execution data to the given file in JaCoCo execution
60 	 * data format. If the file already exists new data is appended.
61 	 *
62 	 * @param outFile
63 	 *            file to write execution data to
64 	 * @param stopDataCollection
65 	 *            ignored
66 	 * @throws IOException
67 	 *             in case of problems with the file output
68 	 */
dumpCoverageData(final File outFile, final boolean stopDataCollection)69 	public static synchronized void dumpCoverageData(final File outFile,
70 			final boolean stopDataCollection) throws IOException {
71 		dumpCoverageData(outFile, true, stopDataCollection);
72 	}
73 
74 }
75