1 #ifndef __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
2 #define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
4 #include <itkProcessObject.h>
5 #include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
6 #include <cpPlugins/Interface/Object.h>
7 #include <cpPlugins/Interface/DataObject.h>
8 #include <cpPlugins/Interface/Parameters.h>
16 class cpPlugins_Interface_EXPORT ProcessObject
20 typedef ProcessObject Self;
21 typedef Object Superclass;
22 typedef itk::SmartPointer< Self > Pointer;
23 typedef itk::SmartPointer< const Self > ConstPointer;
26 itkTypeMacro( ProcessObject, Object );
29 virtual std::string GetClassName( ) const;
30 virtual std::string GetClassType( ) const;
31 virtual const Parameters& GetDefaultParameters( ) const;
32 virtual void SetParameters( const Parameters& params );
34 virtual unsigned int GetNumberOfInputs( ) const;
35 virtual unsigned int GetNumberOfOutputs( ) const;
37 virtual void SetNumberOfInputs( unsigned int n );
38 virtual void SetNumberOfOutputs( unsigned int n );
40 virtual void SetInput( unsigned int idx, DataObject* dobj );
41 virtual DataObject* GetOutput( unsigned int idx );
43 virtual std::string Update( );
44 virtual void DisconnectOutputs( );
48 virtual ~ProcessObject( );
50 virtual itk::DataObject* _GetInput( unsigned int idx );
51 virtual void _SetOutput( unsigned int idx, itk::DataObject* dobj );
54 void _MakeOutput( unsigned int idx )
56 if( idx >= this->m_Outputs.size( ) )
58 this->m_Outputs[ idx ] = O::New( );
59 this->m_Outputs[ idx ]->SetSource( this );
62 virtual std::string _GenerateData( ) = 0;
65 // Purposely not implemented
66 ProcessObject( const Self& );
67 Self& operator=( const Self& );
70 itk::ProcessObject::Pointer m_RealProcessObject;
71 Parameters m_DefaultParameters;
72 Parameters m_Parameters;
74 std::vector< DataObject::Pointer > m_Inputs;
75 std::vector< DataObject::Pointer > m_Outputs;
82 #endif // __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__