]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkAtomicBlackBox.cxx
*** empty log message ***
[bbtk.git] / kernel / src / bbtkAtomicBlackBox.cxx
index 6b8d402ac8a5da09bed23f9547c6eca49697b1af..b826efcc7e31676d93e57184a35c8f6e3e64aebf 100644 (file)
@@ -3,8 +3,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkAtomicBlackBox.cxx,v $
   Language:  C++
-  Date:      $Date: 2008/02/07 11:06:37 $
-  Version:   $Revision: 1.1 $
+  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,25 +30,30 @@ 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);
   }
   //========================================================================= 
   
   //=========================================================================
   /// Constructor from an existing box (copy) with a new name 
   AtomicBlackBox::AtomicBlackBox(AtomicBlackBox& from, 
-                            const std::string &name, 
-                            bool alloc)
+                const std::string &name, 
+                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,88 +63,79 @@ namespace bbtk
   ///  Destructor
   AtomicBlackBox::~AtomicBlackBox()
   {
-    bbtkDebugMessage("Kernel",7,"AtomicBlackBox::~AtomicBlackBox()"
+    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() ["
+    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);
+    bbtkDebugMessage("process",5,"Initial Status  = "<<bbGetStatus()
+                    <<std::endl);
+    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() ) )
+        ( bbBoxProcessModeIsAlways() ) )
       {
-       bool wasExecuting = bbGlobalGetSomeBoxExecuting();
-       bbGlobalSetSomeBoxExecuting(true);
-
-       //      bbSetStatus(UPDATING);
 
-       // Updates its inputs
-       IOStatus s = bbUpdateInputs();
+       bbSetStatus(UPDATING);
        
-       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
-       if ( ( s == UPTODATE ) && 
-            ( ! bbBoxProcessModeIsAlways() ) ) 
-         {
-           bbSetStatus(UPTODATE);
-         }
-       else 
-         {
-           // else it remains MODIFIED
-           bbSetStatus(MODIFIED);
-         }     
-
-       // Creates the window (WxBlackbox)
-       //      bbCreateWindow();
-
-       // Children update (WxContainerBlackBox)
-       //      bbUpdateChildren(caller);       
-
-       // User process
-       bbProcess();
-
-       // Displays the window (WxBlackbox)
-       bbShowWindow(caller);
+       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();
 
-       bbGlobalSetSomeBoxExecuting(wasExecuting);
+        // Displays the window (WxBlackbox)
+        bbShowWindow(caller);
 
+        bbGlobalSetSomeBoxExecuting(wasExecuting);
 
       }
     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    = "
-                    <<bbGetStatus()<<std::endl);
-    bbtkDebugMessage("Process",1,
-                    "<= AtomicBlackBox::bbBackwardUpdate() ["
-                    <<bbGetFullName()<<"]"<<std::endl);
-    bbtkDebugDecTab("Process",1);
+    bbtkDebugMessage("process",5,"Final Status    = "
+            <<bbGetStatus()<<std::endl);
+    bbtkDebugMessage("process",3,
+            "<= AtomicBlackBox::bbBackwardUpdate() ["
+            <<bbGetFullName()<<"]"<<std::endl);
+
 
     return bbGetStatus();
 
@@ -151,11 +147,12 @@ namespace bbtk
   Data AtomicBlackBox::bbGetOutput( const std::string &name )
   {
     bbtkDebugMessageInc("Data",7,
-                       "AtomicBlackBox::bbGetOutput(\""<<name<<"\") ["
-                       <<bbGetFullName()<<"]"
-                       <<std::endl);
+            "AtomicBlackBox::bbGetOutput(\""<<name<<"\") ["
+            <<bbGetFullName()<<"]"
+            <<std::endl);
     
