VTK  9.6.1
vtkStringArray.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-FileCopyrightText: Copyright 2004 Sandia Corporation
3// SPDX-License-Identifier: LicenseRef-BSD-3-Clause-Sandia-USGov
20
21#ifndef vtkStringArray_h
22#define vtkStringArray_h
23
24#include "vtkAbstractArray.h"
25#include "vtkCommonCoreModule.h" // For export macro
26#include "vtkStdString.h" // needed for vtkStdString definition
27#include "vtkWrappingHints.h" // For VTK_MARSHALMANUAL
28
29VTK_ABI_NAMESPACE_BEGIN
30class vtkStringArrayLookup;
31
32class VTKCOMMONCORE_EXPORT VTK_MARSHALMANUAL vtkStringArray : public vtkAbstractArray
33{
34public:
42 using ArrayTypeTag = std::integral_constant<int, vtkArrayTypes::VTK_STRING_ARRAY>;
43 using DataTypeTag = std::integral_constant<int, VTK_STRING>;
45
49 void PrintSelf(ostream& os, vtkIndent indent) override;
50
58
62 int GetArrayType() const override { return vtkStringArray::ArrayTypeTag::value; }
63
67 int GetDataType() const override { return vtkStringArray::DataTypeTag::value; }
68
69 int IsNumeric() const override { return 0; }
70
74 void Initialize() override;
75
80 bool CopyComponent(int dstComponent, vtkAbstractArray* src, int srcComponent) override;
81
88 int GetDataTypeSize() const override;
89
94 void Squeeze() override { this->ResizeAndExtend(this->MaxId + 1); }
95
99 vtkTypeBool Resize(vtkIdType numTuples) override;
100
108
114
120 void InsertTuples(vtkIdList* dstIds, vtkIdList* srcIds, vtkAbstractArray* source) override;
121
123 vtkIdType dstStart, vtkIdList* srcIds, vtkAbstractArray* source) override;
124
131 vtkIdType dstStart, vtkIdType n, vtkIdType srcStart, vtkAbstractArray* source) override;
132
139
148 vtkIdType i, vtkIdList* ptIndices, vtkAbstractArray* source, double* weights) override;
149
159 vtkAbstractArray* source2, double t) override;
160
167 void GetTuples(vtkIdList* ptIds, vtkAbstractArray* output) override;
168
176 void GetTuples(vtkIdType p1, vtkIdType p2, vtkAbstractArray* output) override;
177
182 vtkTypeBool Allocate(vtkIdType sz, vtkIdType ext = 1000) override;
183
187 const ValueType& GetValue(vtkIdType id) const
188 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues());
189
194
200 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues())
201 {
202 this->Array[id] = value;
203 this->DataChanged();
204 }
205
206 void SetValue(vtkIdType id, const char* value)
207 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues()) VTK_EXPECTS(value != nullptr);
208
213 void SetNumberOfTuples(vtkIdType number) override
214 {
215 this->SetNumberOfValues(this->NumberOfComponents * number);
216 }
217
221 vtkIdType GetNumberOfValues() const { return (this->MaxId + 1); }
222
224 int GetElementComponentSize() const override
225 {
226 return static_cast<int>(sizeof(ValueType::value_type));
227 }
228
233 void InsertValue(vtkIdType id, const char* val) VTK_EXPECTS(0 <= id) VTK_EXPECTS(val != nullptr);
234
239 void SetVariantValue(vtkIdType idx, vtkVariant value) override;
240
245 void InsertVariantValue(vtkIdType idx, vtkVariant value) override;
246
251 vtkIdType InsertNextValue(const char* f) VTK_EXPECTS(f != nullptr);
252
259
264 ValueType* GetPointer(vtkIdType id) { return this->Array + id; }
265 void* GetVoidPointer(vtkIdType id) override { return this->GetPointer(id); }
266
271 void DeepCopy(vtkAbstractArray* aa) override;
272
286 ValueType* array, vtkIdType size, int save, int deleteMethod = VTK_DATA_ARRAY_DELETE);
287 void SetVoidArray(void* array, vtkIdType size, int save) override
288 {
289 this->SetArray(static_cast<ValueType*>(array), size, save);
290 }
291 void SetVoidArray(void* array, vtkIdType size, int save, int deleteMethod) override
292 {
293 this->SetArray(static_cast<ValueType*>(array), size, save, deleteMethod);
294 }
295
302 void SetArrayFreeFunction(void (*callback)(void*)) override;
303
315 unsigned long GetActualMemorySize() const override;
316
321
327 vtkIdType GetDataSize() const override;
328
330
334 void LookupValue(vtkVariant value, vtkIdList* ids) override;
336
338 void LookupValue(const ValueType& value, vtkIdList* ids);
339
340 vtkIdType LookupValue(const char* value);
341 void LookupValue(const char* value, vtkIdList* ids);
342
351 void DataChanged() override;
352
359
365 void ClearLookup() override;
366
367protected:
369 ~vtkStringArray() override;
370
371 ValueType* Array; // pointer to data
372 ValueType* ResizeAndExtend(vtkIdType sz); // function to resize data
373
374 void (*DeleteFunction)(void*);
375
376private:
377 vtkStringArray(const vtkStringArray&) = delete;
378 void operator=(const vtkStringArray&) = delete;
379
380 vtkStringArrayLookup* Lookup;
381 void UpdateLookup();
382};
383
384// Declare vtkArrayDownCast implementations for vtkStringArray:
386
387VTK_ABI_NAMESPACE_END
388#endif
virtual bool SetNumberOfValues(vtkIdType numValues)
Specify the number of values (tuples * components) for this object to hold.
vtkIdType GetNumberOfValues() const
Get the total number of values in the array.
virtual void DataChanged()=0
Tell the array explicitly that the data has changed.
Abstract superclass to iterate over elements in an vtkAbstractArray.
list of point or cell ids
Definition vtkIdList.h:24
a simple class to control print indentation
Definition vtkIndent.h:29
Wrapper around std::string to keep symbols short.
StdString::value_type value_type
a vtkAbstractArray subclass for strings
int GetArrayType() const override
Return the array type.
int GetDataType() const override
Get the data type.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
ValueType & GetValue(vtkIdType id)
Get the string at a particular index.
ValueType * WritePointer(vtkIdType id, vtkIdType number)
Get the address of a particular data index.
vtkIdType InsertNextValue(const char *f)
void SetVoidArray(void *array, vtkIdType size, int save, int deleteMethod) override
This method lets the user specify data to be held by the array.
vtkArrayIterator * NewIterator() override
Returns a vtkArrayIteratorTemplate<vtkStdString>.
static vtkStringArray * ExtendedNew()
void * GetVoidPointer(vtkIdType id) override
Return a void pointer.
int GetElementComponentSize() const override
Return the size, in bytes, of the lowest-level element of an array.
vtkIdType GetNumberOfValues() const
Return the number of values in the array.
void Squeeze() override
Free any unnecessary memory.
void SetVariantValue(vtkIdType idx, vtkVariant value) override
Set a value in the array form a variant.
vtkIdType InsertNextValue(ValueType f)
Insert data at the end of the array.
void InsertTuples(vtkIdType dstStart, vtkIdType n, vtkIdType srcStart, vtkAbstractArray *source) override
Copy n consecutive tuples starting at srcStart from the source array to this array,...
void SetArrayFreeFunction(void(*callback)(void *)) override
This method allows the user to specify a custom free function to be called when the array is dealloca...
void(* DeleteFunction)(void *)
virtual void DataElementChanged(vtkIdType id)
Tell the array explicitly that a single data element has changed.
static vtkStringArray * FastDownCast(vtkAbstractArray *source)
Perform a fast, safe cast from a vtkAbstractArray to a vtkStringArray.
vtkTypeBool Allocate(vtkIdType sz, vtkIdType ext=1000) override
Allocate memory for this array.
static vtkStringArray * New()
vtkIdType LookupValue(vtkVariant value) override
Return the indices where a specific value appears.
void GetTuples(vtkIdList *ptIds, vtkAbstractArray *output) override
Given a list of indices, return an array of values.
ValueType * GetPointer(vtkIdType id)
Get the address of a particular data index.
void ClearLookup() override
Delete the associated fast lookup data structure on this array, if it exists.
vtkIdType GetDataSize() const override
Returns the size of the data in DataTypeSize units.
void LookupValue(const char *value, vtkIdList *ids)
void InsertTuples(vtkIdList *dstIds, vtkIdList *srcIds, vtkAbstractArray *source) override
Copy the tuples indexed in srcIds from the source array to the tuple locations indexed by dstIds in t...
void LookupValue(vtkVariant value, vtkIdList *ids) override
Return the indices where a specific value appears.
void InsertValue(vtkIdType id, const char *val)
int GetNumberOfElementComponents()
unsigned long GetActualMemorySize() const override
Return the memory in kibibytes (1024 bytes) consumed by this data array.
bool CopyComponent(int dstComponent, vtkAbstractArray *src, int srcComponent) override
Copy one component from src into a (potentially different) component of this array.
void DeepCopy(vtkAbstractArray *aa) override
Deep copy of another string array.
ValueType * ResizeAndExtend(vtkIdType sz)
void Initialize() override
Release storage and reset array to initial state.
void InterpolateTuple(vtkIdType i, vtkIdList *ptIndices, vtkAbstractArray *source, double *weights) override
Set the ith tuple in this array as the interpolated tuple value, given the ptIndices in the source ar...
vtkIdType LookupValue(const ValueType &value)
void InsertTuplesStartingAt(vtkIdType dstStart, vtkIdList *srcIds, vtkAbstractArray *source) override
Copy the tuples indexed in srcIds from the source array to the tuple locations starting at index dstS...
void LookupValue(const ValueType &value, vtkIdList *ids)
void InsertVariantValue(vtkIdType idx, vtkVariant value) override
Safely set a value in the array form a variant.
void GetTuples(vtkIdType p1, vtkIdType p2, vtkAbstractArray *output) override
Get the values for the range of indices specified (i.e., p1->p2 inclusive).
void SetArray(ValueType *array, vtkIdType size, int save, int deleteMethod=VTK_DATA_ARRAY_DELETE)
This method lets the user specify data to be held by the array.
vtkIdType LookupValue(const char *value)
const ValueType & GetValue(vtkIdType id) const
Read-access of string at a particular index.
void InsertTuple(vtkIdType i, vtkIdType j, vtkAbstractArray *source) override
Insert the jth tuple in the source array, at ith location in this array.
vtkTypeBool Resize(vtkIdType numTuples) override
Resize the array while conserving the data.
~vtkStringArray() override
void SetValue(vtkIdType id, const char *value)
std::integral_constant< int, VTK_STRING > DataTypeTag
vtkIdType InsertNextTuple(vtkIdType j, vtkAbstractArray *source) override
Insert the jth tuple in the source array, at the end in this array.
vtkStdString ValueType
std::integral_constant< int, vtkArrayTypes::VTK_STRING_ARRAY > ArrayTypeTag
void SetTuple(vtkIdType i, vtkIdType j, vtkAbstractArray *source) override
Set the tuple at the ith location using the jth tuple in the source array.
void DataChanged() override
Tell the array explicitly that the data has changed.
void SetValue(vtkIdType id, ValueType value)
Set the data at a particular index.
int IsNumeric() const override
This method is here to make backward compatibility easier.
void SetVoidArray(void *array, vtkIdType size, int save) override
This method lets the user specify data to be held by the array.
int GetDataTypeSize() const override
Return the size of the data type.
ValueType * Array
void InterpolateTuple(vtkIdType i, vtkIdType id1, vtkAbstractArray *source1, vtkIdType id2, vtkAbstractArray *source2, double t) override
Insert the ith tuple in this array as interpolated from the two values, p1 and p2,...
void SetNumberOfTuples(vtkIdType number) override
Set the number of tuples (a component group) in the array.
void InsertValue(vtkIdType id, ValueType f)
Insert data at a specified position in the array.
A type representing the union of many types.
Definition vtkVariant.h:53
int vtkTypeBool
Definition vtkABI.h:64
#define vtkArrayDownCast_FastCastMacro(ArrayT)
This macro is used to tell vtkArrayDownCast to use FastDownCast instead of SafeDownCast.
boost::graph_traits< vtkGraph * >::vertex_descriptor source(boost::graph_traits< vtkGraph * >::edge_descriptor e, vtkGraph *)
int vtkIdType
Definition vtkType.h:368
void save(Archiver &ar, const std::string &str, const unsigned int version)
#define VTK_EXPECTS(x)
#define VTK_MARSHALMANUAL
#define VTK_NEWINSTANCE