Package adams.flow.transformer
Class SpreadSheetTransformHeaderCells
- java.lang.Object
-
- adams.core.logging.LoggingObject
-
- adams.core.logging.CustomLoggingLevelObject
-
- adams.core.option.AbstractOptionHandler
-
- adams.flow.core.AbstractActor
-
- adams.flow.transformer.AbstractTransformer
-
- adams.flow.transformer.AbstractSpreadSheetTransformer
-
- adams.flow.transformer.AbstractInPlaceSpreadSheetTransformer
-
- adams.flow.transformer.SpreadSheetTransformHeaderCells
-
- All Implemented Interfaces:
AdditionalInformationHandler
,CleanUpHandler
,Destroyable
,GlobalInfoSupporter
,LoggingLevelHandler
,LoggingSupporter
,OptionHandler
,QuickInfoSupporter
,ShallowCopySupporter<Actor>
,SizeOfHandler
,Stoppable
,StoppableWithFeedback
,VariablesInspectionHandler
,InPlaceProcessing
,VariableChangeListener
,Actor
,CallableActorUser
,ErrorHandler
,InputConsumer
,OutputProducer
,Serializable
,Comparable
public class SpreadSheetTransformHeaderCells extends AbstractInPlaceSpreadSheetTransformer implements CallableActorUser
Transforms header cells with a callable transformer.
In case of transformers having Object or Unknown in their types of classes that they accept, no proper type can be inferred automatically. Therefore it is recommended to manually enforce the 'input type'.
Input/output:
- accepts:
adams.data.spreadsheet.SpreadSheet
- generates:
adams.data.spreadsheet.SpreadSheet
-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: SpreadSheetTransformHeaderCells
-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
-no-copy <boolean> (property: noCopy) If enabled, no copy of the spreadsheet is created before processing it. default: false
-force-input-type <boolean> (property: forceInputType) If enabled, the input type is forced to a user-specified type, rather than trying to determine type based on data types that the callable transformer accepts. default: false
-input-type <MISSING|STRING|BOOLEAN|LONG|DOUBLE|DATE|DATETIME|TIME|OBJECT> (property: inputType) The input type to use in case the input type is enforced. default: STRING
-skip-missing <boolean> (property: skipMissing) If enabled, missing cells are skipped. default: true
-missing-replacement-value <java.lang.String> (property: missingReplacementValue) The string representation of the value to use for replacing missing values. default:
-missing-replacement-type <MISSING|STRING|BOOLEAN|LONG|DOUBLE|DATE|DATETIME|TIME|OBJECT> (property: missingReplacementType) The data type to use for the replacement value for missing values. default: STRING
-transformer <adams.flow.core.CallableActorReference> (property: transformer) The callable transformer to apply to the header cells. default: unknown
- Author:
- fracpete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static String
BACKUP_CALLABLEACTOR
the key for backing up the callable actor.protected Actor
m_CallableActor
the callable actor.protected Compatibility
m_Compatibility
for compatibility comparisons.protected boolean
m_ForceInputType
whether to force the input type.protected CallableActorHelper
m_Helper
the helper class.protected Cell.ContentType
m_InputType
the input type.protected Cell.ContentType
m_MissingReplacementType
the data type of the replacement value.protected String
m_MissingReplacementValue
the value to use instead of missing.protected boolean
m_SkipMissing
whether to skip missing cells.protected CallableActorReference
m_Transformer
the callable transformer to apply to the cells.-
Fields inherited from class adams.flow.transformer.AbstractInPlaceSpreadSheetTransformer
m_NoCopy
-
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 SpreadSheetTransformHeaderCells()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected Hashtable<String,Object>
backupState()
Backs up the current state of the actor before update the variables.void
defineOptions()
Adds options to the internal list of options.protected String
doExecute()
Executes the flow item.protected Actor
findCallableActor()
Tries to find the callable actor referenced by its callable name.String
forceInputTypeTipText()
Returns the tip text for this property.Actor
getCallableActor()
Returns the currently set callable actor.boolean
getForceInputType()
Returns whether to force the input type.Cell.ContentType
getInputType()
Returns the input type to enforce.Cell.ContentType
getMissingReplacementType()
Returns the data type of the replacement value.String
getMissingReplacementValue()
Returns the replacement value for missing values.String
getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.boolean
getSkipMissing()
Returns whether missing cells are skipped.CallableActorReference
getTransformer()
Returns the reference to the callable transformer.String
globalInfo()
Returns a string describing the object.boolean
hasCallableActor()
Checks whether a reference to the callable actor is currently available.protected void
initialize()
Initializes the members.String
inputTypeTipText()
Returns the tip text for this property.String
missingReplacementTypeTipText()
Returns the tip text for this property.String
missingReplacementValueTipText()
Returns the tip text for this property.protected void
pruneBackup()
Removes entries from the backup.protected void
reset()
Resets the scheme.protected void
restoreState(Hashtable<String,Object> state)
Restores the state of the actor before the variables got updated.void
setForceInputType(boolean value)
Sets whether to force the input type.void
setInputType(Cell.ContentType value)
Sets the input type to enforce.void
setMissingReplacementType(Cell.ContentType value)
Sets the data type of the replacement value.void
setMissingReplacementValue(String value)
Sets the replacement value for missing values.void
setSkipMissing(boolean value)
Sets whether to skip missing cells.void
setTransformer(CallableActorReference value)
Sets the reference to the callable transformer.String
setUp()
Initializes the item for flow execution.protected String
setUpCallableActor()
Configures the callable actor.String
skipMissingTipText()
Returns the tip text for this property.protected String
transformCell(Cell cell, SpreadSheet sheet)
Applies the transformer to the cell.String
transformerTipText()
Returns the tip text for this property.-
Methods inherited from class adams.flow.transformer.AbstractInPlaceSpreadSheetTransformer
getNoCopy, noCopyTipText, setNoCopy
-
Methods inherited from class adams.flow.transformer.AbstractSpreadSheetTransformer
accepts, generates
-
Methods inherited from class adams.flow.transformer.AbstractTransformer
currentInput, execute, hasInput, hasPendingOutput, input, output, postExecute, 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, isBackedUp, isExecuted, isExecuting, isFinished, isHeadless, isStopped, nameTipText, performSetUpChecks, performVariableChecks, preExecute, pruneBackup, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, 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, 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
-
BACKUP_CALLABLEACTOR
public static final String BACKUP_CALLABLEACTOR
the key for backing up the callable actor.- See Also:
- Constant Field Values
-
m_ForceInputType
protected boolean m_ForceInputType
whether to force the input type.
-
m_InputType
protected Cell.ContentType m_InputType
the input type.
-
m_SkipMissing
protected boolean m_SkipMissing
whether to skip missing cells.
-
m_MissingReplacementValue
protected String m_MissingReplacementValue
the value to use instead of missing.
-
m_MissingReplacementType
protected Cell.ContentType m_MissingReplacementType
the data type of the replacement value.
-
m_Transformer
protected CallableActorReference m_Transformer
the callable transformer to apply to the cells.
-
m_Helper
protected CallableActorHelper m_Helper
the helper class.
-
m_CallableActor
protected Actor m_CallableActor
the callable actor.
-
m_Compatibility
protected Compatibility m_Compatibility
for compatibility comparisons.
-
-
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 classAbstractInPlaceSpreadSheetTransformer
-
initialize
protected void initialize()
Initializes the members.- Overrides:
initialize
in classAbstractActor
-
reset
protected void reset()
Resets the scheme.- Overrides:
reset
in classAbstractActor
-
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
-
setForceInputType
public void setForceInputType(boolean value)
Sets whether to force the input type.- Parameters:
value
- true if to force type
-
getForceInputType
public boolean getForceInputType()
Returns whether to force the input type.- Returns:
- true type forced
-
forceInputTypeTipText
public String forceInputTypeTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setInputType
public void setInputType(Cell.ContentType value)
Sets the input type to enforce.- Parameters:
value
- the input type
-
getInputType
public Cell.ContentType getInputType()
Returns the input type to enforce.- Returns:
- the input type
-
inputTypeTipText
public String inputTypeTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setSkipMissing
public void setSkipMissing(boolean value)
Sets whether to skip missing cells.- Parameters:
value
- true if to skip missing cells
-
getSkipMissing
public boolean getSkipMissing()
Returns whether missing cells are skipped.- Returns:
- true if missing cells are skipped
-
skipMissingTipText
public String skipMissingTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setMissingReplacementValue
public void setMissingReplacementValue(String value)
Sets the replacement value for missing values.- Parameters:
value
- the replacement value
-
getMissingReplacementValue
public String getMissingReplacementValue()
Returns the replacement value for missing values.- Returns:
- the replacement value
-
missingReplacementValueTipText
public String missingReplacementValueTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setMissingReplacementType
public void setMissingReplacementType(Cell.ContentType value)
Sets the data type of the replacement value.- Parameters:
value
- the replacement type
-
getMissingReplacementType
public Cell.ContentType getMissingReplacementType()
Returns the data type of the replacement value.- Returns:
- the replacement type
-
missingReplacementTypeTipText
public String missingReplacementTypeTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setTransformer
public void setTransformer(CallableActorReference value)
Sets the reference to the callable transformer.- Parameters:
value
- the reference
-
getTransformer
public CallableActorReference getTransformer()
Returns the reference to the callable transformer.- Returns:
- the conversion
-
transformerTipText
public String transformerTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
findCallableActor
protected Actor findCallableActor()
Tries to find the callable actor referenced by its callable name.- Returns:
- the callable actor or null if not found
-
hasCallableActor
public boolean hasCallableActor()
Checks whether a reference to the callable actor is currently available.- Returns:
- true if a reference is available
- See Also:
getCallableActor()
-
getCallableActor
public Actor getCallableActor()
Returns the currently set callable actor.- Specified by:
getCallableActor
in interfaceCallableActorUser
- Returns:
- the actor, can be null
-
pruneBackup
protected void pruneBackup()
Removes entries from the backup.- Overrides:
pruneBackup
in classAbstractActor
- See Also:
AbstractActor.reset()
-
backupState
protected Hashtable<String,Object> backupState()
Backs up the current state of the actor before update the variables.- Overrides:
backupState
in classAbstractTransformer
- Returns:
- the backup
- See Also:
AbstractActor.updateVariables()
,AbstractActor.restoreState(Hashtable)
-
restoreState
protected void restoreState(Hashtable<String,Object> state)
Restores the state of the actor before the variables got updated.- Overrides:
restoreState
in classAbstractTransformer
- Parameters:
state
- the backup of the state to restore from- See Also:
AbstractActor.updateVariables()
,AbstractActor.backupState()
-
setUpCallableActor
protected String setUpCallableActor()
Configures the callable actor.- Returns:
- null if successful, otherwise error message
-
setUp
public String setUp()
Initializes the item for flow execution.- Specified by:
setUp
in interfaceActor
- Overrides:
setUp
in classAbstractActor
- Returns:
- null if everything is fine, otherwise error message
- See Also:
AbstractActor.reset()
-
transformCell
protected String transformCell(Cell cell, SpreadSheet sheet)
Applies the transformer to the cell.- Parameters:
cell
- the cell to transformsheet
- the sheet to process- Returns:
- null if successful, otherwise error message
-
doExecute
protected String doExecute()
Executes the flow item.- Specified by:
doExecute
in classAbstractActor
- Returns:
- null if everything is fine, otherwise error message
-
-