]> Creatis software - cpPlugins.git/blobdiff - lib/cpPlugins/Interface/Object.h
...
[cpPlugins.git] / lib / cpPlugins / Interface / Object.h
index fe86f1bc7efbb140e4b0e4f571bcc72e811bfd54..ef8cab82dfedf6c96feaa84174cd9ef86462c1ca 100644 (file)
@@ -3,13 +3,15 @@
 
 #include <string>
 #include <Pluma/Pluma.hpp>
+#include <cpPlugins/cpPlugins_Export.h>
+
+#define ITK_MANUAL_INSTANTIATION
 #include <itkObject.h>
 #include <itkObjectFactory.h>
-#include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
 
 // -------------------------------------------------------------------------
 #define CPPLUGINS_PROVIDER_HEADER_BEGIN( TYPE )                 \
-  class cpPlugins_Interface_EXPORT TYPE##Provider               \
+  class cpPlugins_EXPORT TYPE##Provider               \
     : public pluma::Provider                                    \
   {                                                             \
   private:                                                      \
@@ -56,7 +58,7 @@ namespace cpPlugins
   {
     /**
      */
-    class cpPlugins_Interface_EXPORT Object
+    class cpPlugins_EXPORT Object
       : public itk::Object
     {
     public:
@@ -70,8 +72,8 @@ namespace cpPlugins
       itkTypeMacro( Object, itkObject );
 
     public:
-      virtual std::string GetClassName( ) const;
-      virtual std::string GetClassType( ) const;
+      itkGetConstMacro( ClassName, std::string );
+      itkGetConstMacro( ClassCategory, std::string );
 
     protected:
       Object( );
@@ -81,6 +83,10 @@ namespace cpPlugins
       // Purposely not implemented
       Object( const Self& );
       Self& operator=( const Self& );
+
+    protected:
+      std::string m_ClassName;
+      std::string m_ClassCategory;
     };
 
     /**