Package adams.flow.standalone
Class DeserializeToStorage
- java.lang.Object
-
- adams.core.logging.LoggingObject
-
- adams.core.logging.CustomLoggingLevelObject
-
- adams.core.option.AbstractOptionHandler
-
- adams.flow.core.AbstractActor
-
- adams.flow.standalone.AbstractStandalone
-
- adams.flow.standalone.DeserializeToStorage
-
- All Implemented Interfaces:
AdditionalInformationHandler
,CleanUpHandler
,Destroyable
,GlobalInfoSupporter
,ModelFileHandler
,LoggingLevelHandler
,LoggingSupporter
,OptionHandler
,QuickInfoSupporter
,ShallowCopySupporter<Actor>
,SizeOfHandler
,Stoppable
,StoppableWithFeedback
,VariablesInspectionHandler
,VariableChangeListener
,StorageUpdater
,Actor
,ErrorHandler
,Serializable
,Comparable
public class DeserializeToStorage extends AbstractStandalone implements ModelFileHandler, StorageUpdater
Deserializes a model from a file with the specified object reader and stores it directly in storage.
It is also possible to define multiple storage name / file name pairs, to make the deserialization of large amounts of files more efficient. Storage name and/or file name can be variables as well (@{...})
-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: DeserializeToStorage
-annotation <adams.core.base.BaseAnnotation> (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 execution at this level gets stopped in case this actor encounters an error; the error gets propagated; useful for critical actors. default: false
-silent <boolean> (property: silent) If enabled, then no errors are output in the console; Note: the enclosing actor handler must have this enabled as well. default: false
-model-file <adams.core.io.PlaceholderFile> (property: modelFile) The file to deserialize and put into storage. default: ${CWD}
-reader <adams.data.io.input.AbstractObjectReader> (property: reader) The reader to use for loading the model. default: adams.data.io.input.SerializedObjectReader
-cache <java.lang.String> (property: cache) The name of the cache to store the value in; uses the regular storage if left empty. default:
-storage-name <adams.flow.control.StorageName> (property: storageName) The name to store the model under. default: storage
-storage-file-pair <adams.core.base.BaseKeyValuePair> [-storage-file-pair ...] (property: storageFilePairs) The pairs of storage name and file name. default:
- Author:
- FracPete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description protected String
m_Cache
the name of the LRU cache.protected PlaceholderFile
m_ModelFile
the file to deserialize.protected AbstractObjectReader
m_Reader
the object reader to use.protected List<BaseKeyValuePair>
m_StorageFilePairs
the storage/file pairs.protected StorageName
m_StorageName
the storage name to store the model under.-
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 DeserializeToStorage()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
addStorageFilePair(BaseKeyValuePair value)
Adds the variable name/value pair.String
cacheTipText()
Returns the tip text for this property.void
defineOptions()
Adds options to the internal list of options.protected String
doExecute()
Executes the flow item.String
getCache()
Returns the name of the LRU cache to use, regular storage if left empty.PlaceholderFile
getModelFile()
Returns the file to load the model from.String
getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.AbstractObjectReader
getReader()
Returns the reader to use for loading the model.BaseKeyValuePair[]
getStorageFilePairs()
Returns the pairs of storage name / file name.StorageName
getStorageName()
Returns the name of the stored value.String
globalInfo()
Returns a string describing the object.protected void
initialize()
Initializes the members.boolean
isUpdatingStorage()
Returns whether storage items are being updated.String
modelFileTipText()
Returns the tip text for this property.protected String
read(PlaceholderFile file, StorageName name)
Reads the file and stores the object in storage.String
readerTipText()
Returns the tip text for this property.void
setCache(String value)
Sets the name of the LRU cache to use, regular storage if left empty.void
setModelFile(PlaceholderFile value)
Sets the file to load the model from.void
setReader(AbstractObjectReader value)
Sets the reader to use for loading the model.void
setStorageFilePairs(BaseKeyValuePair[] value)
Sets the storage name / file name pairs.void
setStorageName(StorageName value)
Sets the name of the stored value.String
setUp()
Initializes the item for flow execution.String
storageFilePairsTipText()
Returns the tip text for this property.String
storageNameTipText()
Returns the tip text for this property.-
Methods inherited from class adams.flow.standalone.AbstractStandalone
preExecute
-
Methods inherited from class adams.flow.core.AbstractActor
annotationsTipText, backupState, canInspectOptions, canPerformSetUpCheck, cleanUp, compareTo, configureLogger, destroy, equals, execute, 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, postExecute, pruneBackup, pruneBackup, reset, restoreState, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setVariables, shallowCopy, shallowCopy, silentTipText, sizeOf, skipTipText, stopExecution, stopExecution, stopFlowOnErrorTipText, updateDetectedVariables, updatePrefix, updateVariables, variableChanged, wrapUp
-
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
toCommandLine
-
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
-
-
-
-
Field Detail
-
m_ModelFile
protected PlaceholderFile m_ModelFile
the file to deserialize.
-
m_Reader
protected AbstractObjectReader m_Reader
the object reader to use.
-
m_Cache
protected String m_Cache
the name of the LRU cache.
-
m_StorageName
protected StorageName m_StorageName
the storage name to store the model under.
-
m_StorageFilePairs
protected List<BaseKeyValuePair> m_StorageFilePairs
the storage/file pairs.
-
-
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
-
initialize
protected void initialize()
Initializes the members.- Overrides:
initialize
in classAbstractActor
-
setModelFile
public void setModelFile(PlaceholderFile value)
Sets the file to load the model from.- Specified by:
setModelFile
in interfaceModelFileHandler
- Parameters:
value
- the model file
-
getModelFile
public PlaceholderFile getModelFile()
Returns the file to load the model from.- Specified by:
getModelFile
in interfaceModelFileHandler
- Returns:
- the model file
-
modelFileTipText
public String modelFileTipText()
Returns the tip text for this property.- Specified by:
modelFileTipText
in interfaceModelFileHandler
- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setReader
public void setReader(AbstractObjectReader value)
Sets the reader to use for loading the model.- Parameters:
value
- the reader
-
getReader
public AbstractObjectReader getReader()
Returns the reader to use for loading the model.- Returns:
- the reader
-
readerTipText
public String readerTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setCache
public void setCache(String value)
Sets the name of the LRU cache to use, regular storage if left empty.- Parameters:
value
- the cache
-
getCache
public String getCache()
Returns the name of the LRU cache to use, regular storage if left empty.- Returns:
- the cache
-
cacheTipText
public String cacheTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setStorageName
public void setStorageName(StorageName value)
Sets the name of the stored value.- Parameters:
value
- the name
-
getStorageName
public StorageName getStorageName()
Returns the name of the stored value.- 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.
-
addStorageFilePair
public void addStorageFilePair(BaseKeyValuePair value)
Adds the variable name/value pair.- Parameters:
value
- the pair to add
-
setStorageFilePairs
public void setStorageFilePairs(BaseKeyValuePair[] value)
Sets the storage name / file name pairs.- Parameters:
value
- the pairs
-
getStorageFilePairs
public BaseKeyValuePair[] getStorageFilePairs()
Returns the pairs of storage name / file name.- Returns:
- the pairs
-
storageFilePairsTipText
public String storageFilePairsTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
isUpdatingStorage
public boolean isUpdatingStorage()
Returns whether storage items are being updated.- Specified by:
isUpdatingStorage
in interfaceStorageUpdater
- Returns:
- true if storage items are updated
-
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
-
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()
-
read
protected String read(PlaceholderFile file, StorageName name)
Reads the file and stores the object in storage.- Parameters:
file
- the file to readname
- the storage name to use- 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
-
-