VTK
vtkInformationIntegerVectorKey.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkInformationIntegerVectorKey.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
22 #ifndef vtkInformationIntegerVectorKey_h
23 #define vtkInformationIntegerVectorKey_h
24 
25 #include "vtkCommonCoreModule.h" // For export macro
26 #include "vtkInformationKey.h"
27 
28 #include "vtkCommonInformationKeyManager.h" // Manage instances of this type.
29 
31 {
32 public:
34  void PrintSelf(ostream& os, vtkIndent indent);
35 
36  vtkInformationIntegerVectorKey(const char* name, const char* location,
37  int length=-1);
39 
41 
44  static vtkInformationIntegerVectorKey* MakeKey(const char* name, const char* location,
45  int length=-1)
46  {
47  return new vtkInformationIntegerVectorKey(name, location, length);
48  }
50 
52 
54  void Append(vtkInformation* info, int value);
55  void Set(vtkInformation* info, int* value, int length);
56  void Set(vtkInformation* info);
57  int* Get(vtkInformation* info);
58  int Get(vtkInformation* info, int idx);
59  void Get(vtkInformation* info, int* value);
60  int Length(vtkInformation* info);
62 
66  virtual void ShallowCopy(vtkInformation* from, vtkInformation* to);
67 
69  virtual void Print(ostream& os, vtkInformation* info);
70 
71 protected:
72  // The required length of the vector value (-1 is no restriction).
74 
78  int* GetWatchAddress(vtkInformation* info);
79 
80 private:
82  void operator=(const vtkInformationIntegerVectorKey&); // Not implemented.
83 };
84 
85 #endif
virtual void ShallowCopy(vtkInformation *from, vtkInformation *to)=0
Store vtkAlgorithm input/output information.
static vtkInformationIntegerVectorKey * MakeKey(const char *name, const char *location, int length=-1)
#define VTKCOMMONCORE_EXPORT
void PrintSelf(ostream &os, vtkIndent indent)
void Print(vtkInformation *info)
Superclass for vtkInformation keys.
a simple class to control print indentation
Definition: vtkIndent.h:38