X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FcpPlugins%2FInterface%2FDataObject.h;h=c08b3a345475f28fc4521c3876fee70233ff513a;hb=75740198fa0c55f8fdcd8b33ddff00071c893a94;hp=9edf92b0cb30502e143ea386154f6b48e6c85432;hpb=1adce86c283e253ec41f762652bc477d56d617a5;p=cpPlugins.git diff --git a/lib/cpPlugins/Interface/DataObject.h b/lib/cpPlugins/Interface/DataObject.h index 9edf92b..c08b3a3 100644 --- a/lib/cpPlugins/Interface/DataObject.h +++ b/lib/cpPlugins/Interface/DataObject.h @@ -3,40 +3,51 @@ #include #include -#include +#include +#include #include #include +#include + namespace cpPlugins { namespace Interface { - class ProcessObject; - /** */ class cpPlugins_Interface_EXPORT DataObject : public Object { public: - typedef DataObject Self; - typedef Object Superclass; + typedef DataObject Self; + typedef Object Superclass; + typedef itk::SmartPointer< Self > Pointer; + typedef itk::SmartPointer< const Self > ConstPointer; public: - DataObject( ); - virtual ~DataObject( ); + itkTypeMacro( DataObject, Object ); - virtual std::string GetClassName( ) const; + public: + Object* GetSource( ); + const Object* GetSource( ) const; + void SetSource( Object* src ); + + void DisconnectPipeline( ); - itk::DataObject* GetDataObject( ) const; - virtual void SetDataObject( itk::DataObject* dobj ); + protected: + DataObject( ); + virtual ~DataObject( ); - ProcessObject* GetSource( ) const; - void SetSource( ProcessObject* src ); + private: + // Purposely not implemented + DataObject( const Self& ); + Self& operator=( const Self& ); protected: - itk::DataObject::Pointer m_DataObject; - ProcessObject* m_Source; + itk::DataObject::Pointer m_ITKObject; + vtkSmartPointer< vtkDataObject > m_VTKObject; + Object::Pointer m_Source; }; } // ecapseman