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 /**
15  * Interface to create programming language specific names from VM names.
16  */
17 public interface ILanguageNames {
18 
19 	/**
20 	 * Calculates the language specific name of a package.
21 	 *
22 	 * @param vmname
23 	 *            vm name of a package
24 	 * @return language specific notation for the package
25 	 */
getPackageName(String vmname)26 	public String getPackageName(String vmname);
27 
28 	/**
29 	 * Calculates the language specific name of a class.
30 	 *
31 	 * @param vmname
32 	 *            vm name of a class
33 	 * @param vmsignature
34 	 *            vm signature of the class (may be <code>null</code>)
35 	 * @param vmsuperclass
36 	 *            vm name of the superclass of the class (may be
37 	 *            <code>null</code>)
38 	 * @param vminterfaces
39 	 *            vm names of interfaces of the class (may be <code>null</code>)
40 	 * @return language specific notation of the class
41 	 */
getClassName(String vmname, String vmsignature, String vmsuperclass, String[] vminterfaces)42 	public String getClassName(String vmname, String vmsignature,
43 			String vmsuperclass, String[] vminterfaces);
44 
45 	/**
46 	 * Calculates the language specific qualified name of a class.
47 	 *
48 	 * @param vmname
49 	 *            vm name of a class
50 	 * @return language specific qualified notation of the class
51 	 */
getQualifiedClassName(String vmname)52 	public String getQualifiedClassName(String vmname);
53 
54 	/**
55 	 * Calculates the language specific name of a method.
56 	 *
57 	 * @param vmclassname
58 	 *            vm name of a containing class
59 	 * @param vmmethodname
60 	 *            vm name of the method
61 	 * @param vmdesc
62 	 *            vm method descriptor
63 	 * @param vmsignature
64 	 *            vm signature of the method (may be <code>null</code>)
65 	 * @return language specific notation for the method
66 	 */
getMethodName(String vmclassname, String vmmethodname, String vmdesc, String vmsignature)67 	public String getMethodName(String vmclassname, String vmmethodname,
68 			String vmdesc, String vmsignature);
69 
70 	/**
71 	 * Calculates the language specific fully qualified name of a method.
72 	 *
73 	 * @param vmclassname
74 	 *            vm name of a containing class
75 	 * @param vmmethodname
76 	 *            vm name of the method
77 	 * @param vmdesc
78 	 *            vm method descriptor
79 	 * @param vmsignature
80 	 *            vm signature of the method (may be <code>null</code>)
81 	 * @return language specific notation for the method
82 	 */
getQualifiedMethodName(String vmclassname, String vmmethodname, String vmdesc, String vmsignature)83 	public String getQualifiedMethodName(String vmclassname,
84 			String vmmethodname, String vmdesc, String vmsignature);
85 
86 }
87