]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkAtomicBlackBox.cxx
*** empty log message ***
[bbtk.git] / kernel / src / bbtkAtomicBlackBox.cxx
index 3f46046d14c92b0f4e2b9255ec8b4f2e25628548..b826efcc7e31676d93e57184a35c8f6e3e64aebf 100644 (file)
@@ -3,8 +3,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkAtomicBlackBox.cxx,v $
   Language:  C++
-  Date:      $Date: 2008/03/20 15:27:56 $
-  Version:   $Revision: 1.2 $
+  Date:      $Date: 2008/06/27 08:12:46 $
+  Version:   $Revision: 1.7 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See Doc/License.txt or
@@ -30,10 +30,12 @@ namespace bbtk
   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);
   }
   //========================================================================= 
   
@@ -44,11 +46,14 @@ namespace bbtk
                 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);
     
   }
   //=========================================================================
@@ -58,60 +63,58 @@ namespace bbtk
   ///  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,
-            "=> AtomicBlackBox::bbBackwardUpdate() ["
-            <<bbGetFullName()<<"]"<<std::endl);
+    bbtkDebugMessageInc("process",3,
+                       "=> AtomicBlackBox::bbBackwardUpdate("
+                       <<(caller?caller->GetFullName():"0")<<") ["
+                       <<bbGetFullName()<<"]"<<std::endl);
     
-    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);
+       bbSetStatus(UPDATING);
+       
+       bool wasExecuting = bbGlobalGetSomeBoxExecuting();
+        bbGlobalSetSomeBoxExecuting(true);
 
         // 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
+       IOStatus new_status;
         if ( ( s == UPTODATE ) && 
             ( ! bbBoxProcessModeIsAlways() ) ) 
             {
-                bbSetStatus(UPTODATE);
+                new_status = UPTODATE;
             }
         else 
             {
                 // else it remains MODIFIED
-                bbSetStatus(MODIFIED);
+                 new_status = MODIFIED;
             }
+       bbSetStatus(new_status);
 
         // User process
         bbProcess();
@@ -124,15 +127,15 @@ namespace bbtk
       }
     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);
+
 
     return bbGetStatus();
 
@@ -240,6 +243,32 @@ namespace bbtk
     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