You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

469 lines
18 KiB
C++

/*=========================================================================
Program: Visualization Toolkit
Module: vtkInformation.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkInformation
* @brief Store vtkAlgorithm input/output information.
*
* vtkInformation represents information and/or data for one input or
* one output of a vtkAlgorithm. It maps from keys to values of
* several data types. Instances of this class are collected in
* vtkInformationVector instances and passed to
* vtkAlgorithm::ProcessRequest calls. The information and
* data referenced by the instance on a particular input or output
* define the request made to the vtkAlgorithm instance.
*/
#ifndef vtkInformation_h
#define vtkInformation_h
#include "vtkCommonCoreModule.h" // For export macro
#include "vtkObject.h"
#include <string> // for std::string compat
class vtkDataObject;
class vtkExecutive;
class vtkInformationDataObjectKey;
class vtkInformationDoubleKey;
class vtkInformationDoubleVectorKey;
class vtkInformationExecutivePortKey;
class vtkInformationExecutivePortVectorKey;
class vtkInformationIdTypeKey;
class vtkInformationInformationKey;
class vtkInformationInformationVectorKey;
class vtkInformationIntegerKey;
class vtkInformationIntegerPointerKey;
class vtkInformationIntegerVectorKey;
class vtkInformationInternals;
class vtkInformationKey;
class vtkInformationKeyToInformationFriendship;
class vtkInformationKeyVectorKey;
class vtkInformationObjectBaseKey;
class vtkInformationObjectBaseVectorKey;
class vtkInformationRequestKey;
class vtkInformationStringKey;
class vtkInformationStringVectorKey;
class vtkInformationUnsignedLongKey;
class vtkInformationVariantKey;
class vtkInformationVariantVectorKey;
class vtkInformationVector;
class vtkVariant;
class VTKCOMMONCORE_EXPORT vtkInformation : public vtkObject
{
public:
static vtkInformation* New();
vtkTypeMacro(vtkInformation, vtkObject);
void PrintSelf(ostream& os, vtkIndent indent) override;
void PrintKeys(ostream& os, vtkIndent indent);
/**
* Modified signature with no arguments that calls Modified
* on vtkObject superclass.
*/
void Modified() override;
/**
* Modified signature that takes an information key as an argument.
* Sets the new MTime and invokes a modified event with the
* information key as call data.
*/
void Modified(vtkInformationKey* key);
/**
* Clear all information entries.
*/
void Clear();
/**
* Return the number of keys in this information object (as would be returned
* by iterating over the keys).
*/
int GetNumberOfKeys();
/**
* Copy all information entries from the given vtkInformation
* instance. Any previously existing entries are removed. If
* deep==1, a deep copy of the information structure is performed (new
* instances of any contained vtkInformation and vtkInformationVector
* objects are created).
*/
void Copy(vtkInformation* from, int deep = 0);
/**
* Append all information entries from the given vtkInformation
* instance. If deep==1, a deep copy of the information structure is performed
* (new instances of any contained vtkInformation and vtkInformationVector
* objects are created).
*/
void Append(vtkInformation* from, int deep = 0);
//@{
/**
* Copy the key/value pair associated with the given key in the
* given information object. If deep=1, a deep copy of the information
* structure is performed (new instances of any contained vtkInformation and
* vtkInformationVector objects are created).
*/
void CopyEntry(vtkInformation* from, vtkInformationKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationDataObjectKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationDoubleVectorKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationVariantKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationVariantVectorKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationInformationKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationInformationVectorKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationIntegerKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationIntegerVectorKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationObjectBaseVectorKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationRequestKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationStringKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationStringVectorKey* key, int deep = 0);
void CopyEntry(vtkInformation* from, vtkInformationUnsignedLongKey* key, int deep = 0);
//@}
/**
* Use the given key to lookup a list of other keys in the given
* information object. The key/value pairs associated with these
* other keys will be copied. If deep==1, a deep copy of the
* information structure is performed.
*/
void CopyEntries(vtkInformation* from, vtkInformationKeyVectorKey* key, int deep = 0);
/**
* Check whether the given key appears in this information object.
*/
int Has(vtkInformationKey* key);
/**
* Remove the given key and its data from this information object.
*/
void Remove(vtkInformationKey* key);
//@{
/**
* Get/Set a request-valued entry.
*/
void Set(vtkInformationRequestKey* key);
void Remove(vtkInformationRequestKey* key);
int Has(vtkInformationRequestKey* key);
//@}
//@{
/**
* Get/Set an integer-valued entry.
*/
void Set(vtkInformationIntegerKey* key, int value);
int Get(vtkInformationIntegerKey* key);
void Remove(vtkInformationIntegerKey* key);
int Has(vtkInformationIntegerKey* key);
//@}
//@{
/**
* Get/Set a vtkIdType-valued entry.
*/
void Set(vtkInformationIdTypeKey* key, vtkIdType value);
vtkIdType Get(vtkInformationIdTypeKey* key);
void Remove(vtkInformationIdTypeKey* key);
int Has(vtkInformationIdTypeKey* key);
//@}
//@{
/**
* Get/Set an double-valued entry.
*/
void Set(vtkInformationDoubleKey* key, double value);
double Get(vtkInformationDoubleKey* key);
void Remove(vtkInformationDoubleKey* key);
int Has(vtkInformationDoubleKey* key);
//@}
//@{
/**
* Get/Set an variant-valued entry.
*/
void Set(vtkInformationVariantKey* key, const vtkVariant& value);
const vtkVariant& Get(vtkInformationVariantKey* key);
void Remove(vtkInformationVariantKey* key);
int Has(vtkInformationVariantKey* key);
//@}
//@{
/**
* Get/Set an integer-vector-valued entry.
*/
void Append(vtkInformationIntegerVectorKey* key, int value);
void Set(vtkInformationIntegerVectorKey* key, const int* value, int length);
void Set(vtkInformationIntegerVectorKey* key, int value1, int value2, int value3);
void Set(vtkInformationIntegerVectorKey* key, int value1, int value2, int value3, int value4,
int value5, int value6);
int* Get(vtkInformationIntegerVectorKey* key);
int Get(vtkInformationIntegerVectorKey* key, int idx);
void Get(vtkInformationIntegerVectorKey* key, int* value);
int Length(vtkInformationIntegerVectorKey* key);
void Remove(vtkInformationIntegerVectorKey* key);
int Has(vtkInformationIntegerVectorKey* key);
//@}
//@{
/**
* Get/Set a string-vector-valued entry.
*/
void Append(vtkInformationStringVectorKey* key, const char* value);
void Set(vtkInformationStringVectorKey* key, const char* value, int idx = 0);
void Append(vtkInformationStringVectorKey* key, const std::string& value);
void Set(vtkInformationStringVectorKey* key, const std::string& value, int idx = 0);
const char* Get(vtkInformationStringVectorKey* key, int idx = 0);
int Length(vtkInformationStringVectorKey* key);
void Remove(vtkInformationStringVectorKey* key);
int Has(vtkInformationStringVectorKey* key);
//@}
//@{
/**
* Get/Set an integer-pointer-valued entry.
*/
void Set(vtkInformationIntegerPointerKey* key, int* value, int length);
int* Get(vtkInformationIntegerPointerKey* key);
void Get(vtkInformationIntegerPointerKey* key, int* value);
int Length(vtkInformationIntegerPointerKey* key);
void Remove(vtkInformationIntegerPointerKey* key);
int Has(vtkInformationIntegerPointerKey* key);
//@}
//@{
/**
* Get/Set an unsigned-long-valued entry.
*/
void Set(vtkInformationUnsignedLongKey* key, unsigned long value);
unsigned long Get(vtkInformationUnsignedLongKey* key);
void Remove(vtkInformationUnsignedLongKey* key);
int Has(vtkInformationUnsignedLongKey* key);
//@}
//@{
/**
* Get/Set an double-vector-valued entry.
*/
void Append(vtkInformationDoubleVectorKey* key, double value);
void Set(vtkInformationDoubleVectorKey* key, const double* value, int length);
void Set(vtkInformationDoubleVectorKey* key, double value1, double value2, double value3);
void Set(vtkInformationDoubleVectorKey* key, double value1, double value2, double value3,
double value4, double value5, double value6);
double* Get(vtkInformationDoubleVectorKey* key);
double Get(vtkInformationDoubleVectorKey* key, int idx);
void Get(vtkInformationDoubleVectorKey* key, double* value);
int Length(vtkInformationDoubleVectorKey* key);
void Remove(vtkInformationDoubleVectorKey* key);
int Has(vtkInformationDoubleVectorKey* key);
//@}
//@{
/**
* Get/Set an variant-vector-valued entry.
*/
void Append(vtkInformationVariantVectorKey* key, const vtkVariant& value);
void Set(vtkInformationVariantVectorKey* key, const vtkVariant* value, int length);
void Set(vtkInformationVariantVectorKey* key, const vtkVariant& value1, const vtkVariant& value2,
const vtkVariant& value3);
void Set(vtkInformationVariantVectorKey* key, const vtkVariant& value1, const vtkVariant& value2,
const vtkVariant& value3, const vtkVariant& value4, const vtkVariant& value5,
const vtkVariant& value6);
const vtkVariant* Get(vtkInformationVariantVectorKey* key);
const vtkVariant& Get(vtkInformationVariantVectorKey* key, int idx);
void Get(vtkInformationVariantVectorKey* key, vtkVariant* value);
int Length(vtkInformationVariantVectorKey* key);
void Remove(vtkInformationVariantVectorKey* key);
int Has(vtkInformationVariantVectorKey* key);
//@}
//@{
/**
* Get/Set an InformationKey-vector-valued entry.
*/
void Append(vtkInformationKeyVectorKey* key, vtkInformationKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationKey* value);
void Set(vtkInformationKeyVectorKey* key, vtkInformationKey* const* value, int length);
void Remove(vtkInformationKeyVectorKey* key, vtkInformationKey* value);
vtkInformationKey** Get(vtkInformationKeyVectorKey* key);
vtkInformationKey* Get(vtkInformationKeyVectorKey* key, int idx);
void Get(vtkInformationKeyVectorKey* key, vtkInformationKey** value);
int Length(vtkInformationKeyVectorKey* key);
void Remove(vtkInformationKeyVectorKey* key);
int Has(vtkInformationKeyVectorKey* key);
//@}
// Provide extra overloads of this method to avoid requiring user
// code to include the headers for these key types. Avoid wrapping
// them because the original method can be called from the wrappers
// anyway and this causes a python help string to be too long.
void Append(vtkInformationKeyVectorKey* key, vtkInformationDataObjectKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationDoubleKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationDoubleVectorKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationInformationKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationInformationVectorKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationIntegerKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationIntegerVectorKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationStringKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationStringVectorKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationObjectBaseKey* value);
void Append(vtkInformationKeyVectorKey* key, vtkInformationUnsignedLongKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationDataObjectKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationDoubleKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationDoubleVectorKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationInformationKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationInformationVectorKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationIntegerKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationIntegerVectorKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationStringKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationStringVectorKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationObjectBaseKey* value);
void AppendUnique(vtkInformationKeyVectorKey* key, vtkInformationUnsignedLongKey* value);
//@{
/**
* Get/Set a string-valued entry.
*/
void Set(vtkInformationStringKey* key, const char*);
void Set(vtkInformationStringKey* key, const std::string&);
const char* Get(vtkInformationStringKey* key);
void Remove(vtkInformationStringKey* key);
int Has(vtkInformationStringKey* key);
//@}
//@{
/**
* Get/Set an entry storing another vtkInformation instance.
*/
void Set(vtkInformationInformationKey* key, vtkInformation*);
vtkInformation* Get(vtkInformationInformationKey* key);
void Remove(vtkInformationInformationKey* key);
int Has(vtkInformationInformationKey* key);
//@}
//@{
/**
* Get/Set an entry storing a vtkInformationVector instance.
*/
void Set(vtkInformationInformationVectorKey* key, vtkInformationVector*);
vtkInformationVector* Get(vtkInformationInformationVectorKey* key);
void Remove(vtkInformationInformationVectorKey* key);
int Has(vtkInformationInformationVectorKey* key);
//@}
//@{
/**
* Get/Set an entry storing a vtkObjectBase instance.
*/
void Set(vtkInformationObjectBaseKey* key, vtkObjectBase*);
vtkObjectBase* Get(vtkInformationObjectBaseKey* key);
void Remove(vtkInformationObjectBaseKey* key);
int Has(vtkInformationObjectBaseKey* key);
//@}
//@{
/**
* Manipulate a ObjectBaseVector entry.
*/
void Append(vtkInformationObjectBaseVectorKey* key, vtkObjectBase* data);
void Set(vtkInformationObjectBaseVectorKey* key, vtkObjectBase* value, int idx = 0);
vtkObjectBase* Get(vtkInformationObjectBaseVectorKey* key, int idx = 0);
int Length(vtkInformationObjectBaseVectorKey* key);
void Remove(vtkInformationObjectBaseVectorKey* key);
void Remove(vtkInformationObjectBaseVectorKey* key, vtkObjectBase* objectToRemove);
void Remove(vtkInformationObjectBaseVectorKey* key, int indexToRemove);
int Has(vtkInformationObjectBaseVectorKey* key);
//@}
//@{
/**
* Get/Set an entry storing a vtkDataObject instance.
*/
void Set(vtkInformationDataObjectKey* key, vtkDataObject VTK_WRAP_EXTERN*);
vtkDataObject VTK_WRAP_EXTERN* Get(vtkInformationDataObjectKey* key);
void Remove(vtkInformationDataObjectKey* key);
int Has(vtkInformationDataObjectKey* key);
//@}
//@{
/**
* Upcast the given key instance.
*/
static vtkInformationKey* GetKey(vtkInformationDataObjectKey* key);
static vtkInformationKey* GetKey(vtkInformationDoubleKey* key);
static vtkInformationKey* GetKey(vtkInformationDoubleVectorKey* key);
static vtkInformationKey* GetKey(vtkInformationInformationKey* key);
static vtkInformationKey* GetKey(vtkInformationInformationVectorKey* key);
static vtkInformationKey* GetKey(vtkInformationIntegerKey* key);
static vtkInformationKey* GetKey(vtkInformationIntegerVectorKey* key);
static vtkInformationKey* GetKey(vtkInformationRequestKey* key);
static vtkInformationKey* GetKey(vtkInformationStringKey* key);
static vtkInformationKey* GetKey(vtkInformationStringVectorKey* key);
static vtkInformationKey* GetKey(vtkInformationKey* key);
static vtkInformationKey* GetKey(vtkInformationUnsignedLongKey* key);
static vtkInformationKey* GetKey(vtkInformationVariantKey* key);
static vtkInformationKey* GetKey(vtkInformationVariantVectorKey* key);
//@}
//@{
/**
* Initiate garbage collection when a reference is removed.
*/
void Register(vtkObjectBase* o) override;
void UnRegister(vtkObjectBase* o) override;
//@}
//@{
/**
* Get/Set the Request ivar
*/
void SetRequest(vtkInformationRequestKey* request);
vtkInformationRequestKey* GetRequest();
//@}
protected:
vtkInformation();
~vtkInformation() override;
// Get/Set a map entry directly through the vtkObjectBase instance
// representing the value. Used internally to manage the map.
void SetAsObjectBase(vtkInformationKey* key, vtkObjectBase* value);
const vtkObjectBase* GetAsObjectBase(const vtkInformationKey* key) const;
vtkObjectBase* GetAsObjectBase(vtkInformationKey* key);
// Internal implementation details.
vtkInformationInternals* Internal;
// Garbage collection support.
void ReportReferences(vtkGarbageCollector*) override;
// Report the object associated with the given key to the collector.
void ReportAsObjectBase(vtkInformationKey* key, vtkGarbageCollector* collector);
private:
friend class vtkInformationKeyToInformationFriendship;
friend class vtkInformationIterator;
private:
vtkInformation(const vtkInformation&) = delete;
void operator=(const vtkInformation&) = delete;
vtkInformationRequestKey* Request;
};
#endif
// VTK-HeaderTest-Exclude: vtkInformation.h