VTK  9.6.20260316
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
185 bool CopyComponent(int dstComponent, vtkAbstractArray* src, int srcComponent) override;
186
193 int GetDataTypeSize() const override;
194
199 void Squeeze() override;
200
208
214
220 void InsertTuples(vtkIdList* dstIds, vtkIdList* srcIds, vtkAbstractArray* source) override;
221
223 vtkIdType dstStart, vtkIdList* srcIds, vtkAbstractArray* source) override;
224
231 vtkIdType dstStart, vtkIdType n, vtkIdType srcStart, vtkAbstractArray* source) override;
232
239
248 vtkIdType i, vtkIdList* ptIndices, vtkAbstractArray* source, double* weights) override;
249
259 vtkAbstractArray* source2, double t) override;
260
267 void GetTuples(vtkIdList* ptIds, vtkAbstractArray* output) override;
268
276 void GetTuples(vtkIdType p1, vtkIdType p2, vtkAbstractArray* output) override;
277
282 vtkTypeBool Allocate(vtkIdType sz, vtkIdType ext = 1000) override;
283
295
299 ValueType GetTypedComponent(vtkIdType tupleIdx, int comp) const
300 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + comp < GetNumberOfValues())
301 VTK_EXPECTS(0 <= comp && comp < GetNumberOfComponents());
302
304
307 void SetTypedComponent(vtkIdType tupleIdx, int comp, ValueType value)
308 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + comp < GetNumberOfValues())
309 VTK_EXPECTS(0 <= comp && comp < GetNumberOfComponents());
311
313
316 void GetTypedTuple(vtkIdType tupleIdx, ValueType* tuple) const
317 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
319
321
324 void SetTypedTuple(vtkIdType tupleIdx, const ValueType* tuple)
325 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
327
331 const ValueType& GetValue(vtkIdType id) const
332 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues());
333
338
344 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues())
345 {
346 this->Buffer->GetBuffer()[id] = value;
347 this->DataChanged();
348 }
349
350 void SetValue(vtkIdType id, const char* value)
351 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues()) VTK_EXPECTS(value != nullptr);
352
353 VTK_DEPRECATED_IN_9_7_0("No longer needed")
355 int GetElementComponentSize() const override
356 {
357 return static_cast<int>(sizeof(ValueType::value_type));
358 }
359
364 void InsertValue(vtkIdType id, const char* val) VTK_EXPECTS(0 <= id) VTK_EXPECTS(val != nullptr);
365
370
374 void SetVariantValue(vtkIdType idx, vtkVariant value) override;
375
380 void InsertVariantValue(vtkIdType idx, vtkVariant value) override;
381
386 vtkIdType InsertNextValue(const char* f) VTK_EXPECTS(f != nullptr);
387
394
399 ValueType* GetPointer(vtkIdType id) { return this->Buffer->GetBuffer() + id; }
400 void* GetVoidPointer(vtkIdType id) override { return this->GetPointer(id); }
401
407#ifdef __VTK_WRAP__
408 vtkAbstractBuffer* GetBuffer() { return this->Buffer; }
409#else
411#endif // __VTK_WRAP__
412
417 void DeepCopy(vtkAbstractArray* aa) override;
418
424 void ShallowCopy(vtkAbstractArray* src) override;
425
439 ValueType* array, vtkIdType size, int save, int deleteMethod = VTK_DATA_ARRAY_DELETE);
440 void SetVoidArray(void* array, vtkIdType size, int save) override
441 {
442 this->SetArray(static_cast<ValueType*>(array), size, save);
443 }
444 void SetVoidArray(void* array, vtkIdType size, int save, int deleteMethod) override
445 {
446 this->SetArray(static_cast<ValueType*>(array), size, save, deleteMethod);
447 }
448
455 void SetArrayFreeFunction(void (*callback)(void*)) override;
456
468 unsigned long GetActualMemorySize() const override;
469
473 VTK_DEPRECATED_IN_9_7_0("Use vtk::DataArrayValueRange, or the array directly")
475
481 vtkIdType GetDataSize() const override;
482
484
488 void LookupValue(vtkVariant value, vtkIdList* ids) override;
490
492 void LookupValue(const ValueType& value, vtkIdList* ids);
493
494 vtkIdType LookupValue(const char* value);
495 void LookupValue(const char* value, vtkIdList* ids);
496
505 void DataChanged() override;
506
512 VTK_DEPRECATED_IN_9_7_0("Use DataChanged() instead")
514
520 void ClearLookup() override;
521
522protected:
524 ~vtkStringArray() override;
525
530 bool AllocateTuples(vtkIdType numTuples);
531
536
541
543
547 VTK_DEPRECATED_IN_9_7_0("Use ReserveTuples")
549 {
550 this->ReserveTuples(sz);
551 return this->Buffer->GetBuffer();
552 }
553
554private:
555 vtkStringArray(const vtkStringArray&) = delete;
556 void operator=(const vtkStringArray&) = delete;
557
558 vtkStringArrayLookup* Lookup;
559 void UpdateLookup();
560};
561
562// Declare vtkArrayDownCast implementations for vtkStringArray:
564
565VTK_ABI_NAMESPACE_END
566#endif
int GetNumberOfComponents() const
Set/Get the dimension (n) of the components.
vtkIdType GetNumberOfTuples() const
Get the number of complete tuples (a component group) in the array.
virtual vtkTypeBool ReserveTuples(vtkIdType numTuples)=0
Reserve the array to the requested number of tuples and preserve data.
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:135
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 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 ReserveTuples(vtkIdType numTuples) override
Reserve the array to the requested number of tuples and preserve 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 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