/*========================================================================= Program: Visualization Toolkit Module: $RCSfile: vtkUnsignedLongLongArray.h,v $ 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. =========================================================================*/ // .NAME vtkUnsignedLongLongArray - dynamic, self-adjusting array of unsigned long long // .SECTION Description // vtkUnsignedLongLongArray is an array of values of type unsigned long long. // It provides methods for insertion and retrieval of values and will // automatically resize itself to hold new data. #ifndef __vtkUnsignedLongLongArray_h #define __vtkUnsignedLongLongArray_h // Tell the template header how to give our superclass a DLL interface. #if !defined(__vtkUnsignedLongLongArray_cxx) # define VTK_DATA_ARRAY_TEMPLATE_TYPE unsigned long long #endif #include "vtkDataArray.h" #include "vtkDataArrayTemplate.h" // Real Superclass // Fake the superclass for the wrappers. #define vtkDataArray vtkDataArrayTemplate class VTK_COMMON_EXPORT vtkUnsignedLongLongArray : public vtkDataArray #undef vtkDataArray { public: static vtkUnsignedLongLongArray* New(); vtkTypeRevisionMacro(vtkUnsignedLongLongArray,vtkDataArray); void PrintSelf(ostream& os, vtkIndent indent); // Description: // Get the data type. int GetDataType() { return VTK_UNSIGNED_LONG_LONG; } // Description: // Copy the tuple value into a user-provided array. void GetTupleValue(vtkIdType i, unsigned long long* tuple) { this->RealSuperclass::GetTupleValue(i, tuple); } // Description: // Set the tuple value at the ith location in the array. void SetTupleValue(vtkIdType i, const unsigned long long* tuple) { this->RealSuperclass::SetTupleValue(i, tuple); } // Description: // Insert (memory allocation performed) the tuple into the ith location // in the array. void InsertTupleValue(vtkIdType i, const unsigned long long* tuple) { this->RealSuperclass::InsertTupleValue(i, tuple); } // Description: // Insert (memory allocation performed) the tuple onto the end of the array. vtkIdType InsertNextTupleValue(const unsigned long long* tuple) { return this->RealSuperclass::InsertNextTupleValue(tuple); } // Description: // Get the data at a particular index. unsigned long long GetValue(vtkIdType id) { return this->RealSuperclass::GetValue(id); } // Description: // Set the data at a particular index. Does not do range checking. Make sure // you use the method SetNumberOfValues() before inserting data. void SetValue(vtkIdType id, unsigned long long value) { this->RealSuperclass::SetValue(id, value); } // Description: // Specify the number of values for this object to hold. Does an // allocation as well as setting the MaxId ivar. Used in conjunction with // SetValue() method for fast insertion. void SetNumberOfValues(vtkIdType number) { this->RealSuperclass::SetNumberOfValues(number); } // Description: // Insert data at a specified position in the array. void InsertValue(vtkIdType id, unsigned long long f) { this->RealSuperclass::InsertValue(id, f); } // Description: // Insert data at the end of the array. Return its location in the array. vtkIdType InsertNextValue(unsigned long long f) { return this->RealSuperclass::InsertNextValue(f); } // Description: // Get the address of a particular data index. Make sure data is allocated // for the number of items requested. Set MaxId according to the number of // data values requested. unsigned long long* WritePointer(vtkIdType id, vtkIdType number) { return this->RealSuperclass::WritePointer(id, number); } // Description: // Get the address of a particular data index. Performs no checks // to verify that the memory has been allocated etc. unsigned long long* GetPointer(vtkIdType id) { return this->RealSuperclass::GetPointer(id); } // Description: // This method lets the user specify data to be held by the array. The // array argument is a pointer to the data. size is the size of // the array supplied by the user. Set save to 1 to keep the class // from deleting the array when it cleans up or reallocates memory. // The class uses the actual array provided; it does not copy the data // from the suppled array. void SetArray(unsigned long long* array, vtkIdType size, int save) { this->RealSuperclass::SetArray(array, size, save); } protected: vtkUnsignedLongLongArray(vtkIdType numComp=1); ~vtkUnsignedLongLongArray(); private: //BTX typedef vtkDataArrayTemplate RealSuperclass; //ETX vtkUnsignedLongLongArray(const vtkUnsignedLongLongArray&); // Not implemented. void operator=(const vtkUnsignedLongLongArray&); // Not implemented. }; #endif