-    Data p = ((AtomicBlackBoxOutputDescriptor*)bbGetDescriptor()->GetOutputDescriptor(name))->GetGetFunctor()->Get(this);
+    Data p = ((AtomicBlackBoxOutputDescriptor*)bbGetDescriptor()
+                ->GetOutputDescriptor(name))->GetGetFunctor()->Get(this);
     
     bbtkDebugDecTab("Data",7);
     return p;
@@ -168,11 +165,12 @@ namespace bbtk
   Data AtomicBlackBox::bbGetInput( const std::string &name ) 
   {
     bbtkDebugMessageInc("Data",7,
-                       "AtomicBlackBox::bbGetInput(\""<<name<<"\") ["
-                       <<bbGetFullName()<<"]"
-                       <<std::endl);  
+            "AtomicBlackBox::bbGetInput(\""<<name<<"\") ["
+            <<bbGetFullName()<<"]"
+            <<std::endl);  
     
-    Data p = ((AtomicBlackBoxInputDescriptor*)bbGetDescriptor()->GetInputDescriptor(name))->GetGetFunctor()->Get(this);
+    Data p = ((AtomicBlackBoxInputDescriptor*)bbGetDescriptor()
+                ->GetInputDescriptor(name))->GetGetFunctor()->Get(this);
     
     bbtkDebugDecTab("Data",7);
     return p;
@@ -185,11 +183,12 @@ namespace bbtk
   void AtomicBlackBox::bbSetOutput( const std::string &name, Data data)
   {
     bbtkDebugMessageInc("Data",7,
-                       "AtomicBlackBox::bbSetOutput(\""<<name<<"\",data) ["
-                       <<bbGetFullName()<<"]"
-                       <<std::endl); 
+            "AtomicBlackBox::bbSetOutput(\""<<name<<"\",data) ["
+            <<bbGetFullName()<<"]"
+            <<std::endl); 
     
-    ((AtomicBlackBoxOutputDescriptor*)bbGetDescriptor()->GetOutputDescriptor(name))->GetSetFunctor()->Set(this,data);
+    ((AtomicBlackBoxOutputDescriptor*)bbGetDescriptor()
+        ->GetOutputDescriptor(name))->GetSetFunctor()->Set(this,data);
     
     bbtkDebugDecTab("Data",7);
   }  
@@ -198,19 +197,21 @@ namespace bbtk
   
   //=========================================================================
   ///  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,
-                       "AtomicBlackBox::bbSetInput(\""<<name<<"\",data) ["
-                       <<bbGetFullName()<<"]"
-                       <<std::endl);  
+            "AtomicBlackBox::bbSetInput(\""<<name<<"\",data) ["
+            <<bbGetFullName()<<"]"
+            <<std::endl);  
     ((AtomicBlackBoxInputDescriptor*)bbGetDescriptor()->GetInputDescriptor(name))->GetSetFunctor()->Set(this,data);
     
     if (setModified) 
-      {
-       bbSetModifiedStatus();
-      }
+        {
+            bbSetModifiedStatus();
+        }
     
     bbtkDebugDecTab("Data",7);
   }
@@ -218,25 +219,56 @@ namespace bbtk
   
     //=========================================================================
   ///  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,
-                       "AtomicBlackBox::bbBruteForceSetInputPointer(\""
-                       <<name<<"\",data) ["
-                       <<bbGetFullName()<<"]"
-                       <<std::endl);  
-    ((AtomicBlackBoxInputDescriptor*)bbGetDescriptor()->GetInputDescriptor(name))->GetSetFunctor()->BruteForceSetPointer(this,data);
+            "AtomicBlackBox::bbBruteForceSetInputPointer(\""
+            <<name<<"\",data) ["
+            <<bbGetFullName()<<"]"
+            <<std::endl);  
+    ((AtomicBlackBoxInputDescriptor*)bbGetDescriptor()
+        ->GetInputDescriptor(name))->GetSetFunctor()
+            ->BruteForceSetPointer(this,data);
     
     if (setModified) 
       {
-       bbSetModifiedStatus();
+        bbSetModifiedStatus();
       }
     
     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