Program: bbtk
Module: $RCSfile: bbtkAtomicBlackBox.cxx,v $
Language: C++
- Date: $Date: 2008/10/17 08:18:12 $
- Version: $Revision: 1.8 $
+ Date: $Date: 2008/12/11 09:50:34 $
+ Version: $Revision: 1.12 $
=========================================================================*/
/* ---------------------------------------------------------------------
- //=========================================================================
- /// Main processing method of the box.
- IOStatus AtomicBlackBox::bbBackwardUpdate( Connection::Pointer caller )
- {
- bbtkDebugMessageInc("process",3,
- "=> AtomicBlackBox::bbBackwardUpdate("
- <<(caller?caller->GetFullName():"0")<<") ["
- <<bbGetFullName()<<"]"<<std::endl);
-
- bbtkDebugMessage("process",5,"Initial Status = "<<bbGetStatus()
- <<std::endl);
- bbtkDebugMessage("process",5,"BoxProcessMode = "
- <<bbGetInputBoxProcessMode()<<std::endl);
-
-
- if ( ( bbGetStatus() == MODIFIED ) ||
- ( bbBoxProcessModeIsAlways() ) )
- {
-
- bbSetStatus(UPDATING);
-
- bool wasExecuting = bbGlobalGetSomeBoxExecuting();
- bbGlobalSetSomeBoxExecuting(true);
-
- // Updates its inputs
- IOStatus s = bbUpdateInputs();
-
- bbtkDebugMessage("process",6,"Inputs post-update status = "<<s<<std::endl);
- // If all inputs are in UPTODATE post-update status
- // and mProcessMode is not "Always"
- // then the box is now UPTODATE
- IOStatus new_status;
- if ( ( s == UPTODATE ) &&
- ( ! bbBoxProcessModeIsAlways() ) )
- {
- new_status = UPTODATE;
- }
- else
- {
- // else it remains MODIFIED
- new_status = MODIFIED;
- }
- bbSetStatus(new_status);
-
- // User process
- bbProcess();
-
- // Displays the window (WxBlackbox)
- bbShowWindow(caller);
-
- bbGlobalSetSomeBoxExecuting(wasExecuting);
-
- }
- else
- {
- bbtkDebugMessage("process",5,"Up-to-date : nothing to do"<<std::endl);
- }
-
- bbtkDebugMessage("process",5,"Final Status = "
- <<bbGetStatus()<<std::endl);
- bbtkDebugMessage("process",3,
- "<= AtomicBlackBox::bbBackwardUpdate() ["
- <<bbGetFullName()<<"]"<<std::endl);
-
-
- return bbGetStatus();
-
- }
- //=========================================================================
-
//=========================================================================
Data AtomicBlackBox::bbGetOutput( const std::string &name )
{
//=========================================================================
/// Sets the data of the input called <name>
- void AtomicBlackBox::bbSetInput(
- const std::string &name,
- Data data,
- bool setModified )
+ void AtomicBlackBox::bbSetInput(const std::string &name,
+ Data data,
+ bool setModified )
{
- bbtkDebugMessageInc("Data",7,
+ bbtkDebugMessageInc("data",7,
"AtomicBlackBox::bbSetInput(\""<<name<<"\",data) ["
<<bbGetFullName()<<"]"
<<std::endl);
((AtomicBlackBoxInputDescriptor*)bbGetDescriptor()->GetInputDescriptor(name))->GetSetFunctor()->Set(this,data);
if (setModified)
- {
- bbSetModifiedStatus();
- }
+ {
+ bbSetStatusAndPropagate(bbGetInputConnectorMap().find(name)->second,
+ MODIFIED);
+ }
- bbtkDebugDecTab("Data",7);
+ bbtkDebugDecTab("data",7);
}
//=========================================================================
- //=========================================================================
+ //=========================================================================
/// Sets the data of the input called <name>
- void AtomicBlackBox::bbBruteForceSetInputPointer
- (
- const std::string &name,
- void* data,
- bool setModified
- )
+ void AtomicBlackBox::bbBruteForceSetInputPointer(const std::string &name,
+ void* data,
+ bool setModified
+ )
{
- bbtkDebugMessageInc("Data",7,
+ bbtkDebugMessageInc("data",7,
"AtomicBlackBox::bbBruteForceSetInputPointer(\""
<<name<<"\",data) ["
<<bbGetFullName()<<"]"
if (setModified)
{
- bbSetModifiedStatus();
+ bbSetStatusAndPropagate(bbGetInputConnectorMap().find(name)->second,
+ MODIFIED);
}
- bbtkDebugDecTab("Data",7);
+ bbtkDebugDecTab("data",7);
}
//=========================================================================