// -------------------------------------------------------------------------
cpPlugins::Interface::ProcessObject::
ProcessObject( )
- : Superclass( )
+ : Superclass( ),
+ m_OutputsDisconnected( false )
{
}
cpPlugins::Interface::ProcessObject::
~ProcessObject( )
{
+ this->_DeleteOutputs( );
}
// -------------------------------------------------------------------------
void cpPlugins::Interface::ProcessObject::
SetNumberOfOutputs( unsigned int n )
{
+ this->_DeleteOutputs( );
this->m_Outputs.clear( );
- this->m_Outputs.resize( n );
-
- // Sync outputs with this source
- for( unsigned int odx = 0; odx < this->m_Outputs.size( ); ++odx )
- this->m_Outputs[ odx ].SetSource( this );
+ this->m_Outputs.resize( n, NULL );
+ this->m_OutputsDisconnected = false;
}
// -------------------------------------------------------------------------
GetOutput( unsigned int idx )
{
if( idx < this->m_Outputs.size( ) )
- return( &( this->m_Outputs[ idx ] ) );
+ return( this->m_Outputs[ idx ] );
else
return( NULL );
}
// Current update
std::string ret = this->_GenerateData( );
+ this->m_OutputsDisconnected = false;
// Return error description, if any
return( ret );
}
+// -------------------------------------------------------------------------
+void cpPlugins::Interface::ProcessObject::
+DisconnectOutputs( )
+{
+ this->m_OutputsDisconnected = true;
+ for( unsigned int idx = 0; idx < this->m_Outputs.size( ); ++idx )
+ if( this->m_Outputs[ idx ] != NULL )
+ this->m_Outputs[ idx ]->GetDataObject( )->DisconnectPipeline( );
+}
+
// -------------------------------------------------------------------------
itk::DataObject* cpPlugins::Interface::ProcessObject::
_GetInput( unsigned int idx )
_SetOutput( unsigned int idx, itk::DataObject* dobj )
{
if( idx < this->m_Outputs.size( ) )
- this->m_Outputs[ idx ].SetDataObject( dobj );
+ if( this->m_Outputs[ idx ] != NULL )
+ this->m_Outputs[ idx ]->SetDataObject( dobj );
+}
+
+// -------------------------------------------------------------------------
+void cpPlugins::Interface::ProcessObject::
+_DeleteOutputs( )
+{
+ if( !( this->m_OutputsDisconnected ) )
+ for( unsigned int idx = 0; idx < this->m_Outputs.size( ); ++idx )
+ if( this->m_Outputs[ idx ] != NULL )
+ delete this->m_Outputs[ idx ];
}
// eof - $RCSfile$