1 /*******************************************************************************
2 * Copyright (c) 2010 Ericsson
4 * All rights reserved. This program and the accompanying materials are
5 * made 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 * Patrick Tasse - Initial API and implementation
11 *******************************************************************************/
13 package org
.eclipse
.linuxtools
.tmf
.ui
.views
.timechart
;
15 import java
.util
.ArrayList
;
16 import java
.util
.HashMap
;
17 import java
.util
.Iterator
;
20 import org
.eclipse
.core
.resources
.IMarker
;
21 import org
.eclipse
.core
.resources
.IMarkerDelta
;
22 import org
.eclipse
.core
.resources
.IResource
;
23 import org
.eclipse
.core
.resources
.IResourceChangeEvent
;
24 import org
.eclipse
.core
.resources
.IResourceChangeListener
;
25 import org
.eclipse
.core
.resources
.IResourceDelta
;
26 import org
.eclipse
.core
.resources
.ResourcesPlugin
;
27 import org
.eclipse
.linuxtools
.tmf
.event
.TmfEvent
;
28 import org
.eclipse
.linuxtools
.tmf
.event
.TmfTimestamp
;
29 import org
.eclipse
.linuxtools
.tmf
.filter
.ITmfFilter
;
30 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfSignalHandler
;
31 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfTimeSynchSignal
;
32 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfTraceSelectedSignal
;
33 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfTraceUpdatedSignal
;
34 import org
.eclipse
.linuxtools
.tmf
.trace
.ITmfTrace
;
35 import org
.eclipse
.linuxtools
.tmf
.trace
.TmfContext
;
36 import org
.eclipse
.linuxtools
.tmf
.ui
.editors
.ITmfTraceEditor
;
37 import org
.eclipse
.linuxtools
.tmf
.ui
.signal
.TmfTraceClosedSignal
;
38 import org
.eclipse
.linuxtools
.tmf
.ui
.signal
.TmfTraceOpenedSignal
;
39 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.TmfViewerFactory
;
40 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.events
.ITmfEventsFilterListener
;
41 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.events
.ITmfEventsFilterProvider
;
42 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.ITimeAnalysisViewer
;
43 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.ITmfTimeScaleSelectionListener
;
44 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.ITmfTimeSelectionListener
;
45 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.TmfTimeScaleSelectionEvent
;
46 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.TmfTimeSelectionEvent
;
47 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.model
.ITimeEvent
;
48 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.model
.ITmfTimeAnalysisEntry
;
49 import org
.eclipse
.linuxtools
.tmf
.ui
.views
.TmfView
;
50 import org
.eclipse
.linuxtools
.tmf
.ui
.views
.colors
.ColorSetting
;
51 import org
.eclipse
.linuxtools
.tmf
.ui
.views
.colors
.ColorSettingsManager
;
52 import org
.eclipse
.linuxtools
.tmf
.ui
.views
.colors
.IColorSettingsListener
;
53 import org
.eclipse
.linuxtools
.tmf
.ui
.views
.timechart
.TimeChartEvent
.RankRange
;
54 import org
.eclipse
.swt
.SWT
;
55 import org
.eclipse
.swt
.layout
.GridLayout
;
56 import org
.eclipse
.swt
.widgets
.Composite
;
57 import org
.eclipse
.swt
.widgets
.Display
;
58 import org
.eclipse
.ui
.IEditorPart
;
59 import org
.eclipse
.ui
.IEditorReference
;
61 public class TimeChartView
extends TmfView
implements ITmfTimeScaleSelectionListener
, ITmfTimeSelectionListener
, IColorSettingsListener
,
62 IResourceChangeListener
, ITmfEventsFilterListener
{
64 public static final String ID
= "org.eclipse.linuxtools.tmf.ui.views.timechart"; //$NON-NLS-1$
66 private static final byte TIMESTAMP_SCALE
= -9;
68 private final int fDisplayWidth
;
69 private Composite fComposite
;
70 private ITimeAnalysisViewer fViewer
;
71 private final ArrayList
<TimeChartAnalysisEntry
> fTimeAnalysisEntries
= new ArrayList
<TimeChartAnalysisEntry
>();
72 private final Map
<ITmfTrace
, TimeChartDecorationProvider
> fDecorationProviders
= new HashMap
<ITmfTrace
, TimeChartDecorationProvider
>();
73 private ArrayList
<DecorateThread
> fDecorateThreads
;
74 private long fStartTime
= 0;
75 private long fStopTime
= Long
.MAX_VALUE
;
76 private boolean fRefreshBusy
= false;
77 private boolean fRefreshPending
= false;
78 private final Object fSyncObj
= new Object();
80 public TimeChartView() {
81 super("Time Chart"); //$NON-NLS-1$
82 fDisplayWidth
= Display
.getDefault().getBounds().width
;
86 public void createPartControl(Composite parent
) {
87 fComposite
= new Composite(parent
, SWT
.NONE
);
88 GridLayout gl
= new GridLayout();
91 fComposite
.setLayout(gl
);
93 fViewer
= TmfViewerFactory
.createViewer(fComposite
, new TimeChartAnalysisProvider());
94 fViewer
.groupTraces(false);
95 fViewer
.setTimeCalendarFormat(true);
96 fViewer
.setAcceptSelectionAPIcalls(true);
97 fViewer
.addWidgetTimeScaleSelectionListner(this);
98 fViewer
.addWidgetSelectionListner(this);
99 fViewer
.setMinimumItemWidth(1);
101 IEditorReference
[] editorReferences
= getSite().getPage().getEditorReferences();
102 for (IEditorReference editorReference
: editorReferences
) {
103 IEditorPart editor
= editorReference
.getEditor(false);
104 if (editor
instanceof ITmfTraceEditor
) {
105 ITmfTrace trace
= ((ITmfTraceEditor
) editor
).getTrace();
107 IResource resource
= ((ITmfTraceEditor
) editor
).getResource();
108 TimeChartAnalysisEntry timeAnalysisEntry
= new TimeChartAnalysisEntry(trace
, fDisplayWidth
* 2);
109 fTimeAnalysisEntries
.add(timeAnalysisEntry
);
110 fDecorationProviders
.put(trace
, new TimeChartDecorationProvider(resource
));
111 Thread thread
= new ProcessTraceThread(timeAnalysisEntry
);
116 fViewer
.display(fTimeAnalysisEntries
.toArray(new TimeChartAnalysisEntry
[0]));
118 fDecorateThreads
= new ArrayList
<DecorateThread
>();
119 ColorSettingsManager
.addColorSettingsListener(this);
120 ResourcesPlugin
.getWorkspace().addResourceChangeListener(this, IResourceChangeEvent
.POST_CHANGE
);
124 public void dispose() {
125 ResourcesPlugin
.getWorkspace().removeResourceChangeListener(this);
126 for (DecorateThread thread
: fDecorateThreads
) {
129 ColorSettingsManager
.removeColorSettingsListener(this);
134 public void setFocus() {
139 private class ProcessTraceThread
extends Thread
{
141 private final TimeChartAnalysisEntry fTimeAnalysisEntry
;
143 public ProcessTraceThread(TimeChartAnalysisEntry timeAnalysisEntry
) {
144 super("ProcessTraceJob:" + timeAnalysisEntry
.getName()); //$NON-NLS-1$
145 fTimeAnalysisEntry
= timeAnalysisEntry
;
150 updateTraceEntry(fTimeAnalysisEntry
, Long
.MAX_VALUE
, 0, Long
.MAX_VALUE
);
154 private void updateTraceEntry(TimeChartAnalysisEntry timeAnalysisEntry
, long stopRank
, long startTime
, long stopTime
) {
155 ITmfTrace trace
= timeAnalysisEntry
.getTrace();
156 TimeChartDecorationProvider decorationProvider
= fDecorationProviders
.get(trace
);
157 if (decorationProvider
== null) {
158 return; // the trace has been closed
160 TmfContext context
= null;
161 // TmfTimestamp lastTimestamp = null;
162 boolean done
= false;
164 synchronized (timeAnalysisEntry
) {
165 if (timeAnalysisEntry
.getLastRank() >= trace
.getNbEvents()) {
169 if (context
== null || context
.getRank() != timeAnalysisEntry
.getLastRank()) {
170 if (context
!= null) {
173 if (timeAnalysisEntry
.getLastRank() != -1) {
174 context
= trace
.seekEvent(timeAnalysisEntry
.getLastRank());
176 // context = trace.seekLocation(null);
177 context
= trace
.seekEvent(0);
181 long rank
= context
.getRank();
182 TmfEvent event
= trace
.getNextEvent(context
);
187 // if (!event.getTimestamp().equals(lastTimestamp)) {
188 TimeChartEvent timeEvent
= new TimeChartEvent(timeAnalysisEntry
, event
, rank
, decorationProvider
);
189 if (timeEvent
.getTime() >= startTime
&& timeEvent
.getTime() <= stopTime
) {
190 timeAnalysisEntry
.addTraceEvent(timeEvent
);
192 // lastTimestamp = event.getTimestamp();
193 // } *** commented out so that color setting priority gets
194 // set even if the event has same time
195 if (context
.getRank() == trace
.getNbEvents() || context
.getRank() == stopRank
) {
199 if (context
.getRank() % trace
.getCacheSize() == 1) {
200 // break for UI refresh
204 // timeAnalysisEntry.setLastRank(Math.min(trace.getNbEvents(),
206 timeAnalysisEntry
.setLastRank(context
.getRank());
208 refreshViewer(false);
210 if (context
!= null) {
215 private void refreshViewer(boolean resetTimeIntervals
) {
216 if (fComposite
== null) {
219 synchronized (fSyncObj
) {
221 fRefreshPending
= true;
227 final boolean reset
= resetTimeIntervals
;
228 // Perform the refresh on the UI thread
229 Display
.getDefault().asyncExec(new Runnable() {
232 if (fComposite
.isDisposed())
234 fViewer
.display(fTimeAnalysisEntries
.toArray(new TimeChartAnalysisEntry
[0]));
236 fViewer
.resetStartFinishTime();
238 synchronized (fSyncObj
) {
239 fRefreshBusy
= false;
240 if (fRefreshPending
) {
241 fRefreshPending
= false;
242 refreshViewer(reset
);
249 private void itemize(long startTime
, long stopTime
) {
250 for (int i
= 0; i
< fTimeAnalysisEntries
.size(); i
++) {
251 Thread thread
= new ItemizeThread(fTimeAnalysisEntries
.get(i
), startTime
, stopTime
);
256 private class ItemizeThread
extends Thread
{
258 private final TimeChartAnalysisEntry fTimeAnalysisEntry
;
259 private final long fStartTime
;
260 private final long fStopTime
;
261 private final long fMaxDuration
;
263 private ItemizeThread(TimeChartAnalysisEntry timeAnalysisEntry
, long startTime
, long stopTime
) {
264 super("Itemize Thread:" + timeAnalysisEntry
.getName()); //$NON-NLS-1$
265 fTimeAnalysisEntry
= timeAnalysisEntry
;
266 fStartTime
= startTime
;
267 fStopTime
= stopTime
;
268 fMaxDuration
= 3 * (fStopTime
- fStartTime
) / fDisplayWidth
;
273 itemizeTraceEntry(fTimeAnalysisEntry
);
276 public void itemizeTraceEntry(TimeChartAnalysisEntry timeAnalysisEntry
) {
277 Iterator
<ITimeEvent
> iterator
= timeAnalysisEntry
.getTraceEventsIterator();
278 TimeChartEvent event
= null;
279 boolean hasNext
= true;
281 synchronized (timeAnalysisEntry
) {
282 while (hasNext
= iterator
.hasNext()) {
283 event
= (TimeChartEvent
) iterator
.next();
284 if (event
.getTime() + event
.getDuration() > fStartTime
&& event
.getTime() < fStopTime
&& event
.getDuration() > fMaxDuration
285 && event
.getNbEvents() > 1) {
291 if (event
.getItemizedEntry() == null) {
294 itemizeTraceEntry(event
.getItemizedEntry());
300 public void itemizeEvent(TimeChartEvent event
) {
301 synchronized (event
) {
302 if (event
.isItemizing()) {
305 event
.setItemizing(true);
307 TimeChartAnalysisEntry timeAnalysisEntry
= new TimeChartAnalysisEntry(fTimeAnalysisEntry
.getTrace(), (int) Math
.min(
308 event
.getNbEvents() + 1, fDisplayWidth
* 2));
309 synchronized (event
.getRankRangeList()) {
310 for (RankRange range
: event
.getRankRangeList()) {
311 timeAnalysisEntry
.setLastRank(range
.getFirstRank());
312 updateTraceEntry(timeAnalysisEntry
, range
.getLastRank() + 1, event
.getTime(), event
.getTime() + event
.getDuration());
315 event
.setItemizedEntry(timeAnalysisEntry
);
316 refreshViewer(false);
317 itemizeTraceEntry(timeAnalysisEntry
);
318 synchronized (event
) {
319 event
.setItemizing(false);
324 private void redecorate() {
325 synchronized (fDecorateThreads
) {
326 for (DecorateThread thread
: fDecorateThreads
) {
329 fDecorateThreads
.clear();
330 for (int i
= 0; i
< fTimeAnalysisEntries
.size(); i
++) {
331 DecorateThread thread
= new DecorateThread(fTimeAnalysisEntries
.get(i
));
333 fDecorateThreads
.add(thread
);
338 private class DecorateThread
extends Thread
{
339 private volatile boolean interrupted
= false;
340 private final TimeChartAnalysisEntry fTimeAnalysisEntry
;
341 private final TimeChartDecorationProvider fDecorationProvider
;
342 private TmfContext fContext
;
343 private int fCount
= 0;
345 private DecorateThread(TimeChartAnalysisEntry timeAnalysisEntry
) {
346 super("Decorate Thread:" + timeAnalysisEntry
.getName()); //$NON-NLS-1$
347 fTimeAnalysisEntry
= timeAnalysisEntry
;
348 fDecorationProvider
= fDecorationProviders
.get(timeAnalysisEntry
.getTrace());
353 resetTraceEntry(fTimeAnalysisEntry
);
354 refreshViewer(false);
355 decorateTraceEntry(fTimeAnalysisEntry
, null);
356 refreshViewer(false);
357 synchronized (fDecorateThreads
) {
358 fDecorateThreads
.remove(this);
362 public void resetTraceEntry(TimeChartAnalysisEntry timeAnalysisEntry
) {
363 Iterator
<ITimeEvent
> iterator
= timeAnalysisEntry
.getTraceEventsIterator();
364 TimeChartEvent event
= null;
365 boolean hasNext
= true;
366 while (!interrupted
&& hasNext
) {
367 synchronized (timeAnalysisEntry
) {
368 while (hasNext
= iterator
.hasNext()) {
369 event
= (TimeChartEvent
) iterator
.next();
374 // TODO possible concurrency problem here with ItemizeJob
375 event
.setColorSettingPriority(ColorSettingsManager
.PRIORITY_NONE
);
376 if (event
.getItemizedEntry() != null) {
377 resetTraceEntry(event
.getItemizedEntry());
383 public void decorateTraceEntry(TimeChartAnalysisEntry timeAnalysisEntry
, TimeChartEvent parentEvent
) {
384 // Set max duration high to ensure iterator does not consider
386 Iterator
<ITimeEvent
> iterator
= timeAnalysisEntry
.getTraceEventsIterator(0, Long
.MAX_VALUE
, Long
.MAX_VALUE
);
387 TimeChartEvent event
= null;
388 int entryPriority
= ColorSettingsManager
.PRIORITY_NONE
;
389 boolean entryIsBookmarked
= false;
390 boolean entryIsVisible
= false;
391 boolean entryIsSearchMatch
= false;
392 boolean hasNext
= true;
393 while (!interrupted
&& hasNext
) {
394 synchronized (timeAnalysisEntry
) {
395 while (hasNext
= iterator
.hasNext()) {
396 event
= (TimeChartEvent
) iterator
.next();
401 // TODO possible concurrency problem here with ItemizeJob
402 if (event
.getItemizedEntry() == null) {
403 decorateEvent(event
);
405 decorateTraceEntry(event
.getItemizedEntry(), event
);
407 entryPriority
= Math
.min(entryPriority
, event
.getColorSettingPriority());
408 entryIsBookmarked
|= event
.isBookmarked();
409 entryIsVisible
|= event
.isVisible();
410 entryIsSearchMatch
|= event
.isSearchMatch();
411 if (++fCount
% timeAnalysisEntry
.getTrace().getCacheSize() == 0) {
412 refreshViewer(false);
416 if (parentEvent
!= null) {
417 parentEvent
.setColorSettingPriority(entryPriority
);
418 parentEvent
.setIsBookmarked(entryIsBookmarked
);
419 parentEvent
.setIsVisible(entryIsVisible
);
420 parentEvent
.setIsSearchMatch(entryIsSearchMatch
);
424 public void decorateEvent(TimeChartEvent timeChartEvent
) {
425 // TODO possible concurrency problem here with ItemizeJob
426 TimeChartAnalysisEntry timeAnalysisEntry
= (TimeChartAnalysisEntry
) timeChartEvent
.getEntry();
427 ITmfTrace trace
= timeAnalysisEntry
.getTrace();
428 int priority
= ColorSettingsManager
.PRIORITY_NONE
;
429 boolean isBookmarked
= false;
430 boolean isVisible
= false;
431 boolean isSearchMatch
= false;
432 synchronized (timeChartEvent
.getRankRangeList()) {
433 for (RankRange range
: timeChartEvent
.getRankRangeList()) {
436 if (fContext
== null || fContext
.getRank() != range
.getFirstRank()) {
437 fContext
= trace
.seekEvent(range
.getFirstRank());
438 fContext
.setRank(range
.getFirstRank());
443 long rank
= fContext
.getRank();
444 TmfEvent event
= trace
.getNextEvent(fContext
);
448 long eventTime
= event
.getTimestamp().synchronize(0, (byte) -9).getValue();
449 if (eventTime
>= timeChartEvent
.getTime() && eventTime
<= timeChartEvent
.getTime() + timeChartEvent
.getDuration()) {
450 priority
= Math
.min(priority
, ColorSettingsManager
.getColorSettingPriority(event
));
452 isBookmarked
|= fDecorationProvider
.isBookmark(rank
);
453 isVisible
|= fDecorationProvider
.isVisible(event
);
454 isSearchMatch
|= fDecorationProvider
.isSearchMatch(event
);
455 if (fContext
.getRank() > range
.getLastRank()) {
461 timeChartEvent
.setColorSettingPriority(priority
);
462 timeChartEvent
.setIsBookmarked(isBookmarked
);
463 timeChartEvent
.setIsVisible(isVisible
);
464 timeChartEvent
.setIsSearchMatch(isSearchMatch
);
467 public void cancel() {
472 // ------------------------------------------------------------------------
474 // ------------------------------------------------------------------------
477 public void tsfTmProcessTimeScaleEvent(TmfTimeScaleSelectionEvent event
) {
478 fStartTime
= event
.getTime0();
479 fStopTime
= event
.getTime1();
480 itemize(fStartTime
, fStopTime
);
484 public void tsfTmProcessSelEvent(TmfTimeSelectionEvent event
) {
485 ITmfTimeAnalysisEntry timeAnalysisEntry
= null;
486 if (event
.getSelection() instanceof TimeChartAnalysisEntry
) {
487 timeAnalysisEntry
= (TimeChartAnalysisEntry
) event
.getSelection();
488 } else if (event
.getSelection() instanceof TimeChartEvent
) {
489 timeAnalysisEntry
= ((TimeChartEvent
) event
.getSelection()).getEntry();
491 if (timeAnalysisEntry
instanceof TimeChartAnalysisEntry
) {
492 broadcast(new TmfTraceSelectedSignal(this, ((TimeChartAnalysisEntry
) timeAnalysisEntry
).getTrace()));
494 broadcast(new TmfTimeSynchSignal(this, new TmfTimestamp(event
.getSelectedTime(), TIMESTAMP_SCALE
)));
498 public void colorSettingsChanged(ColorSetting
[] colorSettings
) {
503 public void resourceChanged(IResourceChangeEvent event
) {
504 for (IMarkerDelta delta
: event
.findMarkerDeltas(IMarker
.BOOKMARK
, false)) {
505 for (TimeChartDecorationProvider provider
: fDecorationProviders
.values()) {
506 if (delta
.getResource().equals(provider
.getResource())) {
507 if (delta
.getKind() == IResourceDelta
.CHANGED
&& delta
.getMarker().getAttribute(IMarker
.LOCATION
, -1) != -1) {
508 provider
.refreshBookmarks();
509 } else if (delta
.getKind() == IResourceDelta
.REMOVED
) {
510 provider
.refreshBookmarks();
519 public void filterApplied(ITmfFilter filter
, ITmfTrace trace
) {
520 TimeChartDecorationProvider decorationProvider
= fDecorationProviders
.get(trace
);
521 decorationProvider
.filterApplied(filter
);
526 public void searchApplied(ITmfFilter filter
, ITmfTrace trace
) {
527 TimeChartDecorationProvider decorationProvider
= fDecorationProviders
.get(trace
);
528 decorationProvider
.searchApplied(filter
);
532 // ------------------------------------------------------------------------
534 // ------------------------------------------------------------------------
537 public void traceOpened(TmfTraceOpenedSignal signal
) {
538 if (fTimeAnalysisEntries
== null)
540 final ITmfTrace trace
= signal
.getTrace();
541 final IResource resource
= signal
.getResource();
542 final ITmfEventsFilterProvider eventsFilterProvider
= signal
.getEventsFilterProvider();
543 TimeChartAnalysisEntry timeAnalysisEntry
= null;
544 for (int i
= 0; i
< fTimeAnalysisEntries
.size(); i
++) {
545 if (fTimeAnalysisEntries
.get(i
).getTrace().equals(trace
)) {
546 timeAnalysisEntry
= fTimeAnalysisEntries
.get(i
);
550 if (timeAnalysisEntry
== null) {
551 timeAnalysisEntry
= new TimeChartAnalysisEntry(trace
, fDisplayWidth
* 2);
552 fTimeAnalysisEntries
.add(timeAnalysisEntry
);
553 fDecorationProviders
.put(trace
, new TimeChartDecorationProvider(resource
));
554 Thread thread
= new ProcessTraceThread(timeAnalysisEntry
);
558 if (eventsFilterProvider
!= null) {
559 eventsFilterProvider
.addEventsFilterListener(this);
564 public void traceClosed(TmfTraceClosedSignal signal
) {
565 if (fTimeAnalysisEntries
== null)
567 final ITmfTrace trace
= signal
.getTrace();
568 for (int i
= 0; i
< fTimeAnalysisEntries
.size(); i
++) {
569 if (fTimeAnalysisEntries
.get(i
).getTrace().equals(trace
)) {
570 fTimeAnalysisEntries
.remove(i
);
571 fDecorationProviders
.remove(trace
);
579 public void traceSelected(TmfTraceSelectedSignal signal
) {
580 if (signal
.getSource() != this && fTimeAnalysisEntries
!= null) {
581 ITmfTrace trace
= signal
.getTrace();
582 for (int i
= 0; i
< fTimeAnalysisEntries
.size(); i
++) {
583 if (fTimeAnalysisEntries
.get(i
).getTrace().equals(trace
)) {
584 fViewer
.setSelectedTrace(fTimeAnalysisEntries
.get(i
));
592 public void traceUpdated(TmfTraceUpdatedSignal signal
) {
593 if (fTimeAnalysisEntries
== null)
595 final ITmfTrace trace
= signal
.getTrace();
596 for (int i
= 0; i
< fTimeAnalysisEntries
.size(); i
++) {
597 TimeChartAnalysisEntry timeAnalysisEntry
= fTimeAnalysisEntries
.get(i
);
598 if (timeAnalysisEntry
.getTrace().equals(trace
)) {
599 updateTraceEntry(timeAnalysisEntry
, Long
.MAX_VALUE
, 0, Long
.MAX_VALUE
);
606 public void currentTimeUpdated(TmfTimeSynchSignal signal
) {
607 long time
= signal
.getCurrentTime().synchronize(0, TIMESTAMP_SCALE
).getValue();
608 fViewer
.setSelectedTime(time
, true, this);