1 #ifndef __CPPLUGINS__PROCESSOBJECT__H__
2 #define __CPPLUGINS__PROCESSOBJECT__H__
6 #include <cpPlugins/Object.h>
7 #include <cpPlugins/Parameters.h>
8 #include <cpPlugins/Port.h>
14 class cpPlugins_EXPORT ProcessObject
18 typedef ProcessObject Self;
19 typedef Object Superclass;
20 typedef itk::SmartPointer< Self > Pointer;
21 typedef itk::SmartPointer< const Self > ConstPointer;
24 itkTypeMacro( ProcessObject, Object );
25 cpPlugins_Id_Macro( ProcessObject, Object );
27 itkBooleanMacro( PrintExecution );
28 itkGetConstMacro( LastExecutionSpan, long );
29 itkGetConstMacro( PrintExecution, bool );
30 itkSetMacro( PrintExecution, bool );
31 itkSetObjectMacro( PrintExecutionStream, std::ofstream );
34 Parameters* GetParameters( );
35 const Parameters* GetParameters( ) const;
37 virtual void SetITK( itk::LightObject* o ) final;
38 virtual void SetVTK( vtkObjectBase* o ) final;
41 std::set< std::string > GetInputsNames( ) const;
42 std::set< std::string > GetOutputsNames( ) const;
43 unsigned int GetNumberOfInputs( ) const;
44 unsigned int GetNumberOfOutputs( ) const;
46 OutputPort& GetOutput( const std::string& id );
47 const OutputPort& GetOutput( const std::string& id ) const;
49 DataObject* GetInputData( const std::string& id );
50 const DataObject* GetInputData( const std::string& id ) const;
51 DataObject* GetOutputData( const std::string& id );
52 const DataObject* GetOutputData( const std::string& id ) const;
54 bool SetInput( const std::string& id, const OutputPort& port );
56 void DisconnectInputs( );
57 void DisconnectOutputs( );
61 virtual void Modified( ) const ITK_OVERRIDE;
62 virtual itk::ModifiedTimeType GetMTime( ) const ITK_OVERRIDE;
63 virtual void Update( );
66 virtual ParametersQtDialog* CreateQtDialog( );
67 virtual bool IsInteractive( );
68 virtual void SetInteractionObjects( const std::vector< void* >& objs );
72 virtual ~ProcessObject( );
74 void _AddInput( const std::string& name, bool required = true );
75 void _Error( const std::string& error );
78 inline void _AddOutput( const std::string& name );
81 inline F* _CreateITK( );
83 inline F* _CreateVTK( );
85 virtual void _GenerateData( ) = 0;
88 // Purposely not implemented
89 ProcessObject( const Self& );
90 Self& operator=( const Self& );
93 Parameters m_Parameters;
95 typedef std::map< std::string, InputPort > _TInputs;
96 typedef std::map< std::string, OutputPort > _TOutputs;
100 itk::ModifiedTimeType m_LastExecutionTime;
101 mutable long m_LastExecutionSpan;
103 bool m_PrintExecution;
104 std::ostream* m_PrintExecutionStream;
109 #include <cpPlugins/ProcessObject.hxx>
111 #endif // __CPPLUGINS__PROCESSOBJECT__H__