00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00022 #ifndef __vtkInformationDoubleVectorKey_h
00023 #define __vtkInformationDoubleVectorKey_h
00024 
00025 #include "vtkInformationKey.h"
00026 
00027 #include "vtkCommonInformationKeyManager.h" 
00028 
00029 class VTK_COMMON_EXPORT vtkInformationDoubleVectorKey : public vtkInformationKey
00030 {
00031 public:
00032   vtkTypeMacro(vtkInformationDoubleVectorKey,vtkInformationKey);
00033   void PrintSelf(ostream& os, vtkIndent indent);
00034 
00035   vtkInformationDoubleVectorKey(const char* name, const char* location,
00036                                  int length=-1);
00037   ~vtkInformationDoubleVectorKey();
00038 
00040 
00042   void Append(vtkInformation* info, double value);
00043   void Set(vtkInformation* info, double* value, int length);
00044   double* Get(vtkInformation* info);
00045   double  Get(vtkInformation* info, int idx);
00046   void Get(vtkInformation* info, double* value);
00047   int Length(vtkInformation* info);
00049 
00053   virtual void ShallowCopy(vtkInformation* from, vtkInformation* to);
00054 
00056   virtual void Print(ostream& os, vtkInformation* info);
00057 
00058 protected:
00059   
00060   int RequiredLength;
00061 
00062 private:
00063   vtkInformationDoubleVectorKey(const vtkInformationDoubleVectorKey&);  
00064   void operator=(const vtkInformationDoubleVectorKey&);  
00065 };
00066 
00067 #endif