File: vtkDGArrayOutputAccessor.h

package info (click to toggle)
vtk9 9.5.2%2Bdfsg3-5
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 205,936 kB
  • sloc: cpp: 2,336,565; ansic: 327,116; python: 111,200; yacc: 4,104; java: 3,977; sh: 3,032; xml: 2,771; perl: 2,189; lex: 1,787; makefile: 181; javascript: 165; objc: 153; tcl: 59
file content (76 lines) | stat: -rw-r--r-- 2,060 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
// SPDX-License-Identifier: BSD-3-Clause
/**
 * @class   vtkDGArrayOutputAccessor
 * @brief   Store values interpolated from DG cells into a vtkDoubleArray instance.
 */
#ifndef vtkDGArrayOutputAccessor_h
#define vtkDGArrayOutputAccessor_h

#include "vtkDoubleArray.h"           // For API.
#include "vtkFiltersCellGridModule.h" // For export macro.
#include "vtkVector.h"                // For API.

#include <cassert>

VTK_ABI_NAMESPACE_BEGIN

class VTKFILTERSCELLGRID_EXPORT vtkDGArrayOutputAccessor
{
public:
  vtkDGArrayOutputAccessor(vtkDoubleArray* result);
  vtkDGArrayOutputAccessor(const vtkDGArrayOutputAccessor& other);
  ~vtkDGArrayOutputAccessor();

  vtkDGArrayOutputAccessor& operator=(const vtkDGArrayOutputAccessor& other);

  /// Expose a tuple in a vtkDoubleArray as an object with a size() method
  /// to satisfy requirements of the output iterator API.
  struct Tuple
  {
    Tuple() = default;
    Tuple(double* data, int size)
      : Data(data)
      , Size(size)
    {
    }
    Tuple(const Tuple&) = default;
    Tuple& operator=(const Tuple&) = default;

    double& operator[](int ii)
    {
      assert(ii < this->Size);
      return this->Data[ii];
    }
    const double* data() const { return this->Data; }
    double* data() { return this->Data; }
    int size() const { return this->Size; }

    /// If a tuple is "null", make it "falsy"; otherwise it is "truthy."
    operator bool() const { return !!this->Data && this->Size > 0; }

    double* Data{ nullptr };
    int Size{ 0 };
  };

  Tuple operator[](vtkTypeUInt64 tupleId);
  vtkTypeUInt64 GetKey() const { return this->Key; }
  Tuple GetTuple();
  void Restart();
  bool IsAtEnd() const;

  std::size_t size() const;

  vtkTypeUInt64 operator++();
  vtkTypeUInt64 operator++(int);

  vtkDGArrayOutputAccessor& operator+=(vtkTypeUInt64 count);

protected:
  vtkTypeUInt64 Key{ 0 };
  vtkDoubleArray* Result{ nullptr };
};

VTK_ABI_NAMESPACE_END

#endif // vtkDGArrayOutputAccessor_h