Package net.sf.okapi.common.filters
Interface IFilterConfigurationMapper
-
- All Superinterfaces:
IParametersEditorMapper
- All Known Implementing Classes:
FilterConfigurationMapper
public interface IFilterConfigurationMapper extends IParametersEditorMapper
Common set of methods to manage filter configurations.This interface allows you to add and remove filter configurations from a central place. You can instantiate the filter corresponding to a given configuration, as well as manipulate its parameters.
Classes that implements this interface should consider overriding the methods related to custom configurations to provide application-specific storage mechanism and naming convention. The methods related to custom configurations are, for example:
createCustomConfiguration(FilterConfiguration),deleteCustomParameters(FilterConfiguration),getCustomParameters(FilterConfiguration),getCustomParameters(FilterConfiguration, IFilter), andsaveCustomParameters(FilterConfiguration, IParameters).
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description voidaddConfiguration(FilterConfiguration config)Adds a new configuration to this mapper.voidaddConfigurations(String filterClass)Adds all the predefined configurations of a given filter to this mapper.voidaddEditor(String editorClass, String parametersClass)Adds a new editor mapping to this mapper.voidclearConfigurations(boolean customOnly)Removes configuration mappings from this mapper.voidclearEditors()Removes all editor mappings for this mapper.IParametersEditorcreateConfigurationEditor(String configId)Creates an instance of the filter's parameters editor for a given configuration identifier.IParametersEditorcreateConfigurationEditor(String configId, IFilter existingFilter)Creates an instance of the filter's parameters editor for a given configuration identifier.FilterConfigurationcreateCustomConfiguration(FilterConfiguration baseConfig)Creates a custom configuration object based on a give one.IFiltercreateFilter(String configId)Creates an instance of the filter for a given configuration identifier and loads its corresponding parameters.IFiltercreateFilter(String configId, IFilter existingFilter)Creates an instance of the filter for a given configuration identifier and loads its corresponding parameters.voiddeleteCustomParameters(FilterConfiguration config)Deletes the parameters of a custom configuration.Iterator<FilterConfiguration>getAllConfigurations()Gets an iterator on all configurations objects for this mapper.FilterConfigurationgetConfiguration(String configId)Gets the FilterConfiguration object for a given configuration identifier.IParametersgetCustomParameters(FilterConfiguration config)Gets the parameters for a given custom filter configuration.IParametersgetCustomParameters(FilterConfiguration config, IFilter existingFilter)Gets the parameters for a given custom filter configuration.FilterConfigurationgetDefaultConfiguration(String mimeType)Gets the first filter configuration for a given MIME type.FilterConfigurationgetDefaultConfigurationFromExtension(String ext)Gets the first filter configuration for a given extension.List<FilterConfiguration>getFilterConfigurations(String filterClass)Gets a list of all FilterConfiguration objects for a given filter class.List<FilterInfo>getFiltersInfo()Gets a list of information on all filters in this mapper.List<FilterConfiguration>getMimeConfigurations(String mimeType)Gets a list of all FilterConfiguration objects for a given MIME type.IParametersgetParameters(FilterConfiguration config)Gets the parameters for a given configuration (predefined or custom).IParametersgetParameters(FilterConfiguration config, IFilter existingFilter)Gets the parameters for a given configuration (predefined or custom).voidremoveConfiguration(String configId)Removes a given configuration from this mapper.voidremoveConfigurations(String filterClass)Removes all the configurations (predefined and custom) of a given filter from this mapper.voidremoveEditor(String editorClass)Removes a given editor from this mapper.voidsaveCustomParameters(FilterConfiguration config, IParameters params)Saves the parameters of a custom configuration.-
Methods inherited from interface net.sf.okapi.common.IParametersEditorMapper
addDescriptionProvider, addDescriptionProvider, addEditor, clearDescriptionProviders, createParametersEditor, getDescriptionProvider, removeDescriptionProvider
-
-
-
-
Method Detail
-
addConfiguration
void addConfiguration(FilterConfiguration config)
Adds a new configuration to this mapper.- Parameters:
config- the configuration to add.
-
removeConfiguration
void removeConfiguration(String configId)
Removes a given configuration from this mapper.- Parameters:
configId- the identifier of the configuration to remove.
-
addConfigurations
void addConfigurations(String filterClass)
Adds all the predefined configurations of a given filter to this mapper.- Parameters:
filterClass- the class name of the filter to lookup.
-
removeConfigurations
void removeConfigurations(String filterClass)
Removes all the configurations (predefined and custom) of a given filter from this mapper.- Parameters:
filterClass- the class name of the filter to lookup.
-
clearConfigurations
void clearConfigurations(boolean customOnly)
Removes configuration mappings from this mapper.- Parameters:
customOnly- true to clear only the custom configurations, false to clear all the configurations from this mapper.
-
addEditor
void addEditor(String editorClass, String parametersClass)
Adds a new editor mapping to this mapper.- Specified by:
addEditorin interfaceIParametersEditorMapper- Parameters:
editorClass- the class name of the editor to add.parametersClass- the class name of the parameters this editor can edit.
-
removeEditor
void removeEditor(String editorClass)
Removes a given editor from this mapper.- Specified by:
removeEditorin interfaceIParametersEditorMapper- Parameters:
editorClass- the class name of the editor to remove.
-
clearEditors
void clearEditors()
Removes all editor mappings for this mapper.- Specified by:
clearEditorsin interfaceIParametersEditorMapper
-
createFilter
IFilter createFilter(String configId, IFilter existingFilter)
Creates an instance of the filter for a given configuration identifier and loads its corresponding parameters.- Parameters:
configId- the configuration identifier to use for look-up.existingFilter- an optional existing instance of a filter. This argument can be null. If this argument is not null, it is checked against the requested filter and re-use if the requested filter and the provided instance are the same. If the provided instance is re-used, its parameters are always re-loaded. Providing an existing instance of the requested filter may allow for better efficiency.- Returns:
- a new
IFilterobject (with its parameters loaded) for the given configuration identifier, or null if the object could not be created. - Throws:
OkapiFilterCreationException- if the filter could not be created.
-
createFilter
IFilter createFilter(String configId)
Creates an instance of the filter for a given configuration identifier and loads its corresponding parameters.- Parameters:
configId- the configuration identifier to use for look-up.- Returns:
- a new
IFilterobject (with its parameters loaded) for the given configuration identifier, or null if the object could not be created. - Throws:
OkapiFilterCreationException- if the filter could not be created.
-
createConfigurationEditor
IParametersEditor createConfigurationEditor(String configId, IFilter existingFilter)
Creates an instance of the filter's parameters editor for a given configuration identifier.- Parameters:
configId- the configuration identifier to use for look-up.existingFilter- an optional existing instance of a filter. This argument can be null. If this argument is not null and matches the filter of the given configuration it is used instead of a temporay instance, to get an instance of the parameters object for which the editor is requested.- Returns:
- a new IParametersEditor object for the given configuration identifier, or null if no editor is available or if the object could not be created.
- Throws:
OkapiFilterCreationException- if a filter needed to be created and could not.OkapiEditorCreationException- if the editor could not be created.
-
createConfigurationEditor
IParametersEditor createConfigurationEditor(String configId)
Creates an instance of the filter's parameters editor for a given configuration identifier.- Parameters:
configId- the configuration identifier to use for look-up.- Returns:
- a new IParametersEditor object for the given configuration identifier, or null if no editor is available or if the object could not be created.
- Throws:
OkapiFilterCreationException- if a filter needed to be created and could not.OkapiEditorCreationException- if the editor could not be created.
-
getConfiguration
FilterConfiguration getConfiguration(String configId)
Gets the FilterConfiguration object for a given configuration identifier.- Parameters:
configId- the configuration identifier to search for.- Returns:
- the FilterConfiguration object for the given configuration identifier, or null if a match could not be found.
-
getDefaultConfiguration
FilterConfiguration getDefaultConfiguration(String mimeType)
Gets the first filter configuration for a given MIME type.- Parameters:
mimeType- MIME type to search for.- Returns:
- the filter configuration for the given MIME type, or null if none is found.
-
getDefaultConfigurationFromExtension
FilterConfiguration getDefaultConfigurationFromExtension(String ext)
Gets the first filter configuration for a given extension.- Parameters:
ext- the extension to search for (must be in the form ".ext" but can be in any case).- Returns:
- the filter configuration for the given extension, or null if none is found.
-
getFiltersInfo
List<FilterInfo> getFiltersInfo()
Gets a list of information on all filters in this mapper.- Returns:
- a list of information on all filters in this mapper.
-
getAllConfigurations
Iterator<FilterConfiguration> getAllConfigurations()
Gets an iterator on all configurations objects for this mapper.- Returns:
- an iterator on all configurations for this mapper.
-
getMimeConfigurations
List<FilterConfiguration> getMimeConfigurations(String mimeType)
Gets a list of all FilterConfiguration objects for a given MIME type.- Parameters:
mimeType- mimeType MIME type to search for.- Returns:
- a list of all FilterConfiguration objects found for the given MIME type (the list may be empty).
-
getFilterConfigurations
List<FilterConfiguration> getFilterConfigurations(String filterClass)
Gets a list of all FilterConfiguration objects for a given filter class.- Parameters:
filterClass- the class name of the filter to search for.- Returns:
- a list of all FilterConfiguration objects found for the given filter class name (the list may be empty).
-
getParameters
IParameters getParameters(FilterConfiguration config)
Gets the parameters for a given configuration (predefined or custom).- Parameters:
config- the configuration for which the parameters are requested.- Returns:
- the parameters object for the given configuration.
- See Also:
getCustomParameters(FilterConfiguration)
-
getParameters
IParameters getParameters(FilterConfiguration config, IFilter existingFilter)
Gets the parameters for a given configuration (predefined or custom).- Parameters:
config- the configuration for which the parameters are requested.existingFilter- optional existing instance of the filter for the given configuration. This argument can be null. If it not null, the provided filter may be used to load the parameters (if it matches the appropriate class). Providing this argument may allow the method to be more efficient by not creating a temporary filter to get an instance of the parameters to load.- Returns:
- the parameters object for the given configuration.
-
createCustomConfiguration
FilterConfiguration createCustomConfiguration(FilterConfiguration baseConfig)
Creates a custom configuration object based on a give one. The new configuration is not added to the current list.- Parameters:
baseConfig- the base configuration from which to base the new one.- Returns:
- a new
FilterConfigurationobject set with some default values, or null if the configuration could not be created.
-
getCustomParameters
IParameters getCustomParameters(FilterConfiguration config, IFilter existingFilter)
Gets the parameters for a given custom filter configuration. This method provides a way for this mapper to implements how it retrieves custom filter parameters.- Parameters:
config- the custom configuration for which the method should return the filter parameters.existingFilter- optional existing instance of the filter for the given configuration. This argument can be null. If it not null, the provided filter may be used to load the parameters (if it matches the appropriate class). Providing this argument may allow the method to be more efficient by not creating a temporary filter to get an instance of the parameters to load.- Returns:
- the parameters for the given custom filter configuration, or null if the parameters could not be provided, or if the corresponding filter does not have parameters.
- Throws:
OkapiFilterCreationException- if the filter of the given configuration could not be created to load the parameters.
-
getCustomParameters
IParameters getCustomParameters(FilterConfiguration config)
Gets the parameters for a given custom filter configuration. This method provides a way for this mapper to implements how it retrieves custom filter parameters.- Parameters:
config- the custom configuration for which the method should return the filter parameters.- Returns:
- the parameters for the given custom filter configuration, or null if the parameters could not be provided, or if the corresponding filter does not have parameters.
- Throws:
OkapiFilterCreationException- if the filter of the given configuration could not be created to load the parameters.- See Also:
getParameters(FilterConfiguration)
-
saveCustomParameters
void saveCustomParameters(FilterConfiguration config, IParameters params)
Saves the parameters of a custom configuration. This method provides a way for this mapper to implements how it stores custom filter parameters.- Parameters:
config- the custom configuration for which to save the parameters.params- the parameters to save.
-
deleteCustomParameters
void deleteCustomParameters(FilterConfiguration config)
Deletes the parameters of a custom configuration. This method provides a way for this mapper to implements how it permanently delete custom filter parameters. The actual configuration is not removed from this mapper, you must do it by callingremoveConfiguration(String).- Parameters:
config- the custom configuration for which to delete the parameters.
-
-