Commit | Line | Data |
---|---|---|
c3c5c786 FC |
1 | /*******************************************************************************\r |
2 | * Copyright (c) 2010 Ericsson\r | |
3 | * \r | |
4 | * All rights reserved. This program and the accompanying materials are\r | |
5 | * made available under the terms of the Eclipse Public License v1.0 which\r | |
6 | * accompanies this distribution, and is available at\r | |
7 | * http://www.eclipse.org/legal/epl-v10.html\r | |
8 | * \r | |
9 | * Contributors:\r | |
10 | * Patrick Tasse - Initial API and implementation\r | |
11 | *******************************************************************************/\r | |
12 | \r | |
13 | package org.eclipse.linuxtools.tmf.ui.parsers.custom;\r | |
14 | \r | |
15 | import java.text.ParseException;\r | |
16 | import java.text.SimpleDateFormat;\r | |
17 | import java.util.Date;\r | |
18 | import java.util.HashMap;\r | |
19 | import java.util.Map;\r | |
20 | \r | |
6c13869b FC |
21 | import org.eclipse.linuxtools.tmf.core.event.TmfEvent;\r |
22 | import org.eclipse.linuxtools.tmf.core.event.TmfEventReference;\r | |
23 | import org.eclipse.linuxtools.tmf.core.event.TmfEventSource;\r | |
24 | import org.eclipse.linuxtools.tmf.core.event.TmfEventType;\r | |
25 | import org.eclipse.linuxtools.tmf.core.event.TmfTimestamp;\r | |
26 | import org.eclipse.linuxtools.tmf.core.trace.ITmfTrace;\r | |
c3c5c786 FC |
27 | import org.eclipse.linuxtools.tmf.ui.parsers.custom.CustomTraceDefinition.OutputColumn;\r |
28 | \r | |
29 | public class CustomEvent extends TmfEvent {\r | |
30 | \r | |
3b38ea61 FC |
31 | protected static final String TIMESTAMP_INPUT_FORMAT_KEY = "CE_TS_I_F"; //$NON-NLS-1$\r |
32 | protected static final String NO_MESSAGE = ""; //$NON-NLS-1$\r | |
c3c5c786 FC |
33 | public static final byte TIMESTAMP_SCALE = -3;\r |
34 | \r | |
35 | protected CustomTraceDefinition fDefinition;\r | |
36 | protected Map<String, String> fData;\r | |
37 | private String[] fColumnData;\r | |
38 | \r | |
4bf17f4a | 39 | public CustomEvent(CustomTraceDefinition definition) {\r |
40 | fDefinition = definition;\r | |
41 | fData = new HashMap<String, String>();\r | |
42 | }\r | |
43 | \r | |
c3c5c786 FC |
44 | public CustomEvent(CustomTraceDefinition definition, TmfEvent other) {\r |
45 | super(other);\r | |
46 | fDefinition = definition;\r | |
47 | fData = new HashMap<String, String>();\r | |
48 | }\r | |
49 | \r | |
4bf17f4a | 50 | public CustomEvent(CustomTraceDefinition definition, ITmfTrace<?> parentTrace, TmfTimestamp timestamp, TmfEventSource source, TmfEventType type, TmfEventReference reference) {\r |
51 | super(parentTrace, timestamp, source, type, reference);\r | |
c3c5c786 FC |
52 | fDefinition = definition;\r |
53 | fData = new HashMap<String, String>();\r | |
54 | }\r | |
55 | \r | |
56 | public CustomEvent(CustomTraceDefinition definition, TmfTimestamp originalTS, TmfTimestamp effectiveTS, TmfEventSource source, TmfEventType type, TmfEventReference reference) {\r | |
57 | super(originalTS, effectiveTS, source, type, reference);\r | |
58 | fDefinition = definition;\r | |
59 | fData = new HashMap<String, String>();\r | |
60 | }\r | |
61 | \r | |
62 | @Override\r | |
63 | public TmfTimestamp getTimestamp() {\r | |
64 | if (fData != null) processData();\r | |
65 | return super.getTimestamp();\r | |
66 | }\r | |
67 | \r | |
68 | @Override\r | |
69 | public TmfTimestamp getOriginalTimestamp() {\r | |
70 | if (fData != null) processData();\r | |
71 | return super.getOriginalTimestamp();\r | |
72 | }\r | |
73 | \r | |
c3c5c786 FC |
74 | public String[] extractItemFields() {\r |
75 | if (fData != null) processData();\r | |
76 | return fColumnData;\r | |
77 | }\r | |
78 | \r | |
79 | private void processData() {\r | |
80 | String timeStampString = fData.get(CustomTraceDefinition.TAG_TIMESTAMP);\r | |
81 | String timeStampInputFormat = fData.get(TIMESTAMP_INPUT_FORMAT_KEY);\r | |
82 | Date date = null;\r | |
83 | if (timeStampInputFormat != null && timeStampString != null) {\r | |
84 | SimpleDateFormat dateFormat = new SimpleDateFormat(timeStampInputFormat);\r | |
85 | try {\r | |
86 | date = dateFormat.parse(timeStampString);\r | |
87 | fOriginalTimestamp = fEffectiveTimestamp = new TmfTimestamp(date.getTime(), TIMESTAMP_SCALE);\r | |
88 | } catch (ParseException e) {\r | |
89 | fOriginalTimestamp = fEffectiveTimestamp = TmfTimestamp.Zero;\r | |
90 | }\r | |
91 | } else {\r | |
92 | fOriginalTimestamp = fEffectiveTimestamp = TmfTimestamp.Zero;\r | |
93 | }\r | |
94 | \r | |
95 | int i = 0;\r | |
96 | fColumnData = new String[fDefinition.outputs.size()];\r | |
97 | for (OutputColumn outputColumn : fDefinition.outputs) {\r | |
98 | String value = fData.get(outputColumn.name);\r | |
99 | if (outputColumn.name.equals(CustomTraceDefinition.TAG_TIMESTAMP) && date != null) {\r | |
100 | SimpleDateFormat dateFormat = new SimpleDateFormat(fDefinition.timeStampOutputFormat);\r | |
101 | fColumnData[i++] = dateFormat.format(date);\r | |
102 | } else {\r | |
d7fcacc9 | 103 | fColumnData[i++] = (value != null ? value : ""); //$NON-NLS-1$\r |
c3c5c786 FC |
104 | }\r |
105 | }\r | |
c3c5c786 FC |
106 | fData = null;\r |
107 | }\r | |
108 | }\r |