tracesrv/tracecompiler/src/com.nokia.tracecompiler/src/com/nokia/tracecompiler/plugin/TraceAPIFormatter.java
author hgs
Fri, 08 Oct 2010 14:56:39 +0300
changeset 56 aa2539c91954
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
* Trace API formatter plug-in
hgs
parents:
diff changeset
    17
*
hgs
parents:
diff changeset
    18
*/
hgs
parents:
diff changeset
    19
package com.nokia.tracecompiler.plugin;
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
/**
hgs
parents:
diff changeset
    22
 * Trace API formatter plug-in
hgs
parents:
diff changeset
    23
 * 
hgs
parents:
diff changeset
    24
 */
hgs
parents:
diff changeset
    25
public interface TraceAPIFormatter {
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
	/**
hgs
parents:
diff changeset
    28
	 * Formatting types for traces
hgs
parents:
diff changeset
    29
	 */
hgs
parents:
diff changeset
    30
	public enum TraceFormatType {
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
		/**
hgs
parents:
diff changeset
    33
		 * Format for extension function header
hgs
parents:
diff changeset
    34
		 */
hgs
parents:
diff changeset
    35
		HEADER,
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
		/**
hgs
parents:
diff changeset
    38
		 * Format for trace buffer function. Added to extension function
hgs
parents:
diff changeset
    39
		 * definition if trace contains more data than is supported by the API
hgs
parents:
diff changeset
    40
		 */
hgs
parents:
diff changeset
    41
		TRACE_BUFFER,
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
		/**
hgs
parents:
diff changeset
    44
		 * Format for trace function if the extension function parameters can be
hgs
parents:
diff changeset
    45
		 * packed into normal trace API call. For example, if the extension
hgs
parents:
diff changeset
    46
		 * function takes 4 8-bit arguments, they are packed into a single
hgs
parents:
diff changeset
    47
		 * 32-bit parameter
hgs
parents:
diff changeset
    48
		 */
hgs
parents:
diff changeset
    49
		TRACE_PACKED,
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
		/**
hgs
parents:
diff changeset
    52
		 * Format for trace activation check function. Added to extension
hgs
parents:
diff changeset
    53
		 * function definition
hgs
parents:
diff changeset
    54
		 */
hgs
parents:
diff changeset
    55
		TRACE_ACTIVATION,
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
		/**
hgs
parents:
diff changeset
    58
		 * Empty declaration for an extension function header
hgs
parents:
diff changeset
    59
		 */
hgs
parents:
diff changeset
    60
		EMPTY_MACRO
hgs
parents:
diff changeset
    61
	}
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
	/**
hgs
parents:
diff changeset
    64
	 * Gets the name of this formatter
hgs
parents:
diff changeset
    65
	 * 
hgs
parents:
diff changeset
    66
	 * @return the name
hgs
parents:
diff changeset
    67
	 */
hgs
parents:
diff changeset
    68
	public String getName();
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
	/**
hgs
parents:
diff changeset
    71
	 * Gets the title shown in the API selection preferences dialog
hgs
parents:
diff changeset
    72
	 * 
hgs
parents:
diff changeset
    73
	 * @return the title
hgs
parents:
diff changeset
    74
	 */
hgs
parents:
diff changeset
    75
	public String getTitle();
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
	/**
hgs
parents:
diff changeset
    78
	 * Gets the trace format based on format type
hgs
parents:
diff changeset
    79
	 * 
hgs
parents:
diff changeset
    80
	 * @param type
hgs
parents:
diff changeset
    81
	 *            the format type
hgs
parents:
diff changeset
    82
	 * @return the trace format
hgs
parents:
diff changeset
    83
	 */
hgs
parents:
diff changeset
    84
	public String getTraceFormat(TraceFormatType type);
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
}