VTK  9.6.20260223
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
129
130#ifndef vtkStringArray_h
131#define vtkStringArray_h
132
133#include "vtkAbstractArray.h"
134#include "vtkBuffer.h" // For vtkBuffer
135#include "vtkCommonCoreModule.h" // For export macro
136#include "vtkStdString.h" // needed for vtkStdString definition
137#include "vtkWrappingHints.h" // For VTK_MARSHALMANUAL
138
139VTK_ABI_NAMESPACE_BEGIN
140class vtkStringArrayLookup;
141
142class VTKCOMMONCORE_EXPORT VTK_MARSHALMANUAL vtkStringArray : public vtkAbstractArray
143{
144public:
152 using ArrayTypeTag = std::integral_constant<int, vtkArrayTypes::VTK_STRING_ARRAY>;
153 using DataTypeTag = std::integral_constant<int, VTK_STRING>;
155
159 void PrintSelf(ostream& os, vtkIndent indent) override;
160
168
172 int GetArrayType() const override { return vtkStringArray::ArrayTypeTag::value; }
173
177 int GetDataType() const override { return vtkStringArray::DataTypeTag::value; }
178
179 int IsNumeric() const override { return 0; }
180
184 void Initialize() override;
185
190 bool CopyComponent(int dstComponent, vtkAbstractArray* src, int srcComponent) override;
191
198 int GetDataTypeSize() const override;
199
204 void Squeeze() override { this->Resize(this->GetNumberOfTuples()); }
205
209 vtkTypeBool Resize(vtkIdType numTuples) override;
210
218
224
230 void InsertTuples(vtkIdList* dstIds, vtkIdList* srcIds, vtkAbstractArray* source) override;
231
233 vtkIdType dstStart, vtkIdList* srcIds, vtkAbstractArray* source) override;
234
241 vtkIdType dstStart, vtkIdType n, vtkIdType srcStart, vtkAbstractArray* source) override;
242
249
258 vtkIdType i, vtkIdList* ptIndices, vtkAbstractArray* source, double* weights) override;
259
269 vtkAbstractArray* source2, double t) override;
270
277 void GetTuples(vtkIdList* ptIds, vtkAbstractArray* output) override;
278
286 void GetTuples(vtkIdType p1, vtkIdType p2, vtkAbstractArray* output) override;
287
292 vtkTypeBool Allocate(vtkIdType sz, vtkIdType ext = 1000) override;
293
297 ValueType GetTypedComponent(vtkIdType tupleIdx, int comp) const
298 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + comp < GetNumberOfValues())
299 VTK_EXPECTS(0 <= comp && comp < GetNumberOfComponents());
300
302
305 void SetTypedComponent(vtkIdType tupleIdx, int comp, ValueType value)
306 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + comp < GetNumberOfValues())
307 VTK_EXPECTS(0 <= comp && comp < GetNumberOfComponents());
309
311
314 void GetTypedTuple(vtkIdType tupleIdx, ValueType* tuple) const
315 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
317
319
322 void SetTypedTuple(vtkIdType tupleIdx, const ValueType* tuple)
323 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
325
329 const ValueType& GetValue(vtkIdType id) const
330 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues());
331
336
342 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues())
343 {
344 this->Buffer->GetBuffer()[id] = value;
345 this->DataChanged();
346 }
347
348 void SetValue(vtkIdType id, const char* value)
349 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues()) VTK_EXPECTS(value != nullptr);
350
355 void SetNumberOfTuples(vtkIdType number) override
356 {
357 this->SetNumberOfValues(this->NumberOfComponents * number);
358 }
359
360 VTK_DEPRECATED_IN_9_7_0("No longer needed")
362 int GetElementComponentSize() const override
363 {
364 return static_cast<int>(sizeof(ValueType::value_type));
365 }
366
371 void InsertValue(vtkIdType id, const char* val) VTK_EXPECTS(0 <= id) VTK_EXPECTS(val != nullptr);
372
377
381 void SetVariantValue(vtkIdType idx, vtkVariant value) override;
382
387 void InsertVariantValue(vtkIdType idx, vtkVariant value) override;
388
393 vtkIdType InsertNextValue(const char* f) VTK_EXPECTS(f != nullptr);
394
401
406 ValueType* GetPointer(vtkIdType id) { return this->Buffer->GetBuffer() + id; }
407 void* GetVoidPointer(vtkIdType id) override { return this->GetPointer(id); }
408
414#ifdef __VTK_WRAP__
415 vtkAbstractBuffer* GetBuffer() { return this->Buffer; }
416#else
418#endif // __VTK_WRAP__
419
424 void DeepCopy(vtkAbstractArray* aa) override;
425
431 void ShallowCopy(vtkAbstractArray* src) override;
432
446 ValueType* array, vtkIdType size, int save, int deleteMethod = VTK_DATA_ARRAY_DELETE);
447 void SetVoidArray(void* array, vtkIdType size, int save) override
448 {
449 this->SetArray(static_cast<ValueType*>(array), size, save);
450 }
451 void SetVoidArray(void* array, vtkIdType size, int save, int deleteMethod) override
452 {
453 this->SetArray(static_cast<ValueType*>(array), size, save, deleteMethod);
454 }
455
462 void SetArrayFreeFunction(void (*callback)(void*)) override;
463
475 unsigned long GetActualMemorySize() const override;
476
480 VTK_DEPRECATED_IN_9_7_0("Use vtk::DataArrayValueRange, or the array directly")
482
488 vtkIdType GetDataSize() const override;
489
491
495 void LookupValue(vtkVariant value, vtkIdList* ids) override;
497
499 void LookupValue(const ValueType& value, vtkIdList* ids);
500
501 vtkIdType LookupValue(const char* value);
502 void LookupValue(const char* value, vtkIdList* ids);
503
512 void DataChanged() override;
513
519 VTK_DEPRECATED_IN_9_7_0("Use DataChanged() instead")
521
527 void ClearLookup() override;
528
529protected:
531 ~vtkStringArray() override;
532
537 bool AllocateTuples(vtkIdType numTuples);
538
543
548
550
554 VTK_DEPRECATED_IN_9_7_0("Use Resize")
556 {
557 this->Resize(sz);
558 return this->Buffer->GetBuffer();
559 }
560
561private:
562 vtkStringArray(const vtkStringArray&) = delete;
563 void operator=(const vtkStringArray&) = delete;
564
565 vtkStringArrayLookup* Lookup;
566 void UpdateLookup();
567};
568
569// Declare vtkArrayDownCast implementations for vtkStringArray:
571
572VTK_ABI_NAMESPACE_END
573#endif
int GetNumberOfComponents() const
Set/Get the dimension (n) of the components.
virtual vtkTypeBool Resize(vtkIdType numTuples)=0
Resize the array to the requested number of tuples and preserve data.
vtkIdType GetNumberOfTuples() const
Get the number of complete tuples (a component group) in the array.
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 base class for vtkBuffer providing buffer protocol support.
Abstract superclass to iterate over elements in an vtkAbstractArray.
internal storage class used by vtkSOADataArrayTemplate, vtkAOSDataArrayTemplate, and others.
Definition vtkBuffer.h:32
list of point or cell ids
Definition vtkIdList.h:133
a simple class to control print indentation
Definition vtkIndent.h:108
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 * 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>.
void ShallowCopy(vtkAbstractArray *src) override
This method will copy the data from the source array to this array.
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.
void Squeeze() override
Free any unnecessary memory.
void SetVariantValue(vtkIdType idx, vtkVariant value) override
Set a value in the array from a variant.
void SetTypedComponent(vtkIdType tupleIdx, int comp, ValueType value)
Set component comp of the tuple at tupleIdx to value.
ValueType GetTypedComponent(vtkIdType tupleIdx, int comp) const
Get component comp of the tuple at tupleIdx.
vtkIdType InsertNextValue(ValueType f)
Insert data at the end of the array.
vtkBuffer< ValueType > * GetBuffer()
Return the underlying buffer object.
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...
virtual void DataElementChanged(vtkIdType id)
Tell the array explicitly that a single data element has changed.
vtkVariant GetVariantValue(vtkIdType idx) override
Get a value in the array as a variant.
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.
void GetTypedTuple(vtkIdType tupleIdx, ValueType *tuple) const
Copy the tuple at tupleIdx into tuple.
vtkIdType GetDataSize() const override
Returns the size of the data in DataTypeSize units.
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...
vtkBuffer< ValueType > * Buffer
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 AllocateTuples(vtkIdType numTuples)
Allocate space for numTuples.
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)
Function to resize data.
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...
bool ReallocateTuples(vtkIdType numTuples)
Allocate space for numTuples.
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 InsertVariantValue(vtkIdType idx, vtkVariant value) override
Safely set a value in the array from 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.
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.
void SetTypedTuple(vtkIdType tupleIdx, const ValueType *tuple)
Set this array's tuple at tupleIdx to the values in tuple.
bool EnsureAccessToTuple(vtkIdType tupleIdx)
This method resizes the array if needed so that the given tuple index is valid/accessible.
vtkTypeBool Resize(vtkIdType numTuples) override
Resize the array while conserving the data.
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.
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:162
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 *)
#define VTK_DEPRECATED_IN_9_7_0(reason)
int vtkIdType
Definition vtkType.h:363
void save(Archiver &ar, const std::string &str, const unsigned int version)
#define VTK_EXPECTS(x)
#define VTK_MARSHALMANUAL
#define VTK_NEWINSTANCE