]> Creatis software - cpPlugins.git/blobdiff - lib/cpPlugins/Interface/ProcessObject.h
Merge branch 'master' of ssh://git.creatis.insa-lyon.fr/cpPlugins
[cpPlugins.git] / lib / cpPlugins / Interface / ProcessObject.h
index 9cf1924992d2396d4e93f20e97a3ae81270a40b4..5fc98f399f605b624bcdd1155e65b67f1be823e0 100644 (file)
@@ -2,6 +2,10 @@
 #define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
 
 #include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
+
+#include <map>
+#include <vector>
+
 #include <cpPlugins/Interface/Config.h>
 #include <cpPlugins/Interface/Object.h>
 #include <cpPlugins/Interface/DataObject.h>
@@ -10,7 +14,7 @@
 #ifdef cpPlugins_Interface_QT4
 class QWidget;
 #else
-typedef char QWidget
+typedef char QWidget;
 #endif // cpPlugins_Interface_QT4
 
 #include <itkProcessObject.h>
@@ -22,6 +26,12 @@ namespace cpPlugins
 {
   namespace Interface
   {
+#ifdef cpPlugins_Interface_QT4
+    class ParametersQtDialog;
+#else
+    typedef char ParametersQtDialog;
+#endif // cpPlugins_Interface_QT4
+
     /**
      */
     class cpPlugins_Interface_EXPORT ProcessObject
@@ -42,16 +52,19 @@ namespace cpPlugins
         );
 
     public:
+      // To impact pipeline
+      virtual void Modified( ) const;
+
       virtual TParameters* GetParameters( );
       virtual const TParameters* GetParameters( ) const;
 
       virtual unsigned int GetNumberOfInputs( ) const;
       virtual unsigned int GetNumberOfOutputs( ) const;
 
-      virtual void SetNumberOfInputs( unsigned int n );
-      virtual void SetNumberOfOutputs( unsigned int n );
+      virtual std::vector< std::string > GetInputsNames( ) const;
+      virtual std::vector< std::string > GetOutputsNames( ) const;
 
-      virtual void SetInput( unsigned int idx, DataObject* dobj );
+      virtual void SetInput( const std::string& id, DataObject* dobj );
 
       virtual std::string Update( );
       virtual void DisconnectOutputs( );
@@ -71,21 +84,23 @@ namespace cpPlugins
         inline const T* GetVTK( ) const;
 
       template< class T >
-        inline T* GetInput( unsigned int idx );
+        inline T* GetInput( const std::string& id );
 
       template< class T >
-        inline const T* GetInput( unsigned int idx ) const;
+        inline const T* GetInput( const std::string& id ) const;
 
       template< class T >
-        inline T* GetOutput( unsigned int idx );
+        inline T* GetOutput( const std::string& id );
 
       template< class T >
-        inline const T* GetOutput( unsigned int idx ) const;
+        inline const T* GetOutput( const std::string& id ) const;
 
     protected:
       ProcessObject( );
       virtual ~ProcessObject( );
 
+      virtual void _AddInput( const std::string& name );
+
       template< class F >
         inline F* _CreateITK( );
 
@@ -93,7 +108,7 @@ namespace cpPlugins
         inline F* _CreateVTK( );
 
       template< class O >
-        inline void _MakeOutput( unsigned int idx );
+        inline void _MakeOutput( const std::string& id );
 
       virtual std::string _GenerateData( ) = 0;
 
@@ -107,9 +122,11 @@ namespace cpPlugins
       vtkSmartPointer< vtkAlgorithm > m_VTKObject;
 
       Parameters::Pointer m_Parameters;
+      ParametersQtDialog* m_ParametersDialog;
 
-      std::vector< DataObject::Pointer > m_Inputs;
-      std::vector< DataObject::Pointer > m_Outputs;
+      typedef std::map< std::string, DataObject::Pointer > _TDataContainer;
+      _TDataContainer m_Inputs;
+      _TDataContainer m_Outputs;
     };
 
   } // ecapseman