]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkBlackBoxInputConnector.cxx
*** empty log message ***
[bbtk.git] / kernel / src / bbtkBlackBoxInputConnector.cxx
index 5180428d18368d55b9574a932366decdca485bca..a2355debee3a22923e2279b16ad9b15a6933ab33 100644 (file)
@@ -2,8 +2,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkBlackBoxInputConnector.cxx,v $
   Language:  C++
-  Date:      $Date: 2009/05/28 08:12:05 $
-  Version:   $Revision: 1.10 $
+  Date:      $Date: 2009/06/08 14:50:02 $
+  Version:   $Revision: 1.11 $
 =========================================================================*/
 
 /* ---------------------------------------------------------------------
 
 namespace bbtk
 {
+
+  //========================================================================
+  /// The Pimpl
+  class BlackBoxInputConnector::Pimpl
+  {
+  public:
+    Pimpl() : mConnection(0), mStatus(MODIFIED) {}
+      
+    /// 
+    BlackBoxWeakPointer mBox;
+    /// The connection plugged into the input
+    Connection* mConnection;
+    /// The status of the input (UPTODATE | MODIFIED | OUTOFDATE)
+    IOStatus mStatus;
+
+  };
+  //========================================================================
+
+  //========================================================================
+  BBTK_IMPL_PIMPL(BlackBoxInputConnector)
+  //========================================================================
+
+
   //========================================================================
   BlackBoxInputConnector::BlackBoxInputConnector(BlackBox::Pointer b)  
-    : mBox(b), mConnection(0), mStatus(MODIFIED)
+  //: mBox(b), mConnection(0), mStatus(MODIFIED)
   {
     bbtkDebugMessage("kernel",9,
                     "["<<b->bbGetName()
                     <<"] BlackBoxInputConnector()"<<std::endl);
+    PimplConstruct();
+    p->mBox = b;
   }
   //========================================================================
 
@@ -53,19 +78,64 @@ namespace bbtk
   BlackBoxInputConnector::~BlackBoxInputConnector() 
   {
     bbtkDebugMessage("kernel",9,
-                    "[NULL"//<<mBox.lock()->bbGetName()
-                    <<"] ~BlackBoxInputConnector()"
+                    "[DEAD BOX] ~BlackBoxInputConnector()"
                     <<std::endl);
+    PimplDestruct();
   }
   //========================================================================
 
+  //========================================================================
+  /// Returns the connection plugged into this input (const)
+  Connection* BlackBoxInputConnector::GetConnection() const 
+  { 
+    return p->mConnection; 
+  }
+  //========================================================================
+  
+
+  //========================================================================
+  /// Returns true iff a connection is connected to it
+    bool BlackBoxInputConnector::IsConnected() const 
+  { 
+    return (p->mConnection != 0); 
+  }
+   //========================================================================
+   
+
+   //========================================================================
+   /// Returns the status of the input 
+    IOStatus BlackBoxInputConnector::GetStatus() const 
+   { 
+     return p->mStatus; 
+   }
+  //========================================================================
+
+  //========================================================================
+    /// Sets the status of the input 
+    void BlackBoxInputConnector::SetStatus(IOStatus s) 
+    { 
+      p->mStatus = s; 
+    }
+   //========================================================================
+   
+    
+
+  //========================================================================
+    /// Returns the black box which owns the connector
+    BlackBoxPointer BlackBoxInputConnector::GetBlackBox() const 
+    { 
+      return p->mBox.lock(); 
+    } 
+
+  //========================================================================
+
   //========================================================================
   void BlackBoxInputConnector::SetConnection(Connection* c) 
   { 
     bbtkDebugMessage("kernel",9,
-                    "["<<mBox.lock()->bbGetName()
+                    "["<<p->mBox.lock()->bbGetName()
                     <<"] BlackBoxInputConnector::SetConnection("<<c<<")"<<std::endl);
-    mConnection = c; 
+    p->mConnection = c; 
   }
   //========================================================================
 
@@ -73,10 +143,10 @@ namespace bbtk
   void BlackBoxInputConnector::UnsetConnection(Connection* c) 
   { 
     bbtkDebugMessage("kernel",9,
-                    "["<<mBox.lock()->bbGetName()
+                    "["<<p->mBox.lock()->bbGetName()
                     <<"] BlackBoxInputConnector::UnsetConnection("
                     <<c<<")"<<std::endl);
-    mConnection = 0; 
+    p->mConnection = 0; 
   }
   //========================================================================
   
@@ -86,20 +156,20 @@ namespace bbtk
     // If connected and OUTOFDATE : recursive update
     // Post-update status is updated by the connection 
     // (either MODIFIED or OUTOFDATE)
-    if ( mConnection && (mStatus == OUTOFDATE) )
+    if ( p->mConnection && (p->mStatus == OUTOFDATE) )
       {
-       mConnection->RecursiveExecute();
+       p->mConnection->RecursiveExecute();
       }
     else
       {
-       if (!mBox.expired())
-         bbtkDebugMessage("process",5,"["<<mBox.lock()->bbGetName()
+       if (!p->mBox.expired())
+         bbtkDebugMessage("process",5,"["<<p->mBox.lock()->bbGetName()
                           <<"] --> BlackBoxInputConnector::RecursiveExecute() : "
                           <<"No connection or input not Out-of-date : nothing to do"
                           <<std::endl);
        else
-         bbtkDebugMessage("process",5,"[UNKNOWN"
-                          <<"] --> BlackBoxInputConnector::RecursiveExecute() : "
+         bbtkDebugMessage("process",5,
+                          "[DEAD BOX] --> BlackBoxInputConnector::RecursiveExecute() : "
                           <<"No connection or input not Out-of-date : nothing to do"
                           <<std::endl);