00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00044 #ifndef __vtkProcessObject_h
00045 #define __vtkProcessObject_h
00046
00047 #include "vtkAlgorithm.h"
00048
00049 class vtkDataObject;
00050
00051 class VTK_FILTERING_EXPORT vtkProcessObject : public vtkAlgorithm
00052 {
00053 public:
00054 vtkTypeRevisionMacro(vtkProcessObject,vtkAlgorithm);
00055 void PrintSelf(ostream& os, vtkIndent indent);
00056
00058
00060 vtkDataObject **GetInputs();
00061 int GetNumberOfInputs();
00063
00066 void SqueezeInputArray();
00067
00069 void RemoveAllInputs();
00070
00072
00074 virtual void SetInputConnection(vtkAlgorithmOutput* input) {
00075 this->vtkAlgorithm::SetInputConnection(input); }
00076 virtual void SetInputConnection(int port, vtkAlgorithmOutput* input);
00077 virtual void AddInputConnection(int port, vtkAlgorithmOutput* input);
00078 virtual void AddInputConnection(vtkAlgorithmOutput* input)
00079 {
00080 this->AddInputConnection(0, input);
00081 }
00082 virtual void RemoveInputConnection(int port, vtkAlgorithmOutput* input);
00083 virtual void SetNthInputConnection(int port, int index,
00084 vtkAlgorithmOutput* input);
00085 virtual void SetNumberOfInputConnections(int port, int n);
00087 protected:
00088 vtkProcessObject();
00089 ~vtkProcessObject();
00090
00091 int NumberOfInputs;
00092 int NumberOfRequiredInputs;
00093 vtkDataObject **Inputs;
00094
00095
00096 void SetNumberOfInputs(int num);
00097
00098
00099 virtual void SetNthInput(int num, vtkDataObject *input);
00100 virtual void AddInput(vtkDataObject *input);
00101 virtual void RemoveInput(vtkDataObject *input);
00102
00103 virtual void ReportReferences(vtkGarbageCollector*);
00104
00105
00106 virtual int FillInputPortInformation(int, vtkInformation*);
00107 virtual int FillOutputPortInformation(int, vtkInformation*);
00108
00109
00110 void AddInputInternal(vtkDataObject* input);
00111 void RemoveInputInternal(vtkDataObject* input);
00112 void SetupInputs();
00113
00114 private:
00115 vtkProcessObject(const vtkProcessObject&);
00116 void operator=(const vtkProcessObject&);
00117 };
00118
00119 #endif
00120