|
Kieker 1.6 | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object kieker.analysis.AnalysisController
public final class AnalysisController
The AnalysisController
can be used to configure and control an analysis instance. It is responsible for the life cycle of the readers, filters and
repositories.
Nested Class Summary | |
---|---|
static class |
AnalysisController.AnalysisControllerWithMapping
|
static interface |
AnalysisController.IStateObserver
This interface can be used for observers which want to get notified about state changes of an analysis controller. |
static class |
AnalysisController.STATE
An enumeration used to describe the state of an AnalysisController . |
Constructor Summary | |
---|---|
AnalysisController()
Constructs an AnalysisController instance. |
|
AnalysisController(File file)
This constructors creates an AnalysisController instance, using the given file to load an analysis model. |
|
AnalysisController(File file,
ClassLoader classLoader)
This constructors creates an AnalysisController instance, using the given file to load an analysis model and the given classloader to initialize the
objects. |
|
AnalysisController(MIProject project)
Creates a new instance of the class AnalysisController but uses the given instance of MIProject to construct the analysis. |
|
AnalysisController(MIProject project,
ClassLoader classLoader)
Creates a new instance of the class AnalysisController but uses the given instance of @link{Project} to construct the analysis. |
|
AnalysisController(String projectName)
Constructs an AnalysisController instance using the given parameter. |
Method Summary | |
---|---|
void |
connect(AbstractPlugin src,
String outputPortName,
AbstractPlugin dst,
String inputPortName)
This method should be used to connect two plugins. |
void |
connect(AbstractPlugin plugin,
String repositoryPort,
AbstractRepository repository)
Connects the given repository to this plugin via the given name. |
static AnalysisController.AnalysisControllerWithMapping |
createAnalysisController(MIProject project,
ClassLoader classLoader)
This is a factory method which can be used to create a new instance of AnalysisController , but delivers the mapping between the MIProject and
the actual analysis. |
MIProject |
getCurrentConfiguration()
This method delivers the current configuration of this instance as an instance of MIProject . |
Collection<AbstractFilterPlugin> |
getFilters()
Delivers an unmodifiable collection of all filters. |
String |
getProjectName()
Delivers the current name of the project. |
Collection<AbstractReaderPlugin> |
getReaders()
Delivers an unmodifiable collection of all readers. |
Collection<AbstractRepository> |
getRepositories()
Delivers an unmodifiable collection of all repositories. |
AnalysisController.STATE |
getState()
Delivers the current state of the analysis controller. |
static MIProject |
loadFromFile(File file)
This method can be used to load a meta model instance from a given file. |
void |
registerFilter(AbstractFilterPlugin filter)
Registers the passed plugin. |
void |
registerReader(AbstractReaderPlugin reader)
Registers a log reader used as a source for monitoring records. |
void |
registerRepository(AbstractRepository repository)
Registers the passed repository. |
void |
registerStateObserver(AnalysisController.IStateObserver stateObserver)
Registers the given instance as a new state observer. |
void |
run()
Starts an AnalysisController instance. |
void |
saveToFile(File file)
This method can be used to store the current configuration of this analysis controller in a specified file. |
static void |
saveToFile(File file,
MIProject project)
This method can be used to save the given instance of MIProject within a given file. |
void |
terminate()
Initiates a termination of the analysis. |
void |
terminate(boolean error)
Initiates a termination of the analysis. |
void |
unregisterStateObserver(AnalysisController.IStateObserver stateObserver)
Unregisters the given instance from the state observers. |
Methods inherited from class java.lang.Object |
---|
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public AnalysisController()
AnalysisController
instance.
public AnalysisController(String projectName)
AnalysisController
instance using the given parameter.
projectName
- The name of the project.public AnalysisController(File file) throws IOException, AnalysisConfigurationException
AnalysisController
instance, using the given file to load an analysis model. The given file should therefore be an
instance of the analysis meta model.
file
- The configuration file for the analysis.
IOException
- If the given file could not be loaded or is not a valid kax-configuration file.
AnalysisConfigurationException
- If one or more plugins or repositories could not be created, one or
more properties of the plugins are invalid or if a connection between two filters is not allowed.public AnalysisController(File file, ClassLoader classLoader) throws IOException, AnalysisConfigurationException
AnalysisController
instance, using the given file to load an analysis model and the given classloader to initialize the
objects. The given file should therefore be an instance of the analysis meta model.
file
- The configuration file for the analysis.classLoader
- The classloader used to initialize the plugins etc.
IOException
- If the given file could not be loaded or is not a valid kax-configuration file.
AnalysisConfigurationException
- If one or more plugins or repositories could not be created, one or
more properties of the plugins are invalid or if a connection between two filters is not allowed.public AnalysisController(MIProject project) throws NullPointerException, AnalysisConfigurationException
AnalysisController
but uses the given instance of MIProject
to construct the analysis.
project
- The project instance for the analysis.
AnalysisConfigurationException
- If the given project could not be loaded.
NullPointerException
- If the project is null.public AnalysisController(MIProject project, ClassLoader classLoader) throws NullPointerException, AnalysisConfigurationException
AnalysisController
but uses the given instance of @link{Project} to construct the analysis.
project
- The project instance for the analysis.classLoader
- The class loader used for the initializing.
NullPointerException
- If the project is null.
AnalysisConfigurationException
- If the given project could not be loaded.Method Detail |
---|
public final void registerStateObserver(AnalysisController.IStateObserver stateObserver)
stateObserver
- The observer to be registered.public final void unregisterStateObserver(AnalysisController.IStateObserver stateObserver)
stateObserver
- The observer to be unregistered.public final void saveToFile(File file) throws IOException, AnalysisConfigurationException
file
- The file in which the configuration will be stored.
IOException
- If an exception during the storage occurred.
AnalysisConfigurationException
- If the current configuration is somehow invalid.public void connect(AbstractPlugin src, String outputPortName, AbstractPlugin dst, String inputPortName) throws IllegalStateException, AnalysisConfigurationException
src
- The source plugin.outputPortName
- The output port of the source plugin.dst
- The destination plugin.inputPortName
- The input port of the destination port.
IllegalStateException
- If this instance has already been started or has already been terminated.
AnalysisConfigurationException
- If the port names or the given plugins are invalid or not compatible.public void connect(AbstractPlugin plugin, String repositoryPort, AbstractRepository repository) throws IllegalStateException, AnalysisConfigurationException
plugin
- The plugin to be connected.repositoryPort
- The name of the port to connect the repository.repository
- The repository which should be used.
IllegalStateException
- If this instance has already been started or has already been terminated.
AnalysisConfigurationException
- If the port names or the given objects are invalid or not compatible.public final MIProject getCurrentConfiguration() throws AnalysisConfigurationException
MIProject
.
AnalysisConfigurationException
- If the current configuration is somehow invalid.public final void run() throws IllegalStateException, AnalysisConfigurationException
AnalysisController
instance.
The method returns after all configured readers finished reading and all analysis plug-ins terminated
On errors during the initialization, Exceptions are thrown.
IllegalStateException
- If the current instance has already been started or already been terminated.
AnalysisConfigurationException
- If plugins with mandatory repositories have not been connected properly or couldn't be initialized.public final void terminate()
public final void terminate(boolean error)
error
- Determines whether this is a normal termination or an termination due to an error during the analysis.public final void registerReader(AbstractReaderPlugin reader) throws IllegalStateException
reader
- The reader to be registered.
IllegalStateException
- If the controller is already running or has already been terminated.public final void registerFilter(AbstractFilterPlugin filter) throws IllegalStateException
filter
- The filter to be registered.
IllegalStateException
- If the controller is already running or has already been terminated.public final void registerRepository(AbstractRepository repository) throws IllegalStateException
repository
- The repository to be registered.
IllegalStateException
- If the controller is already running or has already been terminated.public final String getProjectName()
public final Collection<AbstractReaderPlugin> getReaders()
public final Collection<AbstractFilterPlugin> getFilters()
public final Collection<AbstractRepository> getRepositories()
public final AnalysisController.STATE getState()
public static final MIProject loadFromFile(File file) throws IOException
file
- The file to be loaded.
MIProject
if everything went well.
IOException
- If something during loading went wrong.public static final void saveToFile(File file, MIProject project) throws IOException
MIProject
within a given file.
file
- The file to be used for the storage.project
- The project to be stored.
IOException
- In case of errors.public static final AnalysisController.AnalysisControllerWithMapping createAnalysisController(MIProject project, ClassLoader classLoader) throws NullPointerException, AnalysisConfigurationException
AnalysisController
, but delivers the mapping between the MIProject
and
the actual analysis. It calls the constructor AnalysisController(MIProject, ClassLoader)
.
project
- The project to be loaded.classLoader
- The class loader used to load the instances.
NullPointerException
- If the project is null.
AnalysisConfigurationException
- If the given project could not be loaded.
|
Kieker 1.6 | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |