]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkBlackBoxOutputConnector.cxx
Forgot this one
[bbtk.git] / kernel / src / bbtkBlackBoxOutputConnector.cxx
index 8024663d81f4734857e704d718bfea3bdf893b94..e6ba06c5c9780ba86018a56923b4f6537e8f4b60 100644 (file)
@@ -2,8 +2,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkBlackBoxOutputConnector.cxx,v $
   Language:  C++
-  Date:      $Date: 2008/12/08 12:54:00 $
-  Version:   $Revision: 1.9 $
+  Date:      $Date: 2009/06/08 14:50:03 $
+  Version:   $Revision: 1.13 $
 =========================================================================*/
 
 /* ---------------------------------------------------------------------
 namespace bbtk
 {
 
+  //========================================================================
+  /// The Pimpl
+  class BlackBoxOutputConnector::Pimpl
+  {
+  public:
+    Pimpl() : mStatus(OUTOFDATE) {}
+    Pimpl(const Pimpl&) {}
+   /// 
+    BlackBoxWeakPointer mBox;
+    /// The vector of output connections
+    ConnectionVector mConnection;
+    /// The status of the output 
+    IOStatus mStatus;
+    /// The output changed signal 
+    BlackBox::OutputChangeSignalType mChangeSignal;
+
+
+  };
+  //========================================================================
+
+  //========================================================================
+  BBTK_IMPL_PIMPL(BlackBoxOutputConnector)
+  //========================================================================
+
+
   //======================================================================
-  BlackBoxOutputConnector::BlackBoxOutputConnector() 
-    : mStatus(OUTOFDATE)
+  BlackBoxOutputConnector::BlackBoxOutputConnector(BlackBox::Pointer b) 
   {
-    bbtkDebugMessage("Kernel",9,"BlackBoxOutputConnector::BlackBoxOutputConnector()"<<std::endl);
+    bbtkDebugMessage("kernel",9,
+                    "["<<b->bbGetName()
+                    <<"] BlackBoxOutputConnector()"<<std::endl);
+    PimplConstruct();
+    p->mBox = b;
   }
   //======================================================================
 
@@ -54,8 +82,8 @@ namespace bbtk
   //======================================================================
   BlackBoxOutputConnector::~BlackBoxOutputConnector() 
   {
-    bbtkDebugMessage("Kernel",9,
-                    "==> BlackBoxOutputConnector::~BlackBoxOutputConnector()"
+    bbtkDebugMessage("kernel",9,
+                    "[DEAD BOX] ==> ~BlackBoxOutputConnector()"
                     <<std::endl);
     /*
     ConnectionVector::iterator i;
@@ -64,9 +92,11 @@ namespace bbtk
         ++i)
       (*i) = Connection::WeakPointer();
     */
-    mConnection.clear();
-    bbtkDebugMessage("Kernel",9,
-                    "<== BlackBoxOutputConnector::~BlackBoxOutputConnector()"
+    p->mConnection.clear();
+    PimplDestruct();
+  
+    bbtkDebugMessage("kernel",9,
+                    "[DEAD BOX] <== ~BlackBoxOutputConnector()"
                     <<std::endl);
   }
   //======================================================================
@@ -75,9 +105,11 @@ namespace bbtk
   ///
   void BlackBoxOutputConnector::SetConnection(Connection* c)
   {
-    bbtkDebugMessage("Kernel",9,"BlackBoxOutputConnector::SetConnection("
+    bbtkDebugMessage("kernel",9,
+                    "["<<p->mBox.lock()->bbGetName()
+                    <<"] BlackBoxOutputConnector::SetConnection("
                     <<c<<")"<<std::endl);
-    mConnection.push_back(c);
+    p->mConnection.push_back(c);
     //    AddChangeObserver(boost::bind(&Connection::SignalChange,c));
   }
   //======================================================================
@@ -86,116 +118,98 @@ namespace bbtk
   //======================================================================
   void BlackBoxOutputConnector::UnsetConnection(Connection* c)
   {
-    bbtkDebugMessageInc("Kernel",9,"BlackBoxOutputConnector::UnsetConnection("
+    bbtkDebugMessage("kernel",9,"["<<p->mBox.lock()->bbGetName()
+                    <<"] BlackBoxOutputConnector::UnsetConnection("
                     <<c<<")"<<std::endl);
 
     if (!c) 
       {
-       bbtkInternalError("BlackBoxOutputConnector::UnsetConnection("<<c<<") : invalid connection");
+       bbtkInternalError(p->mBox.lock()->bbGetFullName()
+                         <<": BlackBoxOutputConnector::UnsetConnection("
+                         <<c<<") : invalid connection");
 
       }
     //    c->Check();
     //Connection::WeakPointer w(c);
     ConnectionVector::iterator i;
     //  = find(mConnection.begin(),mConnection.end(),c);
-    for (i=mConnection.begin();
-        i!=mConnection.end();
+    for (i=p->mConnection.begin();
+        i!=p->mConnection.end();
         ++i)
       {
        if (*i==c) break;
       }
-    if (i==mConnection.end())
+    if (i==p->mConnection.end())
       {
-       bbtkInternalError("BlackBoxOutputConnector::UnsetConnection("<<c<<") : connection is absent from connections list");
+       bbtkInternalError(p->mBox.lock()->bbGetFullName()
+                         <<": BlackBoxOutputConnector::UnsetConnection("
+                         <<c
+                         <<") : connection is absent from connections list");
       }
-    mConnection.erase(i);
+    p->mConnection.erase(i);
     //    RemoveChangeObserver(boost::bind(&Connection::SignalChange,c));
 
-    bbtkDebugDecTab("Kernel",9);
+
   }
   //======================================================================
-
   
-   //======================================================================
-  void BlackBoxOutputConnector::SignalChange( BlackBox::Pointer box,
-                                             const std::string& output )
-  {
-    bbtkDebugMessage("change",2,
-                    "==> BlackBoxOutputConnector::SignalChange("
-                    <<box->bbGetFullName()<<",'"
-                    <<output<<"','"<<GetIOStatusString(mStatus)<<"') ["
-                    <<this<<"]"
-                    <<std::endl);
-
-    mChangeSignal(box,output,mStatus);
-
-    bbtkDebugMessage("change",2,
-                    "<== BlackBoxOutputConnector::SignalChange("
-                    <<box->bbGetFullName()<<",'"
-                    <<output<<"','"<<GetIOStatusString(mStatus)<<"') ["
-                    <<this<<"]"
-                    <<std::endl);
+  //======================================================================
+  const BlackBoxOutputConnector::ConnectionVector& 
+  BlackBoxOutputConnector::GetConnectionVector() const
+  { 
+    return p->mConnection; 
   }
   //======================================================================
- /*
-  void BlackBoxOutputConnector::SetModifiedStatus()
-  {
-    bbtkDebugMessage("modified",2,
-                    "==> BlackBoxOutputConnector::SetModifiedStatus() ["
-                    <<this<<"]"
-                    <<std::endl);
-    ConnectionVector::iterator i;
-    for (i=mConnection.begin();i!=mConnection.end();++i) 
-      {
-       (*i)->SetModifiedStatus();
-      }
-    
-    
-   }
-  */
-  /*
+  
   //======================================================================
-  void BlackBoxOutputConnector::SetChangeTime(const ChangeTime& t)
+  /// Returns the status of the input 
+  IOStatus BlackBoxOutputConnector::GetStatus() const 
+  { 
+    return p->mStatus; 
+  }
+  //======================================================================
+
+  //======================================================================
+  /// Sets the status of the input 
+  void BlackBoxOutputConnector::SetStatus( IOStatus s ) 
   {
-    bbtkDebugMessage("change",2,
-                    "==> BlackBoxOutputConnector::SetChangeTime("<<t<<") ["
-                    <<this<<"]"
-                    <<std::endl);
-    if (mChangeTime.Set(t))
-      {
-       mChangeSignal(this);
-      }
-    bbtkDebugMessage("change",2,
-                    "<== BlackBoxOutputConnector::SetChangeTime("<<t<<") ["
-                    <<this<<"]"
-                    <<std::endl);
+    p->mStatus = s; 
   }
   //======================================================================
-  */
-  /*
- //======================================================================
-  void BlackBoxOutputConnector::SetChangeTimeToCurrentTime()
+  
+  //======================================================================
+  void BlackBoxOutputConnector::SignalChange( BlackBox::Pointer box,
+                                             const std::string& output )
   {
+    IOStatus s = OUTOFDATE; //mStatus;
+    //if (s==UPTODATE) s=MODIFIED;
+    
     bbtkDebugMessage("change",2,
-                    "==> BlackBoxOutputConnector::SetChangeTimetoCurrentTime() ["
+                    "["<<box->bbGetName()
+                    <<"] ==> BlackBoxOutputConnector::SignalChange('"
+                    <<output<<"','"<<GetIOStatusString(s)<<"') ["
                     <<this<<"]"
                     <<std::endl);
-    mChangeTime.Set(ChangeTime::GetCurrentTime());
-    mChangeSignal(this);
+    
+    //    std::cout<<"BlackBoxOutputConnector::SignalChange("
+    //      <<box->bbGetName()<<",'"
+    //      <<output<<"')"<<std::endl;
+    p->mChangeSignal(box,output,s);
     
     bbtkDebugMessage("change",2,
-                    "<==> BlackBoxOutputConnector::SetChangeTimetoCurrentTime() ["
+                    "["<<box->bbGetName()
+                    <<"] <== BlackBoxOutputConnector::SignalChange('"
+                    <<output<<"','"<<GetIOStatusString(s)<<"') ["
                     <<this<<"]"
                     <<std::endl);
   }
   //======================================================================
-  */
-
 
   //======================================================================
   void BlackBoxOutputConnector::AddChangeObserver(OutputChangeCallbackType f)
   { 
-    mChangeSignal.connect(f); 
+    //    std::cout << "BlackBoxOutputConnector::AddChangeObserver" << std::endl;
+    p->mChangeSignal.connect(f); 
   }
   //======================================================================