Program: bbtk
Module: $RCSfile: bbtkAtomicBlackBox.cxx,v $
Language: C++
- Date: $Date: 2008/04/08 06:59:29 $
- Version: $Revision: 1.3 $
+ Date: $Date: 2008/04/24 10:11:27 $
+ Version: $Revision: 1.6 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
AtomicBlackBox::AtomicBlackBox(const std::string &name, bool alloc)
: BlackBox(name)
{
- bbtkDebugMessageInc("Kernel",7,
- "AtomicBlackBox::AtomicBlackBox(\""
- <<name<<"\")"<<std::endl);
- bbtkDebugDecTab("Kernel",7);
+ bbtkDebugMessage("object",3,
+ "==> AtomicBlackBox::AtomicBlackBox(\""
+ <<name<<"\")"<<std::endl);
+ bbtkDebugMessage("object",3,
+ "<== AtomicBlackBox::AtomicBlackBox(\""
+ <<name<<"\")"<<std::endl);
}
//=========================================================================
bool alloc)
: BlackBox(from,name)
{
- bbtkDebugMessageInc("Kernel",7,
- "AtomicBlackBox::AtomicBlackBox("
- <<from.bbGetFullName()<<",\""
- <<name<<"\")"<<std::endl);
- bbtkDebugDecTab("Kernel",7);
+ bbtkDebugMessage("object",3,
+ "==>AtomicBlackBox::AtomicBlackBox("
+ <<from.bbGetFullName()<<",\""
+ <<name<<"\")"<<std::endl);
+ bbtkDebugMessage("object",3,
+ "<==AtomicBlackBox::AtomicBlackBox("
+ <<from.bbGetFullName()<<",\""
+ <<name<<"\")"<<std::endl);
}
//=========================================================================
/// Destructor
AtomicBlackBox::~AtomicBlackBox()
{
- bbtkDebugMessage("Kernel",7,"AtomicBlackBox::~AtomicBlackBox()"
- <<std::endl);
+ bbtkDebugMessage("object",3,"==> AtomicBlackBox::~AtomicBlackBox()"
+ <<std::endl);
+ bbtkDebugMessage("object",3,"<== AtomicBlackBox::~AtomicBlackBox()"
+ <<std::endl);
}
//=========================================================================
-
+
//=========================================================================
/// Main processing method of the box.
- IOStatus AtomicBlackBox::bbBackwardUpdate( Connection* caller )
+ IOStatus AtomicBlackBox::bbBackwardUpdate( Connection::Pointer caller )
{
- bbtkDebugMessageInc("Process",1,
+ bbtkDebugMessageInc("process",3,
"=> AtomicBlackBox::bbBackwardUpdate("
<<(caller?caller->GetFullName():"0")<<") ["
<<bbGetFullName()<<"]"<<std::endl);
- if (bbGetExecuting())
- {
- bbtkWarning(bbGetFullName()<<" : Cyclic execution stopped");
- return UPTODATE;
- }
- bbSetExecuting(true);
-
- bbtkDebugMessage("Process",5,"Initial Status = "<<bbGetStatus()
+ bbtkDebugMessage("process",5,"Initial Status = "<<bbGetStatus()
<<std::endl);
- bbtkDebugMessage("Process",5,"BoxProcessMode = "
+ bbtkDebugMessage("process",5,"BoxProcessMode = "
<<bbGetInputBoxProcessMode()<<std::endl);
- /*
- if ( bbGetStatus() == UPDATING )
- {
- bbtkMessage("Warning",1,"!! WARNING !! Cyclic pipeline execution (bbBackwardUpdate ["<<bbGetFullName()<<"] reentered). This may indicate an error in pipeline conception"<<std::endl);
- // return UPTODATE;
- bbSetStatus(MODIFIED);
- }
- */
if ( ( bbGetStatus() == MODIFIED ) ||
( bbBoxProcessModeIsAlways() ) )
bool wasExecuting = bbGlobalGetSomeBoxExecuting();
bbGlobalSetSomeBoxExecuting(true);
- // bbSetStatus(UPDATING);
-
// Updates its inputs
IOStatus s = bbUpdateInputs();
- bbtkDebugMessage("Process",6,"Inputs post-update status = "<<s<<std::endl);
+ 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
}
else
{
- bbtkDebugMessage("Process",5,"Up-to-date : nothing to do"<<std::endl);
+ bbtkDebugMessage("process",5,"Up-to-date : nothing to do"<<std::endl);
}
- bbtkDebugMessage("Process",5,"Final Status = "
+ bbtkDebugMessage("process",5,"Final Status = "
<<bbGetStatus()<<std::endl);
- bbtkDebugMessage("Process",1,
+ bbtkDebugMessage("process",3,
"<= AtomicBlackBox::bbBackwardUpdate() ["
<<bbGetFullName()<<"]"<<std::endl);
- bbtkDebugDecTab("Process",1);
- bbSetExecuting(false);
return bbGetStatus();
bbtkDebugDecTab("Data",7);
}
//=========================================================================
+
+
+
+ //==========================================================================
+ std::string AtomicBlackBox::GetObjectInfo() const
+ {
+ std::stringstream i;
+ return i.str();
+ }
+ //==========================================================================
+
+ //==========================================================================
+ size_t AtomicBlackBox::GetObjectSize() const
+ {
+ return sizeof(*this);
+ }
+ //==========================================================================
+ //==========================================================================
+ size_t AtomicBlackBox::GetObjectRecursiveSize() const
+ {
+ size_t s = GetObjectSize();
+ return s;
+ }
+ //==========================================================================
+
+
}
// EO namespace bbtk