Program: bbtk
Module: $RCSfile: bbtkConnection.cxx,v $
Language: C++
- Date: $Date: 2008/10/17 08:18:13 $
- Version: $Revision: 1.15 $
+ Date: $Date: 2008/12/08 12:54:19 $
+ Version: $Revision: 1.16 $
=========================================================================*/
/* ---------------------------------------------------------------------
#include "bbtkFactory.h"
#include "bbtkBlackBox.h"
#include "bbtkMessageManager.h"
+#include "bbtkBlackBoxOutputConnector.h"
namespace bbtk
{
+ const std::string IOSTATUS_STRING[3] =
+ {"Up-to-date","Modified","Out-of-date"};
+
+ const std::string& GetIOStatusString(IOStatus s)
+ { return IOSTATUS_STRING[s]; }
+
//==================================================================
Connection::Pointer Connection::New(BlackBox::Pointer from,
const std::string& output,
//Pointer p = MakePointer(this,true);
from->bbConnectOutput(output,this);
to->bbConnectInput(input,this);
+
+ from->bbGetOutputConnector(output).AddChangeObserver(boost::bind(&bbtk::Connection::OnOutputChange,this, _1, _2, _3));
bbtkDebugMessage("connection",1,"<== Connection::Connection(\""
from->bbConnectOutput(output,this);
to->bbConnectInput(input,this);
+ from->bbGetOutputConnector(output).AddChangeObserver(boost::bind(&bbtk::Connection::OnOutputChange,this, _1, _2, _3));
bbtkDebugMessage("connection",1,"<== Connection::Connection(\""
<<from->bbGetFullName()<<"\",\""<<output<<"\",\""
//==================================================================
/// Backward Update
- IOStatus Connection::BackwardUpdate()
+ void Connection::BackwardUpdate()
{
bbtkDebugMessage("process",5,
"===> Connection::BackwardUpdate() ["
<<GetFullName()<<"]"<<std::endl);
- IOStatus s = UPTODATE;
- s = mFrom->bbBackwardUpdate(GetThisPointer<Connection>());
+ mFrom->bbBackwardUpdate(GetThisPointer<Connection>());
TransferData();
- if (mAdaptor && (s==MODIFIED)) mAdaptor->bbSetModifiedStatus();
+ // Transfer status
+ IOStatus s = MODIFIED;
+ if ( mFrom->bbGetOutputConnector(mOutput).GetStatus() == OUTOFDATE)
+ s = OUTOFDATE,
+ mTo->bbGetInputConnector(mInput).SetStatus(s);
bbtkDebugMessage("process",5,
"<=== Connection::BackwardUpdate() ["
<<GetFullName()<<"]"<<std::endl);
- return s;
+ return; // s;
}
//==================================================================
}
//==================================================================
+ /*
//==================================================================
/// Modified
void Connection::SetModifiedStatus()
mTo->bbSetModifiedStatus( mTo->bbGetInputConnectorMap().find(mInput)->second );
- /*
- bbtkDebugMessage("modified",2,
- "==> Connection::SetModifiedStatus() ["
+
+ }
+ //==================================================================
+ */
+ //==================================================================
+ /// From.Output change propagation
+ void Connection::OnOutputChange(bbtk::BlackBox::Pointer, const std::string&,
+ IOStatus status)
+ {
+ bbtkDebugMessage("change",2,
+ "==> Connection::OnOutputChange("<<status<<") ["
<<GetFullName()<<"]"<<std::endl);
- */
+
+ if (mAdaptor)
+ {
+ BlackBoxInputConnector* ac = mAdaptor->bbGetInputConnectorMap().find("In")->second;
+ mAdaptor->bbSetStatusAndPropagate(ac,status);
+ }
+
+ mTo->bbSetStatusAndPropagate( mTo->bbGetInputConnectorMap().find(mInput)->second, status);
+
+
}
//==================================================================