1 /*******************************************************************************
2 * Copyright (c) 2013 École Polytechnique de Montréal
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 * Geneviève Bastien - Initial API and implementation
11 *******************************************************************************/
13 package org
.eclipse
.linuxtools
.tmf
.core
.statesystem
;
15 import org
.eclipse
.jdt
.annotation
.NonNullByDefault
;
16 import org
.eclipse
.jdt
.annotation
.Nullable
;
19 * Interface for analysis modules providing state systems.
21 * @author Geneviève Bastien
25 public interface ITmfAnalysisModuleWithStateSystems
{
28 * Return a specific state system provided by this analysis.
31 * The ID of the state system
32 * @return The state system corresponding to the given ID, null if there is
36 ITmfStateSystem
getStateSystem(String id
);
39 * FIXME The ID's should be saved in the state system themselves
40 * (ITmfStateSystem.getId()), so this will eventually not be needed.
42 * Return the ID of a given state system.
45 * The state system for which you want the ID, null if there is
47 * @return The corresponding state system
50 String
getStateSystemId(ITmfStateSystem ss
);
53 * Return all the state systems provided by this analysis module, in
56 * @return The state systems
58 Iterable
<ITmfStateSystem
> getStateSystems();