00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00023 #ifndef __vtkInformationExecutivePortVectorKey_h
00024 #define __vtkInformationExecutivePortVectorKey_h
00025
00026 #include "vtkInformationKey.h"
00027
00028 #include "vtkFilteringInformationKeyManager.h"
00029
00030 class vtkExecutive;
00031
00032 class VTK_FILTERING_EXPORT vtkInformationExecutivePortVectorKey : public vtkInformationKey
00033 {
00034 public:
00035 vtkTypeRevisionMacro(vtkInformationExecutivePortVectorKey,vtkInformationKey);
00036 void PrintSelf(ostream& os, vtkIndent indent);
00037
00038 vtkInformationExecutivePortVectorKey(const char* name, const char* location);
00039 ~vtkInformationExecutivePortVectorKey();
00040
00042
00044 void Append(vtkInformation* info, vtkExecutive* executive, int port);
00045 void Remove(vtkInformation* info, vtkExecutive* executive, int port);
00046 void Set(vtkInformation* info, vtkExecutive** executives, int* ports, int length);
00047 vtkExecutive** GetExecutives(vtkInformation* info);
00048 int* GetPorts(vtkInformation* info);
00049 void Get(vtkInformation* info, vtkExecutive** executives, int* ports);
00050 int Length(vtkInformation* info);
00051 int Has(vtkInformation* info);
00053
00057 virtual void ShallowCopy(vtkInformation* from, vtkInformation* to);
00058
00060 virtual void Remove(vtkInformation* info);
00061
00063 virtual void Report(vtkInformation* info, vtkGarbageCollector* collector);
00064
00066 virtual void Print(ostream& os, vtkInformation* info);
00067
00068 protected:
00069
00071
00074 vtkExecutive** GetExecutivesWatchAddress(vtkInformation* info);
00075 int* GetPortsWatchAddress(vtkInformation* info);
00077
00078 private:
00079 vtkInformationExecutivePortVectorKey(const vtkInformationExecutivePortVectorKey&);
00080 void operator=(const vtkInformationExecutivePortVectorKey&);
00081 };
00082
00083 #endif