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
.NonNull
;
16 import org
.eclipse
.jdt
.annotation
.NonNullByDefault
;
17 import org
.eclipse
.jdt
.annotation
.Nullable
;
20 * Interface for analysis modules providing state systems.
22 * @author Geneviève Bastien
26 public interface ITmfAnalysisModuleWithStateSystems
{
29 * Return a specific state system provided by this analysis.
32 * The ID of the state system
33 * @return The state system corresponding to the given ID, null if there is
37 ITmfStateSystem
getStateSystem(@NonNull String id
);
40 * FIXME The ID's should be saved in the state system themselves
41 * (ITmfStateSystem.getId()), so this will eventually not be needed.
43 * Return the ID of a given state system.
46 * The state system for which you want the ID, null if there is
48 * @return The corresponding state system
51 String
getStateSystemId(@NonNull ITmfStateSystem ss
);
54 * Return all the state systems provided by this analysis module, in
57 * @return The state systems
59 Iterable
<ITmfStateSystem
> getStateSystems();