1 /*******************************************************************************
2 * Copyright (c) 2013, 2014 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 * Alexandre Montplaisir - Initial API and implementation
11 * Patrick Tasse - Support selection range
12 * Xavier Raynaud - Support filters tracking
13 *******************************************************************************/
15 package org
.eclipse
.tracecompass
.tmf
.core
.trace
;
17 import org
.eclipse
.core
.resources
.IFile
;
18 import org
.eclipse
.jdt
.annotation
.NonNullByDefault
;
19 import org
.eclipse
.jdt
.annotation
.Nullable
;
20 import org
.eclipse
.tracecompass
.tmf
.core
.filter
.ITmfFilter
;
21 import org
.eclipse
.tracecompass
.tmf
.core
.timestamp
.TmfTimeRange
;
22 import org
.eclipse
.tracecompass
.tmf
.core
.timestamp
.TmfTimestamp
;
25 * Context of a trace, which is the representation of the "view" the user
26 * currently has on this trace (window time range, selected time or time range).
28 * TODO could be extended to support the notion of current location too.
30 * FIXME Is this really the right place for the Editor File ?
32 * @author Alexandre Montplaisir
36 public class TmfTraceContext
implements ITraceContextSignalHandler
{
38 static final TmfTraceContext NULL_CONTEXT
= new TmfTraceContext(new TmfTimeRange(TmfTimestamp
.BIG_CRUNCH
, TmfTimestamp
.BIG_CRUNCH
),
39 TmfTimeRange
.NULL_RANGE
, null, null);
41 private final TmfTimeRange fSelection
;
42 private final TmfTimeRange fWindowRange
;
43 private final @Nullable IFile fEditorFile
;
44 private final @Nullable ITmfFilter fFilter
;
47 * Build a new trace context.
50 * The selected time range
52 * The visible window's time range
54 * The file representing the selected editor
56 * The currently applied filter. 'null' for none.
58 public TmfTraceContext(TmfTimeRange selection
, TmfTimeRange windowRange
,
59 @Nullable IFile editorFile
, @Nullable ITmfFilter filter
) {
60 fSelection
= selection
;
61 fWindowRange
= windowRange
;
62 fEditorFile
= editorFile
;
67 * Return the time range representing the current active selection.
69 * @return The selected time range
71 public TmfTimeRange
getSelectionRange() {
76 * Return the current window time range.
78 * @return The current window time range
80 public TmfTimeRange
getWindowRange() {
85 * Get the editor's file
87 * @return The editor file
89 public @Nullable IFile
getEditorFile() {
94 * Gets the filter applied to the current trace
96 * @return The current filter, or <code>null</code> if there is none
98 public @Nullable ITmfFilter
getFilter() {
103 public String
toString() {
104 return getClass().getSimpleName() + "[fSelection=" + fSelection
+ //$NON-NLS-1$
105 ", fWindowRange=" + fWindowRange
+ ']'; //$NON-NLS-1$