X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkBlackBoxInputConnector.cxx;h=a2355debee3a22923e2279b16ad9b15a6933ab33;hb=8a05f9b39b1a8639e96b938f95cd93cfb2fd4de6;hp=5180428d18368d55b9574a932366decdca485bca;hpb=8c690fedb5ea897b6a69584e1e237cb5dbad97a5;p=bbtk.git diff --git a/kernel/src/bbtkBlackBoxInputConnector.cxx b/kernel/src/bbtkBlackBoxInputConnector.cxx index 5180428..a2355de 100644 --- a/kernel/src/bbtkBlackBoxInputConnector.cxx +++ b/kernel/src/bbtkBlackBoxInputConnector.cxx @@ -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 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -39,13 +39,38 @@ 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, "["<bbGetName() <<"] BlackBoxInputConnector()"<mBox = b; } //======================================================================== @@ -53,19 +78,64 @@ namespace bbtk BlackBoxInputConnector::~BlackBoxInputConnector() { bbtkDebugMessage("kernel",9, - "[NULL"//<bbGetName() - <<"] ~BlackBoxInputConnector()" + "[DEAD BOX] ~BlackBoxInputConnector()" <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, - "["<bbGetName() + "["<mBox.lock()->bbGetName() <<"] BlackBoxInputConnector::SetConnection("<mConnection = c; } //======================================================================== @@ -73,10 +143,10 @@ namespace bbtk void BlackBoxInputConnector::UnsetConnection(Connection* c) { bbtkDebugMessage("kernel",9, - "["<bbGetName() + "["<mBox.lock()->bbGetName() <<"] BlackBoxInputConnector::UnsetConnection(" <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,"["<bbGetName() + if (!p->mBox.expired()) + bbtkDebugMessage("process",5,"["<mBox.lock()->bbGetName() <<"] --> BlackBoxInputConnector::RecursiveExecute() : " <<"No connection or input not Out-of-date : nothing to do" < BlackBoxInputConnector::RecursiveExecute() : " + bbtkDebugMessage("process",5, + "[DEAD BOX] --> BlackBoxInputConnector::RecursiveExecute() : " <<"No connection or input not Out-of-date : nothing to do" <