VTK  9.6.20260406
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
289
293 ValueType GetTypedComponent(vtkIdType tupleIdx, int comp) const
294 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + comp < GetNumberOfValues())
295 VTK_EXPECTS(0 <= comp && comp < GetNumberOfComponents());
296
298
301 void SetTypedComponent(vtkIdType tupleIdx, int comp, ValueType value)
302 VTK_EXPECTS(0 <= tupleIdx && GetNumberOfComponents() * tupleIdx + comp < GetNumberOfValues())
303 VTK_EXPECTS(0 <= comp && comp < GetNumberOfComponents());
305
307
310 void GetTypedTuple(vtkIdType tupleIdx, ValueType* tuple) const
311 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
313
315
318 void SetTypedTuple(vtkIdType tupleIdx, const ValueType* tuple)
319 VTK_EXPECTS(0 <= tupleIdx && tupleIdx < GetNumberOfTuples());
321
325 const ValueType& GetValue(vtkIdType id) const
326 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues());
327
332
338 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues())
339 {
340 this->Buffer->GetBuffer()[id] = value;
341 this->DataChanged();
342 }
343
344 void SetValue(vtkIdType id, const char* value)
345 VTK_EXPECTS(0 <= id && id < this->GetNumberOfValues()) VTK_EXPECTS(value != nullptr);
346
347 VTK_DEPRECATED_IN_9_7_0("No longer needed")
349 int GetElementComponentSize() const override
350 {
351 return static_cast<int>(sizeof(ValueType::value_type));
352 }
353
358 void InsertValue(vtkIdType id, const char* val) VTK_EXPECTS(0 <= id) VTK_EXPECTS(val != nullptr);
359
364
368 void SetVariantValue(vtkIdType idx, vtkVariant value) override;
369
374 void InsertVariantValue(vtkIdType idx, vtkVariant value) override;
375
380 vtkIdType InsertNextValue(const char* f) VTK_EXPECTS(f != nullptr);
381
388
393 ValueType* GetPointer(vtkIdType id) { return this->Buffer->GetBuffer() + id; }
394 void* GetVoidPointer(vtkIdType id) override { return this->GetPointer(id); }
395
401#ifdef __VTK_WRAP__
402 vtkAbstractBuffer* GetBuffer() { return this->Buffer; }
403#else
405#endif // __VTK_WRAP__
406
411 void DeepCopy(vtkAbstractArray* aa) override;
412
418 void ShallowCopy(vtkAbstractArray* src) override;
419
433 ValueType* array, vtkIdType size, int save, int deleteMethod = VTK_DATA_ARRAY_DELETE);
434 void SetVoidArray(void* array, vtkIdType size, int save) override
435 {
436 this->SetArray(static_cast<ValueType*>(array), size, save);
437 }
438 void SetVoidArray(void* array, vtkIdType size, int save, int deleteMethod) override
439 {
440 this->SetArray(static_cast<ValueType*>(array), size, save, deleteMethod);
441 }
442
449 void SetArrayFreeFunction(void (*callback)(void*)) override;
450
462 unsigned long GetActualMemorySize() const override;
463
467 VTK_DEPRECATED_IN_9_7_0("Use vtk::DataArrayValueRange, or the array directly")
469
475 vtkIdType GetDataSize() const override;
476
478
482 void LookupValue(vtkVariant value, vtkIdList* ids) override;
484
486 void LookupValue(const ValueType& value, vtkIdList* ids);
487
488 vtkIdType LookupValue(const char* value);
489 void LookupValue(const char* value, vtkIdList* ids);
490
499 void DataChanged() override;
500
506 VTK_DEPRECATED_IN_9_7_0("Use DataChanged() instead")
508
514 void ClearLookup() override;
515
516protected:
518 ~vtkStringArray() override;
519
524
529
531
535 VTK_DEPRECATED_IN_9_7_0("Use ReserveTuples")
537 {
538 this->ReserveTuples(sz);
539 return this->Buffer->GetBuffer();
540 }
541
542private:
543 vtkStringArray(const vtkStringArray&) = delete;
544 void operator=(const vtkStringArray&) = delete;
545
546 vtkStringArrayLookup* Lookup;
547 void UpdateLookup();
548};
549
550// Declare vtkArrayDownCast implementations for vtkStringArray:
552
553VTK_ABI_NAMESPACE_END
554#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.
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 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