Package adams.flow.transformer
Class LookUp
-
- All Implemented Interfaces:
AdditionalInformationHandler
,CleanUpHandler
,Destroyable
,GlobalInfoSupporter
,LoggingLevelHandler
,LoggingSupporter
,OptionHandler
,QuickInfoSupporter
,ShallowCopySupporter<Actor>
,SizeOfHandler
,Stoppable
,StoppableWithFeedback
,VariablesInspectionHandler
,VariableChangeListener
,StorageUser
,Actor
,ErrorHandler
,InputConsumer
,OutputProducer
,Serializable
,Comparable
public class LookUp extends AbstractTransformer implements StorageUser
Forwards the value associated with the key that the actor gets as input, using the specified lookup table from internal storage.
Input/output:
- accepts:
java.lang.String
- generates:
java.lang.String
-logging-level <OFF|SEVERE|WARNING|INFO|CONFIG|FINE|FINER|FINEST> (property: loggingLevel) The logging level for outputting errors and debugging output. default: WARNING
-name <java.lang.String> (property: name) The name of the actor. default: LookUp
-annotation <adams.core.base.BaseText> (property: annotations) The annotations to attach to this actor. default:
-skip <boolean> (property: skip) If set to true, transformation is skipped and the input token is just forwarded as it is. default: false
-stop-flow-on-error <boolean> (property: stopFlowOnError) If set to true, the flow gets stopped in case this actor encounters an error; useful for critical actors. default: false
-storage-name <adams.flow.control.StorageName> (property: storageName) The name for the lookup table in the internal storage. default: lookup
-missing-key <NO_OUTPUT|OUTPUT_MISSING_VALUE|OUTPUT_KEY|CAUSE_ERROR> (property: missingKey) The behavior in case a lookup key is missing (ie not found in the lookup table). default: NO_OUTPUT
-missing-value <java.lang.String> (property: missingValue) The value to forward if the missing key behavior is OUTPUT_MISSING_VALUE. default: ???
-use-native <boolean> (property: useNative) If enabled, native objects are output rather than strings. default: false
-suppress-missing-key-warnings <boolean> (property: suppressMissingKeyWarnings) If enabled, warnings about missing keys are suppressed. default: false
- Version:
- $Revision$
- Author:
- fracpete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description protected MissingLookUpKey
m_MissingKey
the behavior for missing keys.protected String
m_MissingValue
the missing value.protected StorageName
m_StorageName
the name of the lookup table in the internal storage.protected boolean
m_SuppressMissingKeyWarnings
whether to suppress warnings when key is not present.protected boolean
m_UseNative
whether to output native objects rather than strings.-
Fields inherited from class adams.flow.transformer.AbstractTransformer
BACKUP_INPUT, BACKUP_OUTPUT, m_InputToken, m_OutputToken
-
Fields inherited from class adams.flow.core.AbstractActor
m_Annotations, m_BackupState, m_DetectedObjectVariables, m_DetectedVariables, m_ErrorHandler, m_Executed, m_Executing, m_ExecutionListeningSupporter, m_FullName, m_LoggingPrefix, m_Name, m_Parent, m_ScopeHandler, m_Self, m_Silent, m_Skip, m_StopFlowOnError, m_StopMessage, m_Stopped, m_StorageHandler, m_VariablesUpdated
-
Fields inherited from class adams.core.option.AbstractOptionHandler
m_OptionManager
-
Fields inherited from class adams.core.logging.LoggingObject
m_Logger, m_LoggingIsEnabled, m_LoggingLevel
-
Fields inherited from interface adams.flow.core.Actor
FILE_EXTENSION, FILE_EXTENSION_GZ
-
-
Constructor Summary
Constructors Constructor Description LookUp()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Class[]
accepts()
Returns the class that the consumer accepts.void
defineOptions()
Adds options to the internal list of options.protected String
doExecute()
Executes the flow item.Class[]
generates()
Returns the class of objects that it generates.MissingLookUpKey
getMissingKey()
Returns the behavior for missing keys.String
getMissingValue()
Returns the value used if behavior isMissingLookUpKey.OUTPUT_MISSING_VALUE
.String
getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.StorageName
getStorageName()
Returns the name for the lookup table in the internal storage.boolean
getSuppressMissingKeyWarnings()
Returns whether to suppress warnings about missing keys.boolean
getUseNative()
Returns whether native objects are output rather than strings.String
globalInfo()
Returns a string describing the object.boolean
isUsingStorage()
Returns whether storage items are being used.String
missingKeyTipText()
Returns the tip text for this property.String
missingValueTipText()
Returns the tip text for this property.void
setMissingKey(MissingLookUpKey value)
Sets the behavior for missing keys.void
setMissingValue(String value)
Sets the value to be used if behavior isMissingLookUpKey.OUTPUT_MISSING_VALUE
.void
setStorageName(StorageName value)
Sets the name for the lookup table in the internal storage.void
setSuppressMissingKeyWarnings(boolean value)
Sets whether to suppress warnings about missing keys.void
setUseNative(boolean value)
Sets whether to output native objects rather than strings.String
storageNameTipText()
Returns the tip text for this property.String
suppressMissingKeyWarningsTipText()
Returns the tip text for this property.String
useNativeTipText()
Returns the tip text for this property.-
Methods inherited from class adams.flow.transformer.AbstractTransformer
backupState, currentInput, execute, hasInput, hasPendingOutput, input, output, postExecute, restoreState, wrapUp
-
Methods inherited from class adams.flow.core.AbstractActor
annotationsTipText, canInspectOptions, canPerformSetUpCheck, cleanUp, compareTo, configureLogger, destroy, equals, finalUpdateVariables, findVariables, findVariables, forceVariables, forCommandLine, forName, forName, getAdditionalInformation, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowActors, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, handleException, hasErrorHandler, hasStopMessage, index, initialize, isBackedUp, isExecuted, isExecuting, isFinished, isHeadless, isStopped, nameTipText, performSetUpChecks, performVariableChecks, preExecute, pruneBackup, pruneBackup, reset, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setUp, setVariables, shallowCopy, shallowCopy, silentTipText, sizeOf, skipTipText, stopExecution, stopExecution, stopFlowOnErrorTipText, updateDetectedVariables, updatePrefix, updateVariables, variableChanged
-
Methods inherited from class adams.core.option.AbstractOptionHandler
cleanUpOptions, finishInit, getDefaultLoggingLevel, getOptionManager, loggingLevelTipText, newOptionManager, setLoggingLevel, toCommandLine, toString
-
Methods inherited from class adams.core.logging.LoggingObject
getLogger, getLoggingLevel, initializeLogging, isLoggingEnabled
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface adams.flow.core.Actor
cleanUp, compareTo, destroy, equals, findVariables, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, hasErrorHandler, hasStopMessage, index, isExecuted, isFinished, isHeadless, isStopped, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setUp, setVariables, shallowCopy, shallowCopy, sizeOf, stopExecution, stopExecution, toCommandLine, variableChanged
-
Methods inherited from interface adams.core.AdditionalInformationHandler
getAdditionalInformation
-
Methods inherited from interface adams.core.logging.LoggingLevelHandler
getLoggingLevel, setLoggingLevel
-
Methods inherited from interface adams.core.logging.LoggingSupporter
getLogger, isLoggingEnabled
-
Methods inherited from interface adams.core.option.OptionHandler
cleanUpOptions, getOptionManager
-
Methods inherited from interface adams.core.VariablesInspectionHandler
canInspectOptions
-
-
-
-
Field Detail
-
m_StorageName
protected StorageName m_StorageName
the name of the lookup table in the internal storage.
-
m_MissingKey
protected MissingLookUpKey m_MissingKey
the behavior for missing keys.
-
m_MissingValue
protected String m_MissingValue
the missing value.
-
m_UseNative
protected boolean m_UseNative
whether to output native objects rather than strings.
-
m_SuppressMissingKeyWarnings
protected boolean m_SuppressMissingKeyWarnings
whether to suppress warnings when key is not present.
-
-
Method Detail
-
globalInfo
public String globalInfo()
Returns a string describing the object.- Specified by:
globalInfo
in interfaceGlobalInfoSupporter
- Specified by:
globalInfo
in classAbstractOptionHandler
- Returns:
- a description suitable for displaying in the gui
-
defineOptions
public void defineOptions()
Adds options to the internal list of options.- Specified by:
defineOptions
in interfaceOptionHandler
- Overrides:
defineOptions
in classAbstractActor
-
isUsingStorage
public boolean isUsingStorage()
Returns whether storage items are being used.- Specified by:
isUsingStorage
in interfaceStorageUser
- Returns:
- true if storage items are used
-
getQuickInfo
public String getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.- Specified by:
getQuickInfo
in interfaceActor
- Specified by:
getQuickInfo
in interfaceQuickInfoSupporter
- Overrides:
getQuickInfo
in classAbstractActor
- Returns:
- null if no info available, otherwise short string
-
setStorageName
public void setStorageName(StorageName value)
Sets the name for the lookup table in the internal storage.- Parameters:
value
- the name
-
getStorageName
public StorageName getStorageName()
Returns the name for the lookup table in the internal storage.- Returns:
- the name
-
storageNameTipText
public String storageNameTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setMissingKey
public void setMissingKey(MissingLookUpKey value)
Sets the behavior for missing keys.- Parameters:
value
- the behavior
-
getMissingKey
public MissingLookUpKey getMissingKey()
Returns the behavior for missing keys.- Returns:
- the behavior
-
missingKeyTipText
public String missingKeyTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setMissingValue
public void setMissingValue(String value)
Sets the value to be used if behavior isMissingLookUpKey.OUTPUT_MISSING_VALUE
.- Parameters:
value
- the value to use- See Also:
MissingLookUpKey.OUTPUT_MISSING_VALUE
-
getMissingValue
public String getMissingValue()
Returns the value used if behavior isMissingLookUpKey.OUTPUT_MISSING_VALUE
.- Returns:
- the value in use
- See Also:
MissingLookUpKey.OUTPUT_MISSING_VALUE
-
missingValueTipText
public String missingValueTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setUseNative
public void setUseNative(boolean value)
Sets whether to output native objects rather than strings.- Parameters:
value
- true if to output native objects
-
getUseNative
public boolean getUseNative()
Returns whether native objects are output rather than strings.- Returns:
- true if native objects are used
-
useNativeTipText
public String useNativeTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setSuppressMissingKeyWarnings
public void setSuppressMissingKeyWarnings(boolean value)
Sets whether to suppress warnings about missing keys.- Parameters:
value
- true if to suppress warnings
-
getSuppressMissingKeyWarnings
public boolean getSuppressMissingKeyWarnings()
Returns whether to suppress warnings about missing keys.- Returns:
- true if warnings suppressed
-
suppressMissingKeyWarningsTipText
public String suppressMissingKeyWarningsTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
accepts
public Class[] accepts()
Returns the class that the consumer accepts.- Specified by:
accepts
in interfaceInputConsumer
- Returns:
- the Class of objects that can be processed
-
generates
public Class[] generates()
Returns the class of objects that it generates.- Specified by:
generates
in interfaceOutputProducer
- Returns:
- the Class of the generated tokens
-
doExecute
protected String doExecute()
Executes the flow item.- Specified by:
doExecute
in classAbstractActor
- Returns:
- null if everything is fine, otherwise error message
-
-