]> Creatis software - cpPlugins.git/blobdiff - lib/cpPlugins/Interface/ProcessObject.h
Widget integration (step 6/6): Interactive architecture finished. Needs to be tested...
[cpPlugins.git] / lib / cpPlugins / Interface / ProcessObject.h
index 9cf1924992d2396d4e93f20e97a3ae81270a40b4..9548d48167c19fda02e1fdb2fa897c0afdb6c348 100644 (file)
@@ -2,6 +2,9 @@
 #define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
 
 #include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
+
+#include <map>
+
 #include <cpPlugins/Interface/Config.h>
 #include <cpPlugins/Interface/Object.h>
 #include <cpPlugins/Interface/DataObject.h>
@@ -42,16 +45,16 @@ 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 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 +74,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 +98,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;
 
@@ -108,8 +113,9 @@ namespace cpPlugins
 
       Parameters::Pointer m_Parameters;
 
-      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