1 #ifndef __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
2 #define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
6 #include <itkDataObject.h>
7 #include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
8 #include <cpPlugins/Interface/Object.h>
9 #include <cpPlugins/Interface/DataObject.h>
19 class cpPlugins_Interface_EXPORT ProcessObject
23 typedef ProcessObject Self;
24 typedef Object Superclass;
26 typedef std::pair< std::string, std::string > TParameter;
27 typedef std::map< std::string, TParameter > TParameters;
31 virtual ~ProcessObject( );
33 virtual std::string GetClassName( ) const;
34 virtual const TParameters& GetDefaultParameters( ) const;
35 virtual void SetParameters( const TParameters& params );
37 virtual unsigned int GetNumberOfInputs( ) const;
38 virtual unsigned int GetNumberOfOutputs( ) const;
40 virtual void SetNumberOfInputs( unsigned int n );
41 virtual void SetNumberOfOutputs( unsigned int n );
43 virtual void SetInput( unsigned int idx, const DataObject* dobj );
44 virtual DataObject* GetOutput( unsigned int idx );
46 virtual std::string Update( );
47 virtual void DisconnectOutputs( );
50 virtual itk::DataObject* _GetInput( unsigned int idx );
51 virtual void _SetOutput( unsigned int idx, itk::DataObject* dobj );
52 virtual void _DeleteOutputs( );
55 void _MakeOutput( unsigned int idx )
57 if( idx >= this->m_Outputs.size( ) )
60 if( !( this->m_OutputsDisconnected ) )
61 if( this->m_Outputs[ idx ] != NULL )
62 delete this->m_Outputs[ idx ];
64 this->m_Outputs[ idx ] = new O( );
65 this->m_Outputs[ idx ]->SetSource( this );
68 virtual std::string _GenerateData( ) = 0;
71 TParameters m_DefaultParameters;
72 TParameters m_Parameters;
74 std::vector< const DataObject* > m_Inputs;
75 std::vector< DataObject* > m_Outputs;
76 bool m_OutputsDisconnected;
83 #endif // __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__