#ifndef __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
#define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
-#include <map>
-#include <string>
-#include <itkDataObject.h>
+#include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
#include <cpPlugins/Interface/Object.h>
+#include <cpPlugins/Interface/DataObject.h>
+#include <cpPlugins/Interface/Parameters.h>
+
+#include <cpPlugins/Interface/Image.h>
+
+#define ITK_MANUAL_INSTANTIATION
+#include <itkProcessObject.h>
namespace cpPlugins
{
namespace Interface
{
- class DataObject;
-
/**
*/
- class ProcessObject
+ class cpPlugins_Interface_EXPORT ProcessObject
: public Object
{
public:
- typedef ProcessObject Self;
- typedef Object Superclass;
-
- typedef std::pair< std::string, std::string > TParameter;
- typedef std::map< std::string, TParameter > TParameters;
+ typedef ProcessObject Self;
+ typedef Object Superclass;
+ typedef itk::SmartPointer< Self > Pointer;
+ typedef itk::SmartPointer< const Self > ConstPointer;
public:
- ProcessObject( );
- virtual ~ProcessObject( );
+ itkTypeMacro( ProcessObject, Object );
- virtual std::string GetClassName( ) const;
- virtual const TParameters& GetDefaultParameters( ) const;
- virtual void SetParameters( const TParameters& params );
+ public:
+ virtual const Parameters& GetDefaultParameters( ) const;
+ virtual void SetParameters( const Parameters& params );
virtual unsigned int GetNumberOfInputs( ) const;
virtual unsigned int GetNumberOfOutputs( ) const;
virtual void SetNumberOfInputs( unsigned int n );
virtual void SetNumberOfOutputs( unsigned int n );
- virtual void SetInput( unsigned int idx, const DataObject* dobj );
+ virtual void SetInput( unsigned int idx, DataObject* dobj );
virtual DataObject* GetOutput( unsigned int idx );
virtual std::string Update( );
+ virtual void DisconnectOutputs( );
protected:
- virtual itk::DataObject* _GetInput( unsigned int idx );
- virtual void _SetOutput( unsigned int idx, itk::DataObject* dobj );
+ ProcessObject( );
+ virtual ~ProcessObject( );
+
+ template< class O >
+ void _MakeOutput( unsigned int idx )
+ {
+ if( idx >= this->m_Outputs.size( ) )
+ return;
+ this->m_Outputs[ idx ] = O::New( );
+ this->m_Outputs[ idx ]->SetSource( this );
+ }
+
virtual std::string _GenerateData( ) = 0;
+ private:
+ // Purposely not implemented
+ ProcessObject( const Self& );
+ Self& operator=( const Self& );
+
protected:
- TParameters m_DefaultParameters;
- TParameters m_Parameters;
+ itk::ProcessObject::Pointer m_RealProcessObject;
+ Parameters m_DefaultParameters;
+ Parameters m_Parameters;
- std::vector< const DataObject* > m_Inputs;
- std::vector< DataObject > m_Outputs;
+ std::vector< DataObject::Pointer > m_Inputs;
+ std::vector< DataObject::Pointer > m_Outputs;
};
} // ecapseman
} // ecapseman
+// -------------------------------------------------------------------------
+#define cpPlugins_Image_Demangle_Methods( c ) \
+ std::string _DemangleImageDimension( itk::DataObject* o ); \
+ std::string _DemangleImagePixel( unsigned int d, itk::DataObject* o );
+
+// -------------------------------------------------------------------------
+#define cpPlugins_Image_Demangle_Methods_Code( c, f ) \
+ std::string c::_DemangleImageDimension( itk::DataObject* o ) \
+ { \
+ std::string r = ""; \
+ if( dynamic_cast< itk::ImageBase< 1 >* >( o ) != NULL ) \
+ { \
+ cpPlugins_Image_Array_Demangle( \
+ itk::Vector, float, 1, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Vector, double, 1, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, float, 1, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, double, 1, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, float, 1, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, double, 1, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, float, 1, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, double, 1, 1, o, f, r \
+ ); \
+ else r = this->_DemangleImagePixel( 1, o ); \
+ } \
+ else if( dynamic_cast< itk::ImageBase< 2 >* >( o ) != NULL ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ itk::RGBPixel< char >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< short >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< unsigned char >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< unsigned short >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< char >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< short >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< unsigned char >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< unsigned short >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Vector, float, 2, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Vector, double, 2, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, float, 2, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, double, 2, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, float, 2, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, double, 2, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, float, 2, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, double, 2, 2, o, f, r \
+ ); \
+ else r = this->_DemangleImagePixel( 2, o ); \
+ } \
+ else if( dynamic_cast< itk::ImageBase< 3 >* >( o ) != NULL ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ itk::RGBPixel< char >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< short >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< unsigned char >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< unsigned short >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< char >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< short >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< unsigned char >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< unsigned short >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Vector, float, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Vector, double, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, float, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, double, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, float, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, double, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, float, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, double, 3, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::DiffusionTensor3D< float >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::DiffusionTensor3D< double >, 3, o, f, r \
+ ); \
+ else r = this->_DemangleImagePixel( 3, o ); \
+ } \
+ else if( dynamic_cast< itk::ImageBase< 4 >* >( o ) != NULL ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ itk::RGBPixel< char >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< short >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< unsigned char >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBPixel< unsigned short >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< char >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< short >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< unsigned char >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::RGBAPixel< unsigned short >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Vector, float, 4, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Vector, double, 4, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, float, 4, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::Point, double, 4, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, float, 4, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::CovariantVector, double, 4, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, float, 4, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Array_Demangle( \
+ itk::SymmetricSecondRankTensor, double, 4, 4, o, f, r \
+ ); \
+ else r = this->_DemangleImagePixel( 4, o ); \
+ } \
+ else \
+ r = \
+ std::string( #c ) + \
+ std::string( ": Image dimension not supported." ); \
+ return( r ); \
+ } \
+ std::string c::_DemangleImagePixel( \
+ unsigned int d, itk::DataObject* o \
+ ) \
+ { \
+ std::string r = ""; \
+ if( d == 1 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< float >, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< double >, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::Offset< 1 >, 1, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else if( d == 2 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< float >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< double >, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::Offset< 2 >, 2, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else if( d == 3 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< float >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< double >, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::Offset< 3 >, 3, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else if( d == 4 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< float >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ std::complex< double >, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ itk::Offset< 4 >, 4, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else \
+ r = \
+ std::string( #c ) + \
+ std::string( ": Image dimension not supported." ); \
+ return( r ); \
+ }
+
+// -------------------------------------------------------------------------
+#define cpPlugins_Image_Demangle_Methods_Code_Only_Scalars( c, f ) \
+ std::string c::_DemangleImageDimension( itk::DataObject* o ) \
+ { \
+ std::string r = ""; \
+ if( dynamic_cast< itk::ImageBase< 1 >* >( o ) != NULL ) \
+ r = this->_DemangleImagePixel( 1, o ); \
+ else if( dynamic_cast< itk::ImageBase< 2 >* >( o ) != NULL ) \
+ r = this->_DemangleImagePixel( 2, o ); \
+ else if( dynamic_cast< itk::ImageBase< 3 >* >( o ) != NULL ) \
+ r = this->_DemangleImagePixel( 3, o ); \
+ else if( dynamic_cast< itk::ImageBase< 4 >* >( o ) != NULL ) \
+ r = this->_DemangleImagePixel( 4, o ); \
+ else \
+ r = \
+ std::string( #c ) + \
+ std::string( ": Image dimension not supported." ); \
+ return( r ); \
+ } \
+ std::string c::_DemangleImagePixel( \
+ unsigned int d, itk::DataObject* o \
+ ) \
+ { \
+ std::string r = ""; \
+ if( d == 1 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 1, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 1, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else if( d == 2 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 2, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 2, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else if( d == 3 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 3, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 3, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else if( d == 4 ) \
+ { \
+ cpPlugins_Image_Demangle( \
+ char, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ short, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ int, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ long, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned char, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned short, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned int, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ unsigned long, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ float, 4, o, f, r \
+ ); \
+ else cpPlugins_Image_Demangle( \
+ double, 4, o, f, r \
+ ); \
+ else r = std::string( #c ) + std::string( ": Image type." ); \
+ } \
+ else \
+ r = \
+ std::string( #c ) + \
+ std::string( ": Image dimension not supported." ); \
+ return( r ); \
+ }
+
#endif // __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
// eof - $RCSfile$