1 /*******************************************************************************
2 * Copyright (c) 2009, 2010 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
9 * Contributors: Alvaro Sanchez-Leon - Initial implementation
10 *******************************************************************************/
11 package org
.eclipse
.linuxtools
.lttng
.ui
.views
.controlflow
;
13 import java
.util
.Vector
;
15 import org
.eclipse
.jface
.action
.Action
;
16 import org
.eclipse
.jface
.action
.IMenuListener
;
17 import org
.eclipse
.jface
.action
.IMenuManager
;
18 import org
.eclipse
.jface
.action
.IToolBarManager
;
19 import org
.eclipse
.jface
.action
.MenuManager
;
20 import org
.eclipse
.jface
.action
.Separator
;
21 import org
.eclipse
.jface
.dialogs
.MessageDialog
;
22 import org
.eclipse
.jface
.viewers
.DoubleClickEvent
;
23 import org
.eclipse
.jface
.viewers
.IDoubleClickListener
;
24 import org
.eclipse
.jface
.viewers
.ISelection
;
25 import org
.eclipse
.jface
.viewers
.ISelectionChangedListener
;
26 import org
.eclipse
.jface
.viewers
.IStructuredContentProvider
;
27 import org
.eclipse
.jface
.viewers
.IStructuredSelection
;
28 import org
.eclipse
.jface
.viewers
.ITableLabelProvider
;
29 import org
.eclipse
.jface
.viewers
.LabelProvider
;
30 import org
.eclipse
.jface
.viewers
.SelectionChangedEvent
;
31 import org
.eclipse
.jface
.viewers
.StructuredViewer
;
32 import org
.eclipse
.jface
.viewers
.TableViewer
;
33 import org
.eclipse
.jface
.viewers
.Viewer
;
34 import org
.eclipse
.jface
.viewers
.ViewerFilter
;
35 import org
.eclipse
.linuxtools
.lttng
.event
.LttngTimestamp
;
36 import org
.eclipse
.linuxtools
.lttng
.request
.ILttngSyntEventRequest
;
37 import org
.eclipse
.linuxtools
.lttng
.state
.evProcessor
.ITransEventProcessor
;
38 import org
.eclipse
.linuxtools
.lttng
.ui
.TraceDebug
;
39 import org
.eclipse
.linuxtools
.lttng
.ui
.model
.trange
.ItemContainer
;
40 import org
.eclipse
.linuxtools
.lttng
.ui
.model
.trange
.TimeRangeEventProcess
;
41 import org
.eclipse
.linuxtools
.lttng
.ui
.model
.trange
.TimeRangeViewerProvider
;
42 import org
.eclipse
.linuxtools
.lttng
.ui
.views
.common
.AbsTimeUpdateView
;
43 import org
.eclipse
.linuxtools
.lttng
.ui
.views
.common
.ParamsUpdater
;
44 import org
.eclipse
.linuxtools
.lttng
.ui
.views
.controlflow
.evProcessor
.FlowEventToHandlerFactory
;
45 import org
.eclipse
.linuxtools
.lttng
.ui
.views
.controlflow
.model
.FlowModelFactory
;
46 import org
.eclipse
.linuxtools
.tmf
.event
.TmfEvent
;
47 import org
.eclipse
.linuxtools
.tmf
.event
.TmfTimeRange
;
48 import org
.eclipse
.linuxtools
.tmf
.experiment
.TmfExperiment
;
49 import org
.eclipse
.linuxtools
.tmf
.request
.ITmfDataRequest
.ExecutionType
;
50 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfExperimentSelectedSignal
;
51 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfRangeSynchSignal
;
52 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfSignalHandler
;
53 import org
.eclipse
.linuxtools
.tmf
.signal
.TmfTimeSynchSignal
;
54 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.TmfViewerFactory
;
55 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.ITmfTimeFilterSelectionListener
;
56 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.ITmfTimeScaleSelectionListener
;
57 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.ITmfTimeSelectionListener
;
58 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.TmfTimeFilterSelectionEvent
;
59 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.TmfTimeScaleSelectionEvent
;
60 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.TmfTimeSelectionEvent
;
61 import org
.eclipse
.linuxtools
.tmf
.ui
.viewers
.timeAnalysis
.model
.ITmfTimeAnalysisEntry
;
62 import org
.eclipse
.swt
.SWT
;
63 import org
.eclipse
.swt
.custom
.SashForm
;
64 import org
.eclipse
.swt
.custom
.ScrolledComposite
;
65 import org
.eclipse
.swt
.events
.KeyEvent
;
66 import org
.eclipse
.swt
.events
.KeyListener
;
67 import org
.eclipse
.swt
.graphics
.Image
;
68 import org
.eclipse
.swt
.graphics
.Point
;
69 import org
.eclipse
.swt
.graphics
.Rectangle
;
70 import org
.eclipse
.swt
.widgets
.Composite
;
71 import org
.eclipse
.swt
.widgets
.Display
;
72 import org
.eclipse
.swt
.widgets
.Menu
;
73 import org
.eclipse
.swt
.widgets
.ScrollBar
;
74 import org
.eclipse
.swt
.widgets
.Table
;
75 import org
.eclipse
.swt
.widgets
.TableColumn
;
76 import org
.eclipse
.swt
.widgets
.TableItem
;
77 import org
.eclipse
.ui
.IActionBars
;
78 import org
.eclipse
.ui
.IWorkbenchActionConstants
;
79 import org
.eclipse
.ui
.PlatformUI
;
80 import org
.eclipse
.ui
.plugin
.AbstractUIPlugin
;
83 * <b><u>ControlFlowView</u></b>
89 public class ControlFlowView
extends AbsTimeUpdateView
implements
90 ITmfTimeSelectionListener
, ITmfTimeScaleSelectionListener
,
91 ITmfTimeFilterSelectionListener
{
93 public static final String ID
= "org.eclipse.linuxtools.lttng.ui.views.controlflow";
95 // ========================================================================
97 // ========================================================================
98 private final String PROCESS_COLUMN
= "Process";
99 private final String BRAND_COLUMN
= "Brand";
100 private final String PID_COLUMN
= "PID";
101 private final String TGID_COLUMN
= "TGID";
102 private final String PPID_COLUMN
= "PPID";
103 private final String CPU_COLUMN
= "CPU";
104 private final String BIRTH_SEC_COLUMN
= "Birth sec";
105 private final String BIRTH_NSEC_COLUMN
= "Birth nsec";
106 private final String TRACE
= "TRACE";
108 private final String
[] columnNames
= new String
[] { PROCESS_COLUMN
, /* */
114 BIRTH_SEC_COLUMN
,/* */
115 BIRTH_NSEC_COLUMN
,/* */
119 // ========================================================================
121 // ========================================================================
122 private TableViewer tableViewer
;
123 // private int totalNumItems = 0;
125 private Action doubleClickAction
;
126 private Action resetScale
;
127 private Action nextEvent
;
128 private Action prevEvent
;
129 private Action nextTrace
;
130 private Action prevTrace
;
131 private Action showLegend
;
132 private Action filterTraces
;
133 private Action zoomIn
;
134 private Action zoomOut
;
135 private Action zoomFilter
;
137 private ViewProcessFilter tableFilter
= null;
138 private ScrolledComposite scrollFrame
= null;
140 // private static SimpleDateFormat stimeformat = new SimpleDateFormat(
141 // "yy/MM/dd HH:mm:ss");
143 // private TraceModelImplFactory fact;
145 // ========================================================================
147 // ========================================================================
149 * The content provider class is responsible for providing objects to the
150 * view. It can wrap existing objects in adapters or simply return objects
151 * as-is. These objects may be sensitive to the current input of the view,
152 * or ignore it and always show the same content (like Task List, for
156 class ViewContentProvider
implements
157 /* ILazyContentProvider, */IStructuredContentProvider
{
158 private TableViewer cviewer
= null;
159 private ITmfTimeAnalysisEntry
[] elements
= null;
161 public ViewContentProvider(TableViewer v
) {
166 public void inputChanged(Viewer v
, Object oldInput
, Object newInput
) {
167 this.elements
= (ITmfTimeAnalysisEntry
[]) newInput
;
168 if (elements
!= null) {
169 TraceDebug
.debug("Total number of processes provided to Control Flow view: " + elements
.length
);
171 TraceDebug
.debug("New input = null");
176 public void dispose() {
180 // Needed with the use of virtual tables in order to initialize items
181 // which were not initially visible.
182 public void updateElement(int index
) {
183 cviewer
.replace(elements
[index
], index
);
187 public Object
[] getElements(Object inputElement
) {
192 class ViewLabelProvider
extends LabelProvider
implements ITableLabelProvider
{
194 public String
getColumnText(Object obj
, int index
) {
195 String strRes
= ""; //$NON-NLS-1$
197 if (obj
instanceof TimeRangeEventProcess
) {
198 TimeRangeEventProcess process
= (TimeRangeEventProcess
) obj
;
201 strRes
= process
.getName();
204 strRes
= process
.getBrand();
207 strRes
= process
.getPid().toString();
210 strRes
= process
.getTgid().toString();
213 strRes
= process
.getPpid().toString();
216 strRes
= process
.getCpu().toString();
219 time
= new LttngTimestamp(process
.getCreationTime()
221 strRes
= time
.getSeconds();
224 time
= new LttngTimestamp(process
.getCreationTime()
226 strRes
= time
.getNanoSeconds();
229 strRes
= process
.getTraceID();
242 public Image
getColumnImage(Object obj
, int index
) {
243 return getImage(obj
);
247 public Image
getImage(Object obj
) {
248 // No image needed for the time being
249 // return PlatformUI.getWorkbench().getSharedImages().getImage(
250 // ISharedImages.IMG_OBJ_ELEMENT);
255 class ViewProcessFilter
extends ViewerFilter
{
257 private Vector
<ITmfTimeAnalysisEntry
> filteredSet
= new Vector
<ITmfTimeAnalysisEntry
>();
258 StructuredViewer viewer
;
260 public ViewProcessFilter(StructuredViewer rviewer
) {
261 this.viewer
= rviewer
;
264 public void setFilter(Vector
<ITmfTimeAnalysisEntry
> filtered
) {
265 if (filtered
!= null) {
266 this.filteredSet
= filtered
;
272 public boolean select(Viewer viewer
, Object parentElement
,
274 boolean filteredIn
= true;
275 if (element
instanceof ITmfTimeAnalysisEntry
) {
276 ITmfTimeAnalysisEntry process
= (ITmfTimeAnalysisEntry
) element
;
277 if (filteredSet
.contains(process
)) {
278 // The element is marked to be filtered out
282 TraceDebug
.debug("Unexpected type of filter element received: "
283 + element
.toString());
285 // Compare element versus a list of filtered out
293 public ControlFlowView() {
298 * This is a callback that will allow us to create the viewer and initialize
305 * org.eclipse.linuxtools.tmf.ui.views.TmfView#createPartControl(org.eclipse
306 * .swt.widgets.Composite)
309 public void createPartControl(Composite parent
) {
311 scrollFrame
= new ScrolledComposite(parent
, SWT
.V_SCROLL
);
313 scrollFrame
.setExpandVertical(true);
314 scrollFrame
.setExpandHorizontal(true);
315 scrollFrame
.setAlwaysShowScrollBars(true);
317 SashForm sash
= new SashForm(scrollFrame
, SWT
.NONE
);
318 scrollFrame
.setContent(sash
);
320 tableViewer
= new TableViewer(sash
, SWT
.FULL_SELECTION
| SWT
.H_SCROLL
);
321 tableViewer
.setContentProvider(new ViewContentProvider(tableViewer
));
322 tableViewer
.setLabelProvider(new ViewLabelProvider());
323 Table table
= tableViewer
.getTable();
324 tableViewer
.addSelectionChangedListener(new ISelectionChangedListener() {
326 public void selectionChanged(SelectionChangedEvent event
) {
327 ISelection sel
= event
.getSelection();
328 if (!sel
.isEmpty()) {
329 Object firstSel
= null;
330 if (sel
instanceof IStructuredSelection
) {
331 firstSel
= ((IStructuredSelection
) sel
).getFirstElement();
333 // Make sure the selection is visible
334 updateScrollOrigin();
336 if (firstSel
instanceof ITmfTimeAnalysisEntry
) {
337 ITmfTimeAnalysisEntry trace
= (ITmfTimeAnalysisEntry
) firstSel
;
338 tsfviewer
.setSelectedTrace(trace
);
345 * Make sure the selected item is visible
347 private void updateScrollOrigin() {
348 Table table
= tableViewer
.getTable();
349 if (table
!= null && table
.getItemCount() > 0) {
350 TableItem item
= table
.getSelection()[0];
352 // no selected reference to go up or down
356 Rectangle itemRect
= item
.getBounds();
357 int step
= itemRect
.height
;
359 // calculate height of horizontal bar
361 ScrollBar hbar
= scrollFrame
.getHorizontalBar();
363 hscrolly
= hbar
.getSize().y
;
366 int visibleHeight
= scrollFrame
.getSize().y
- hscrolly
;
368 // the current scrollbar offset to adjust i.e. start
370 // the visible window
371 Point origin
= scrollFrame
.getOrigin();
372 // end of visible window
373 int endy
= origin
.y
+ visibleHeight
;
375 int itemStartPos
= itemRect
.y
+ table
.getHeaderHeight() + table
.getBorderWidth()
376 + table
.getParent().getBorderWidth();
379 int itemEndPos
= itemStartPos
+ step
;
381 // check if need to go up
382 if (origin
.y
>= step
&& itemStartPos
< origin
.y
) {
384 scrollFrame
.setOrigin(origin
.x
, origin
.y
- step
);
388 // check if it needs to go down
389 if (itemEndPos
> endy
) {
391 scrollFrame
.setOrigin(origin
.x
, origin
.y
+ step
);
398 // Listen to page up /down and Home / Enc keys
399 tableViewer
.getTable().addKeyListener(new KeyListener() {
401 public void keyPressed(KeyEvent e
) {
402 Table table
= tableViewer
.getTable();
403 Point origin
= scrollFrame
.getOrigin();
404 if (table
== null || table
.getItemCount() < 1) {
414 updateScrollPageDown();
421 count
= table
.getItemCount();
422 item
= table
.getItem(0);
424 scrollFrame
.setOrigin(origin
.x
, 0);
428 count
= table
.getItemCount();
429 item
= table
.getItem(count
- 1);
430 int itemStartPos
= item
.getBounds().y
;
432 scrollFrame
.setOrigin(origin
.x
, itemStartPos
);
440 public void keyReleased(KeyEvent e
) {
446 * Scroll one page down
448 private void updateScrollPageDown() {
449 // null protection before calling private method
450 Table table
= tableViewer
.getTable();
451 int step
= table
.getItemHeight();
454 ScrollBar hbar
= scrollFrame
.getHorizontalBar();
456 hscrolly
= hbar
.getSize().y
;
459 Point origin
= scrollFrame
.getOrigin();
460 int visibleHeight
= scrollFrame
.getSize().y
- hscrolly
;
461 int endy
= origin
.y
+ visibleHeight
;
463 scrollFrame
.setOrigin(origin
.x
, endy
- step
);
469 private void updateScrollUp() {
470 // null protection before calling private method
471 Table table
= tableViewer
.getTable();
472 int step
= table
.getItemHeight();
475 ScrollBar hbar
= scrollFrame
.getHorizontalBar();
477 hscrolly
= hbar
.getSize().y
;
480 Point origin
= scrollFrame
.getOrigin();
481 int visibleHeight
= scrollFrame
.getSize().y
- hscrolly
;
482 int pageUpPos
= origin
.y
- visibleHeight
+ step
;
483 pageUpPos
= pageUpPos
> 0 ? pageUpPos
: 0;
484 scrollFrame
.setOrigin(origin
.x
, pageUpPos
);
489 applyTableLayout(table
);
491 int borderWidth
= table
.getBorderWidth();
493 int itemHeight
= table
.getItemHeight() + checkForSWTBugItemHeightAdjustement();
494 int headerHeight
= table
.getHeaderHeight();
495 table
.getVerticalBar().setVisible(false);
497 tsfviewer
= TmfViewerFactory
.createViewer(sash
,
498 new TimeRangeViewerProvider(getParamsUpdater()));
500 tsfviewer
.addWidgetSelectionListner(this);
501 tsfviewer
.addWidgetTimeScaleSelectionListner(this);
503 // Traces shall not be grouped to allow synchronisation
504 tsfviewer
.groupTraces(false);
505 tsfviewer
.setItemHeight(itemHeight
);
506 tsfviewer
.setBorderWidth(borderWidth
);
507 tsfviewer
.setHeaderHeight(headerHeight
);
508 tsfviewer
.setVisibleVerticalScroll(false);
509 // Names provided by the table
510 tsfviewer
.setNameWidthPref(0);
511 tsfviewer
.setAcceptSelectionAPIcalls(true);
513 // Viewer to notify selection to this class
514 // This class will synchronise selections with table.
515 tsfviewer
.addWidgetSelectionListner(this);
516 tsfviewer
.addFilterSelectionListner(this);
517 tsfviewer
.addWidgetTimeScaleSelectionListner(this);
519 sash
.setWeights(new int[] { 1, 1 });
520 // Create the help context id for the viewer's control
521 // TODO: Associate with help system
522 PlatformUI
.getWorkbench().getHelpSystem().setHelp(
523 tableViewer
.getControl(),
524 "org.eclipse.linuxtools.lttnng.ui.views.flow.viewer"); //$NON-NLS-1$
528 hookDoubleClickAction();
529 contributeToActionBars();
531 // scrollFrame.addControlListener(new ControlAdapter() {
534 // public void controlResized(ControlEvent e) {
535 // tsfviewer.resizeControls();
536 // updateScrolls(scrollFrame);
540 // set the initial view parameter values
541 // Experiment start and end time
542 // as well as time space width in pixels, used by the time analysis
544 // Read relevant values
545 int timeSpaceWidth
= tsfviewer
.getTimeSpace();
546 if (timeSpaceWidth
< 0) {
547 timeSpaceWidth
= -timeSpaceWidth
;
550 TmfExperiment
<?
> experiment
= TmfExperiment
.getCurrentExperiment();
551 if (experiment
!= null) {
552 TmfTimeRange experimentTRange
= experiment
.getTimeRange();
554 // send request and received the adjusted time used
555 TmfTimeRange adjustedTimeRange
= initialExperimentDataRequest(this,
558 // initialize widget time boundaries and filtering parameters
559 ModelUpdateInit(experimentTRange
, adjustedTimeRange
, this);
561 TraceDebug
.debug("No selected experiment information available");
565 private void hookContextMenu() {
566 MenuManager menuMgr
= new MenuManager("#PopupMenu"); //$NON-NLS-1$
567 menuMgr
.setRemoveAllWhenShown(true);
568 menuMgr
.addMenuListener(new IMenuListener() {
570 public void menuAboutToShow(IMenuManager manager
) {
571 ControlFlowView
.this.fillContextMenu(manager
);
574 Menu menu
= menuMgr
.createContextMenu(tableViewer
.getControl());
575 tableViewer
.getControl().setMenu(menu
);
576 getSite().registerContextMenu(menuMgr
, tableViewer
);
579 private void contributeToActionBars() {
580 IActionBars bars
= getViewSite().getActionBars();
581 fillLocalPullDown(bars
.getMenuManager());
582 fillLocalToolBar(bars
.getToolBarManager());
585 private void fillLocalPullDown(IMenuManager manager
) {
586 manager
.add(new Separator());
587 // manager.add(showLegend);
588 manager
.add(new Separator());
589 manager
.add(resetScale
);
590 manager
.add(nextEvent
);
591 manager
.add(prevEvent
);
592 manager
.add(nextTrace
);
593 manager
.add(prevTrace
);
594 // manager.add(filterTraces);
596 manager
.add(zoomOut
);
597 manager
.add(zoomFilter
);
598 manager
.add(new Separator());
601 private void fillContextMenu(IMenuManager manager
) {
602 // manager.add(showLegend);
603 manager
.add(new Separator());
604 manager
.add(resetScale
);
605 manager
.add(nextEvent
);
606 manager
.add(prevEvent
);
607 manager
.add(nextTrace
);
608 manager
.add(prevTrace
);
609 // manager.add(showLegend);
610 // manager.add(filterTraces);
612 manager
.add(zoomOut
);
613 manager
.add(zoomFilter
);
614 manager
.add(new Separator());
615 manager
.add(new Separator(IWorkbenchActionConstants
.MB_ADDITIONS
));
618 private void fillLocalToolBar(IToolBarManager manager
) {
619 // manager.add(showLegend);
620 manager
.add(new Separator());
621 manager
.add(resetScale
);
622 manager
.add(nextEvent
);
623 manager
.add(prevEvent
);
624 manager
.add(nextTrace
);
625 manager
.add(prevTrace
);
626 // manager.add(filterTraces);
628 manager
.add(zoomOut
);
629 manager
.add(zoomFilter
);
630 manager
.add(new Separator());
633 private void makeActions() {
635 resetScale
= new Action() {
638 if (tsfviewer
!= null) {
639 tsfviewer
.resetStartFinishTime();
644 resetScale
.setText(Messages
.getString("ControlFlowView.Action.Reset")); //$NON-NLS-1$
645 resetScale
.setToolTipText(Messages
646 .getString("ControlFlowView.Action.Reset.ToolTip")); //$NON-NLS-1$
647 resetScale
.setImageDescriptor(AbstractUIPlugin
648 .imageDescriptorFromPlugin(Messages
649 .getString("ControlFlowView.tmf.UI"),
650 "icons/home_nav.gif"));
653 nextEvent
= new Action() {
656 if (tsfviewer
!= null) {
657 tsfviewer
.selectNextEvent();
661 nextEvent
.setText(Messages
662 .getString("ControlFlowView.Action.NextEvent")); //$NON-NLS-1$
663 nextEvent
.setToolTipText(Messages
664 .getString("ControlFlowView.Action.NextEvent.Tooltip")); //$NON-NLS-1$
665 nextEvent
.setImageDescriptor(AbstractUIPlugin
666 .imageDescriptorFromPlugin(Messages
667 .getString("ControlFlowView.tmf.UI"),
668 "icons/next_event.gif"));
671 prevEvent
= new Action() {
674 if (tsfviewer
!= null) {
675 tsfviewer
.selectPrevEvent();
679 prevEvent
.setText(Messages
680 .getString("ControlFlowView.Action.PrevEvent")); //$NON-NLS-1$
681 prevEvent
.setToolTipText(Messages
682 .getString("ControlFlowView.Action.PrevEvent.Tooltip")); //$NON-NLS-1$
683 prevEvent
.setImageDescriptor(AbstractUIPlugin
684 .imageDescriptorFromPlugin(Messages
685 .getString("ControlFlowView.tmf.UI"),
686 "icons/prev_event.gif"));
689 nextTrace
= new Action() {
692 if (tsfviewer
!= null) {
693 tsfviewer
.selectNextTrace();
697 nextTrace
.setText(Messages
698 .getString("ControlFlowView.Action.NextProcess")); //$NON-NLS-1$
699 nextTrace
.setToolTipText(Messages
700 .getString("ControlFlowView.Action.NextProcess.ToolTip")); //$NON-NLS-1$
701 nextTrace
.setImageDescriptor(AbstractUIPlugin
702 .imageDescriptorFromPlugin(Messages
703 .getString("ControlFlowView.tmf.UI"),
704 "icons/next_item.gif"));
707 prevTrace
= new Action() {
710 if (tsfviewer
!= null) {
711 tsfviewer
.selectPrevTrace();
715 prevTrace
.setText(Messages
716 .getString("ControlFlowView.Action.PreviousProcess")); //$NON-NLS-1$
717 prevTrace
.setToolTipText(Messages
718 .getString("ControlFlowView.Action.PreviousProcess.Tooltip")); //$NON-NLS-1$
719 prevTrace
.setImageDescriptor(AbstractUIPlugin
720 .imageDescriptorFromPlugin(Messages
721 .getString("ControlFlowView.tmf.UI"),
722 "icons/prev_item.gif"));
725 showLegend
= new Action() {
728 if (tsfviewer
!= null) {
729 tsfviewer
.showLegend();
733 showLegend
.setText(Messages
.getString("ControlFlowView.Action.Legend")); //$NON-NLS-1$
734 showLegend
.setToolTipText(Messages
735 .getString("ControlFlowView.Action.Legend.ToolTip")); //$NON-NLS-1$
738 filterTraces
= new Action() {
741 if (tsfviewer
!= null) {
742 tsfviewer
.filterTraces();
746 filterTraces
.setText(Messages
747 .getString("ControlFlowView.Action.Filter")); //$NON-NLS-1$
748 filterTraces
.setToolTipText(Messages
749 .getString("ControlFlowView.Action.Filter.ToolTip")); //$NON-NLS-1$
750 filterTraces
.setImageDescriptor(AbstractUIPlugin
751 .imageDescriptorFromPlugin(Messages
752 .getString("ControlFlowView.tmf.UI"),
753 "icons/filter_items.gif"));
756 zoomIn
= new Action() {
759 if (tsfviewer
!= null) {
764 zoomIn
.setText(Messages
.getString("ControlFlowView.Action.ZoomIn")); //$NON-NLS-1$
765 zoomIn
.setToolTipText(Messages
766 .getString("ControlFlowView.Action.ZoomIn.Tooltip")); //$NON-NLS-1$
767 zoomIn
.setImageDescriptor(AbstractUIPlugin
.imageDescriptorFromPlugin(
768 Messages
.getString("ControlFlowView.tmf.UI"),
769 "icons/zoomin_nav.gif"));
772 zoomOut
= new Action() {
775 if (tsfviewer
!= null) {
780 zoomOut
.setText(Messages
.getString("ControlFlowView.Action.ZoomOut")); //$NON-NLS-1$
781 zoomOut
.setToolTipText(Messages
782 .getString("ControlFlowView.Action.ZoomOut.tooltip")); //$NON-NLS-1$
783 zoomOut
.setImageDescriptor(AbstractUIPlugin
.imageDescriptorFromPlugin(
784 Messages
.getString("ControlFlowView.tmf.UI"),
785 "icons/zoomout_nav.gif"));
788 zoomFilter
= new Action() {
791 // Nothing to do, however the selection status is needed by the
795 zoomFilter
.setText(Messages
796 .getString("ControlFlowView.Action.ZoomFilter")); //$NON-NLS-1$
797 zoomFilter
.setToolTipText(Messages
798 .getString("ControlFlowView.Action.ZoomFilter.tooltip")); //$NON-NLS-1$
799 zoomFilter
.setImageDescriptor(AbstractUIPlugin
800 .imageDescriptorFromPlugin(Messages
801 .getString("ControlFlowView.tmf.UI"),
802 "icons/filter_items.gif"));
803 zoomFilter
.setChecked(false);
805 // PlatformUI.getWorkbench().getSharedImages().getImage(ISharedImages.IMG_ELCL_SYNCED);
807 doubleClickAction
= new Action() {
810 ISelection selection
= tableViewer
.getSelection();
811 Object obj
= ((IStructuredSelection
) selection
)
813 showMessage("Double-click detected on " + obj
.toString()); //$NON-NLS-1$
818 private void hookDoubleClickAction() {
819 tableViewer
.addDoubleClickListener(new IDoubleClickListener() {
821 public void doubleClick(DoubleClickEvent event
) {
822 doubleClickAction
.run();
827 private void showMessage(String message
) {
828 MessageDialog
.openInformation(tableViewer
.getControl().getShell(),
829 Messages
.getString("ControlFlowView.msgSlogan"), message
); //$NON-NLS-1$
833 * Passing the focus request to the viewer's control.
836 public void setFocus() {
837 tableViewer
.getControl().setFocus();
843 * @see org.eclipse.linuxtools.lttng.ui.views.common.AbsTimeUpdateView#
844 * tsfTmProcessSelEvent
845 * (org.eclipse.linuxtools.tmf.ui.viewers.timeAnalysis.TmfTimeSelectionEvent
849 public void tsfTmProcessSelEvent(TmfTimeSelectionEvent event
) {
850 // common implementation
851 super.tsfTmProcessSelEvent(event
);
853 // Reselect the table viewer to widget selection
854 ISelection sel
= tsfviewer
.getSelectionTrace();
855 if (sel
!= null && !sel
.isEmpty()) {
856 tableViewer
.setSelection(sel
);
863 * @see org.eclipse.linuxtools.tmf.ui.viewers.timeAnalysis.
864 * ITmfTimeScaleSelectionListener
865 * #tsfTmProcessTimeScaleEvent(org.eclipse.linuxtools
866 * .tmf.ui.viewers.timeAnalysis.TmfTimeScaleSelectionEvent)
869 public synchronized void tsfTmProcessTimeScaleEvent(TmfTimeScaleSelectionEvent event
) {
870 super.tsfTmProcessTimeScaleEvent(event
);
873 private void applyTableLayout(Table table
) {
874 for (int i
= 0; i
< columnNames
.length
; i
++) {
875 TableColumn tableColumn
= new TableColumn(table
, SWT
.LEFT
);
876 tableColumn
.setText(columnNames
[i
]);
879 table
.setHeaderVisible(true);
880 table
.setLinesVisible(true);
887 * org.eclipse.linuxtools.lttng.ui.views.common.AbsTimeUpdateView#displayModel
888 * (org.eclipse.linuxtools.tmf.ui.viewers.timeAnalysis.model.
889 * ITmfTimeAnalysisEntry[], long, long, boolean, long, long,
893 public void displayModel(final ITmfTimeAnalysisEntry
[] items
,
894 final long startBoundTime
, final long endBoundTime
,
895 final boolean updateTimeBounds
, final long startVisibleWindow
,
896 final long endVisibleWindow
, final Object source
) {
898 if(tableViewer
!= null) {
899 final Table table
= tableViewer
.getTable();
901 // Ignore update if widget is disposed
902 if (table
.isDisposed()) return;
904 Display display
= table
.getDisplay();
906 // Perform the updates on the UI thread)
907 display
.asyncExec(new Runnable() {
910 if (!table
.isDisposed()) {
911 tableViewer
.setInput(items
); // This shall be the minimal
913 tableFilter
= new ViewProcessFilter(tableViewer
);
914 tableViewer
.setFilters(new ViewerFilter
[] { tableFilter
});
916 resizeTableColumns(table
);
918 tableViewer
.refresh();
920 tsfviewer
.display(items
, startBoundTime
, endBoundTime
,
923 // validate visible boundaries
924 if (startVisibleWindow
> -1 && endVisibleWindow
> -1) {
925 tsfviewer
.setSelectVisTimeWindow(startVisibleWindow
,
926 endVisibleWindow
, source
);
929 tsfviewer
.resizeControls();
931 // Adjust the size of the vertical scroll bar to fit the
933 if (scrollFrame
!= null) {
934 updateScrolls(scrollFrame
);
943 public void dispose() {
944 // dispose parent resources
947 tsfviewer
.removeFilterSelectionListner(this);
948 tsfviewer
.removeWidgetSelectionListner(this);
949 tsfviewer
.removeWidgetTimeScaleSelectionListner(this);
955 * @param tableComposite
958 private synchronized void resizeTableColumns(Table table
) {
960 Composite parent
= table
.getParent();
961 int tableWidthSum
= parent
.getBorderWidth();
963 TableColumn
[] columns
= table
.getColumns();
964 for (TableColumn column
: columns
) {
966 tableWidthSum
+= column
.getWidth();
972 public void tmfTaProcessFilterSelection(TmfTimeFilterSelectionEvent event
) {
973 if (tableFilter
!= null) {
974 Vector
<ITmfTimeAnalysisEntry
> filteredout
= event
.getFilteredOut();
975 if (filteredout
!= null) {
976 tableFilter
.setFilter(filteredout
);
978 tableFilter
.setFilter(new Vector
<ITmfTimeAnalysisEntry
>());
980 tableViewer
.refresh();
988 private void updateScrolls(final ScrolledComposite scrollFrame
) {
989 scrollFrame
.setMinSize(tableViewer
.getTable().computeSize(SWT
.DEFAULT
, SWT
.DEFAULT
));
993 * Registers as listener of time selection from other views
999 public void synchToTime(TmfTimeSynchSignal signal
) {
1000 super.synchToTime(signal
);
1004 * Annotation Registers as listener of time range selection from other views
1005 * The implementation handles the entry of the signal.
1010 public void synchToTimeRange(TmfRangeSynchSignal signal
) {
1011 if (zoomFilter
!= null) {
1012 synchToTimeRange(signal
, zoomFilter
.isChecked());
1017 public void modelIncomplete(ILttngSyntEventRequest request
) {
1019 // The data will be refreshed on the next request
1025 * @see org.eclipse.linuxtools.lttng.ui.views.common.AbsTimeUpdateView#
1026 * getEventProcessor()
1029 public ITransEventProcessor
getEventProcessor() {
1030 return FlowEventToHandlerFactory
.getInstance();
1037 public void experimentSelected(
1038 TmfExperimentSelectedSignal
<?
extends TmfEvent
> signal
) {
1039 if (signal
!= null) {
1040 TmfTimeRange experimentTRange
= signal
.getExperiment()
1043 // prepare time intervals in widget
1044 ModelUpdateInit(experimentTRange
, experimentTRange
, signal
1047 // request initial data
1048 initialExperimentDataRequest(signal
1049 .getSource(), experimentTRange
);
1055 * @param experimentTRange
1056 * @return Adjusted time window used for the request (smaller window to
1059 private TmfTimeRange
initialExperimentDataRequest(Object source
,
1060 TmfTimeRange experimentTRange
) {
1061 // Adjust the initial time window to a shorter interval to allow
1062 // user to select the interesting area based on the perspective
1063 TmfTimeRange initTimeWindow
= getInitTRange(experimentTRange
);
1065 dataRequest(initTimeWindow
, experimentTRange
, true, ExecutionType
.FOREGROUND
);
1066 if (TraceDebug
.isDEBUG()) {
1067 TraceDebug
.debug("Initialization request time range is: "
1068 + initTimeWindow
.getStartTime().toString() + "-"
1069 + initTimeWindow
.getEndTime().toString());
1072 return initTimeWindow
;
1079 public int checkForSWTBugItemHeightAdjustement() {
1080 int returnedAjustement
= 0;
1081 String desktopSessionName
= System
.getenv("DESKTOP_SESSION");
1083 // Gnome : most common case, no adjustement
1084 if ( desktopSessionName
.equals("gnome") ) {
1085 returnedAjustement
= 0;
1087 // Kde : ajustement of 2 is needed
1088 else if ( desktopSessionName
.equals("kde") ) {
1089 returnedAjustement
= 2;
1092 return returnedAjustement
;
1098 * @see org.eclipse.linuxtools.lttng.ui.views.common.AbsTimeUpdateView#
1099 * getParamsUpdater()
1102 protected ParamsUpdater
getParamsUpdater() {
1103 return FlowModelFactory
.getParamsUpdater();
1109 * @see org.eclipse.linuxtools.lttng.ui.views.common.AbsTimeUpdateView#
1110 * getItemContainer()
1113 protected ItemContainer
<?
> getItemContainer() {
1114 return FlowModelFactory
.getProcContainer();