1 /*******************************************************************************
2 * Copyright (c) 2012, 2014 Ericsson
4 * All rights reserved. This program and the accompanying materials are made
5 * available under the terms of the Eclipse Public License v1.0 which
6 * accompanies this distribution, and is available at
7 * http://www.eclipse.org/legal/epl-v10.html
10 * Matthew Khouzam - Initial API and implementation
11 * Simon Delisle - Remove the iterator in dispose()
12 *******************************************************************************/
14 package org
.eclipse
.tracecompass
.tmf
.ctf
.core
.context
;
16 import org
.eclipse
.tracecompass
.internal
.tmf
.ctf
.core
.trace
.iterator
.CtfIterator
;
17 import org
.eclipse
.tracecompass
.tmf
.core
.trace
.ITmfContext
;
18 import org
.eclipse
.tracecompass
.tmf
.core
.trace
.location
.ITmfLocation
;
19 import org
.eclipse
.tracecompass
.tmf
.ctf
.core
.event
.CtfTmfEvent
;
20 import org
.eclipse
.tracecompass
.tmf
.ctf
.core
.trace
.CtfTmfTrace
;
23 * Lightweight Context for CtfTmf traces. Should only use 3 references, 1 ref to
24 * a boxed Long, a long and an int.
26 * @author Matthew Khouzam
28 public class CtfTmfContext
implements ITmfContext
{
30 // -------------------------------------------
32 // -------------------------------------------
34 private CtfLocation fCurLocation
;
35 private long fCurRank
;
37 private final CtfTmfTrace fTrace
;
39 // -------------------------------------------
41 // -------------------------------------------
49 public CtfTmfContext(CtfTmfTrace ctfTmfTrace
) {
51 fCurLocation
= new CtfLocation(new CtfLocationInfo(0, 0));
54 // -------------------------------------------
55 // TmfContext Overrides
56 // -------------------------------------------
59 public long getRank() {
64 public synchronized ITmfLocation
getLocation() {
69 public boolean hasValidRank() {
70 return fCurRank
!= CtfLocation
.INVALID_LOCATION
.getTimestamp();
74 public synchronized void setLocation(ITmfLocation location
) {
75 fCurLocation
= (CtfLocation
) location
;
76 if (fCurLocation
!= null) {
77 getIterator().seek(fCurLocation
.getLocationInfo());
82 public void setRank(long rank
) {
88 public void increaseRank() {
94 // -------------------------------------------
95 // CtfTmfTrace Helpers
96 // -------------------------------------------
99 * Gets the trace of this context.
101 * @return The trace of this context
103 public CtfTmfTrace
getTrace() {
108 * Gets the current event. Wrapper to help CtfTmfTrace
110 * @return The event or null
112 public synchronized CtfTmfEvent
getCurrentEvent() {
113 return getIterator().getCurrentEvent();
117 * Advances to a the next event. Wrapper to help CtfTmfTrace
119 * @return success or not
121 public synchronized boolean advance() {
122 final CtfLocationInfo curLocationData
= fCurLocation
.getLocationInfo();
123 CtfIterator iterator
= getIterator();
124 boolean retVal
= iterator
.advance();
125 CtfTmfEvent currentEvent
= iterator
.getCurrentEvent();
127 if (currentEvent
!= null) {
128 final long timestampValue
= iterator
.getCurrentTimestamp();
129 if (curLocationData
.getTimestamp() == timestampValue
) {
130 fCurLocation
= new CtfLocation(timestampValue
, curLocationData
.getIndex() + 1);
132 fCurLocation
= new CtfLocation(timestampValue
, 0L);
135 fCurLocation
= new CtfLocation(CtfLocation
.INVALID_LOCATION
);
142 public void dispose() {
143 fTrace
.disposeContext(this);
147 * Seeks to a given timestamp. Wrapper to help CtfTmfTrace
151 * @return success or not
153 public synchronized boolean seek(final long timestamp
) {
154 fCurLocation
= new CtfLocation(timestamp
, 0);
155 return getIterator().seek(timestamp
);
159 * Seeks to a given location. Wrapper to help CtfTmfTrace
161 * unique location to find the event.
163 * @return success or not
165 public synchronized boolean seek(final CtfLocationInfo location
) {
166 fCurLocation
= new CtfLocation(location
);
167 return getIterator().seek(location
);
170 // -------------------------------------------
172 // -------------------------------------------
175 * Get iterator, called every time to get an iterator, no local copy is
176 * stored so that there is no need to "update"
178 * @return an iterator
180 private CtfIterator
getIterator() {
181 return (CtfIterator
) fTrace
.createIteratorFromContext(this);