]> Creatis software - cpPlugins.git/blobdiff - lib/cpInstances/DataObjects/Mesh.h
yet another refactoring
[cpPlugins.git] / lib / cpInstances / DataObjects / Mesh.h
diff --git a/lib/cpInstances/DataObjects/Mesh.h b/lib/cpInstances/DataObjects/Mesh.h
new file mode 100644 (file)
index 0000000..fa658ed
--- /dev/null
@@ -0,0 +1,53 @@
+#ifndef __cpInstances__Mesh__h__
+#define __cpInstances__Mesh__h__
+
+#define ITK_MANUAL_INSTANTIATION
+#include <cpInstances/cpPluginsDataObjects_Export.h>
+#include <cpInstances/DataObjects/Mesh_Demanglers.h>
+#include <cpPlugins/Pipeline/DataObject.h>
+
+namespace cpInstances
+{
+  namespace DataObjects
+  {
+    /**
+     */
+    class cpPluginsDataObjects_EXPORT Mesh
+      : public cpPlugins::Pipeline::DataObject
+    {
+    public:
+      typedef Mesh                            Self;
+      typedef cpPlugins::Pipeline::DataObject Superclass;
+      typedef itk::SmartPointer< Self >       Pointer;
+      typedef itk::SmartPointer< const Self > ConstPointer;
+
+    public:
+      itkNewMacro( Self );
+      itkTypeMacro( Mesh, DataObject );
+      cpPlugins_Id_Macro( Mesh, Object );
+      cpPlugins_Compatibility_Macro;
+
+    public:
+      virtual void SetITK( itk::LightObject* o ) cpPlugins_OVERRIDE;
+      virtual void SetVTK( vtkObjectBase* o ) cpPlugins_OVERRIDE;
+
+    protected:
+      Mesh( );
+      virtual ~Mesh( );
+
+      template< class _TMesh >
+      inline void _ITK_2_VTK( _TMesh* mesh );
+
+    private:
+      // Purposely not implemented
+      Mesh( const Self& );
+      Self& operator=( const Self& );
+    };
+
+  } // ecapseman
+
+} // ecapseman
+
+#endif // __cpInstances__Mesh__h__
+
+// eof - $RCSfile$