1 /*=========================================================================
2 
3   Program:   Visualization Toolkit
4   Module:    vtkArrayCoordinates.cxx
5 
6 -------------------------------------------------------------------------
7   Copyright 2008 Sandia Corporation.
8   Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
9   the U.S. Government retains certain rights in this software.
10 -------------------------------------------------------------------------
11 
12   Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
13   All rights reserved.
14   See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
15 
16      This software is distributed WITHOUT ANY WARRANTY; without even
17      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
18      PURPOSE.  See the above copyright notice for more information.
19 
20 =========================================================================*/
21 
22 #include "vtkArrayCoordinates.h"
23 
24 vtkArrayCoordinates::vtkArrayCoordinates() = default;
25 
vtkArrayCoordinates(CoordinateT i)26 vtkArrayCoordinates::vtkArrayCoordinates(CoordinateT i) :
27   Storage(1)
28 {
29   this->Storage[0] = i;
30 }
31 
vtkArrayCoordinates(CoordinateT i,CoordinateT j)32 vtkArrayCoordinates::vtkArrayCoordinates(CoordinateT i, CoordinateT j) :
33   Storage(2)
34 {
35   this->Storage[0] = i;
36   this->Storage[1] = j;
37 }
38 
vtkArrayCoordinates(CoordinateT i,CoordinateT j,CoordinateT k)39 vtkArrayCoordinates::vtkArrayCoordinates(CoordinateT i, CoordinateT j, CoordinateT k) :
40   Storage(3)
41 {
42   this->Storage[0] = i;
43   this->Storage[1] = j;
44   this->Storage[2] = k;
45 }
46 
GetDimensions() const47 vtkArrayCoordinates::DimensionT vtkArrayCoordinates::GetDimensions() const
48 {
49   return static_cast<vtkArrayCoordinates::DimensionT>(this->Storage.size());
50 }
51 
SetDimensions(DimensionT dimensions)52 void vtkArrayCoordinates::SetDimensions(DimensionT dimensions)
53 {
54   this->Storage.assign(dimensions, 0);
55 }
56 
operator [](DimensionT i)57 vtkArrayCoordinates::CoordinateT& vtkArrayCoordinates::operator[](DimensionT i)
58 {
59   return this->Storage[i];
60 }
61 
operator [](DimensionT i) const62 const vtkArrayCoordinates::CoordinateT& vtkArrayCoordinates::operator[](DimensionT i) const
63 {
64   return this->Storage[i];
65 }
66 
GetCoordinate(DimensionT i) const67 vtkArrayCoordinates::CoordinateT vtkArrayCoordinates::GetCoordinate(DimensionT i) const
68 {
69   return this->Storage[i];
70 }
71 
SetCoordinate(DimensionT i,const CoordinateT & coordinate)72 void vtkArrayCoordinates::SetCoordinate(DimensionT i, const CoordinateT& coordinate)
73 {
74   this->Storage[i] = coordinate;
75 }
76 
operator ==(const vtkArrayCoordinates & rhs) const77 bool vtkArrayCoordinates::operator==(const vtkArrayCoordinates& rhs) const
78 {
79   return this->Storage == rhs.Storage;
80 }
81 
operator !=(const vtkArrayCoordinates & rhs) const82 bool vtkArrayCoordinates::operator!=(const vtkArrayCoordinates& rhs) const
83 {
84   return !(*this == rhs);
85 }
86 
operator <<(ostream & stream,const vtkArrayCoordinates & rhs)87 ostream& operator<<(ostream& stream, const vtkArrayCoordinates& rhs)
88 {
89   for(vtkArrayCoordinates::DimensionT i = 0; i != rhs.GetDimensions(); ++i)
90   {
91     if(i)
92       stream << ",";
93     stream << rhs[i];
94   }
95 
96   return stream;
97 }
98 
99