X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkBlackBoxInputConnector.cxx;h=a2355debee3a22923e2279b16ad9b15a6933ab33;hb=a280c10c9ba7730cd9105a91bf1a40e72503a6e3;hp=f980cc3470f8324908baeece6d7d44b3ae707ae1;hpb=3928b4ad06b5b5fd142f696f58a7828d064e2883;p=bbtk.git diff --git a/kernel/src/bbtkBlackBoxInputConnector.cxx b/kernel/src/bbtkBlackBoxInputConnector.cxx index f980cc3..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/12/08 12:53:50 $ - Version: $Revision: 1.7 $ + Date: $Date: 2009/06/08 14:50:02 $ + Version: $Revision: 1.11 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -39,62 +39,141 @@ 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; } //======================================================================== //======================================================================== - void BlackBoxInputConnector::BackwardUpdate() + void BlackBoxInputConnector::RecursiveExecute() { - bbtkDebugMessage("process",9,"==> BlackBoxInputConnector::BackwardUpdate()" - <mConnection && (p->mStatus == OUTOFDATE) ) + { + p->mConnection->RecursiveExecute(); + } + else { - mConnection->BackwardUpdate(); + 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" + <