X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkBlackBoxInputConnector.cxx;h=a2355debee3a22923e2279b16ad9b15a6933ab33;hb=f8d8e622fda6007b1bf8d8b1f51b6f42c15e1ebc;hp=c9371af4007048b7c7787290dff95fab3cb62fd1;hpb=6575a389b71b1b85c79e4444885becb76ecf16e4;p=bbtk.git diff --git a/kernel/src/bbtkBlackBoxInputConnector.cxx b/kernel/src/bbtkBlackBoxInputConnector.cxx index c9371af..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: 2008/10/17 08:18:12 $ - Version: $Revision: 1.6 $ + Date: $Date: 2009/06/08 14:50:02 $ + Version: $Revision: 1.11 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -39,54 +39,144 @@ 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,"BlackBoxInputConnector::BlackBoxInputConnector()"<bbGetName() + <<"] BlackBoxInputConnector()"<mBox = b; } + //======================================================================== - + //======================================================================== BlackBoxInputConnector::~BlackBoxInputConnector() { - bbtkDebugMessageInc("Kernel",9,"BlackBoxInputConnector::~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,"BlackBoxInputConnector::SetConnection("<mBox.lock()->bbGetName() + <<"] BlackBoxInputConnector::SetConnection("<mConnection = c; } - + //======================================================================== + + //======================================================================== void BlackBoxInputConnector::UnsetConnection(Connection* c) { - bbtkDebugMessage("Kernel",9,"BlackBoxInputConnector::UnsetConnection(" + bbtkDebugMessage("kernel",9, + "["<mBox.lock()->bbGetName() + <<"] BlackBoxInputConnector::UnsetConnection(" <mConnection = 0; } + //======================================================================== - IOStatus BlackBoxInputConnector::BackwardUpdate() + //======================================================================== + void BlackBoxInputConnector::RecursiveExecute() { - bbtkDebugMessage("process",9,"==> BlackBoxInputConnector::BackwardUpdate()" - <mConnection && (p->mStatus == OUTOFDATE) ) { - IOStatus s = mConnection->BackwardUpdate(); - mStatus = s; + p->mConnection->RecursiveExecute(); } - else + else { - mStatus = UPTODATE; + 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() : " + <<"No connection or input not Out-of-date : nothing to do" + <