dune-common  2.2.0
array.hh
Go to the documentation of this file.
1 // -*- tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
2 // vi: set ts=8 sw=2 et sts=2:
3 
4 #ifndef DUNE_ARRAY_HH
5 #define DUNE_ARRAY_HH
6 
11 #include<iostream>
12 #include<iomanip>
13 #include<string>
14 
15 // Include system implementation of array class if present
16 #ifdef HAVE_ARRAY
17 #include <array>
18 #else
19 #include <algorithm>
20 #endif
21 
22 #include "deprecated.hh"
23 
24 namespace Dune
25 {
31 #ifdef HAVE_ARRAY
32  using std::array;
33 #else
34 
39  template<class T, size_t N>
40  class array {
41  public:
42 
44  typedef T value_type;
45 
48 
50  typedef const value_type& const_reference;
51 
53  typedef value_type* iterator;
54 
56  typedef const value_type* const_iterator;
57 
59  typedef std::size_t size_type;
60 
62  typedef std::ptrdiff_t difference_type;
63 
65  typedef std::reverse_iterator<iterator> reverse_iterator;
66 
68  typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
69 
71  size_type size() const {return N;}
72 
74  array<T,N>& operator= (const T& t)
75  {
76  fill(t);
77  return (*this);
78  }
79 
81  void assign(const T& t) DUNE_DEPRECATED
82  {
83  fill(t);
84  }
85 
87  void fill(const T& t)
88  {
89  for (size_type i=0; i<N; i++) a[i]=t;
90  }
91 
94  {
95  return a[i];
96  }
97 
100  {
101  return a[i];
102  }
103 
105  {
106  return a;
107  }
108 
110  {
111  return a;
112  }
113 
115  {
116  return a + N;
117  }
118 
120  {
121  return a + N;
122  }
123 
124  T a[(N > 0) ? N : 1];
125  };
126 
127 
128 
129  // Comparison Operators (see [lib.container.requirements])
130  // -------------------------------------------------------
131 
132  template< class T, size_t N >
133  inline bool operator< ( const array< T, N > &a, const array< T, N > &b )
134  {
135  return std::lexicographical_compare( a.begin(), a.end(), b.begin(), b.end() );
136  }
137 
138  template< class T, size_t N >
139  inline bool operator> ( const array< T, N > &a, const array< T, N > &b )
140  {
141  return b < a;
142  }
143 
144  template< class T, size_t N >
145  inline bool operator<= ( const array< T, N > &a, const array< T, N > &b )
146  {
147  return !(a > b);
148  }
149 
150  template< class T, size_t N >
151  inline bool operator>= ( const array< T, N > &a, const array< T, N > &b )
152  {
153  return !(a < b);
154  }
155 #endif
156 
158  template < class T, size_t N >
159  inline std::ostream& operator<< (std::ostream& s, const array<T,N>& e)
160  {
161  s << "[";
162  for (size_t i=0; i<N-1; i++) s << e[i] << ",";
163  s << e[N-1] << "]";
164  return s;
165  }
166 
167 #ifndef DOXYGEN
168  template<class T>
169  array<T, 1> make_array(const T &t0) {
170  array<T, 1> result = { t0 };
171  return result;
172  }
173 
174  template<class T>
175  array<T, 2> make_array(const T &t0, const T &t1) {
176  array<T, 2> result = { t0, t1 };
177  return result;
178  }
179 
180  template<class T>
181  array<T, 3> make_array(const T &t0, const T &t1, const T &t2) {
182  array<T, 3> result = { t0, t1, t2 };
183  return result;
184  }
185 
186  template<class T>
187  array<T, 4> make_array(const T &t0, const T &t1, const T &t2, const T &t3) {
188  array<T, 4> result = { t0, t1, t2, t3 };
189  return result;
190  }
191 
192  template<class T>
193  array<T, 5> make_array(const T &t0, const T &t1, const T &t2, const T &t3,
194  const T &t4)
195  {
196  array<T, 5> result = { t0, t1, t2, t3, t4 };
197  return result;
198  }
199 
200  template<class T>
201  array<T, 6> make_array(const T &t0, const T &t1, const T &t2, const T &t3,
202  const T &t4, const T &t5)
203  {
204  array<T, 6> result = { t0, t1, t2, t3, t4, t5 };
205  return result;
206  }
207 
208  template<class T>
209  array<T, 7> make_array(const T &t0, const T &t1, const T &t2, const T &t3,
210  const T &t4, const T &t5, const T &t6)
211  {
212  array<T, 7> result = { t0, t1, t2, t3, t4, t5, t6 };
213  return result;
214  }
215 
216  template<class T>
217  array<T, 8> make_array(const T &t0, const T &t1, const T &t2, const T &t3,
218  const T &t4, const T &t5, const T &t6, const T &t7)
219  {
220  array<T, 8> result = { t0, t1, t2, t3, t4, t5, t6, t7 };
221  return result;
222  }
223 
224  template<class T>
225  array<T, 9> make_array(const T &t0, const T &t1, const T &t2, const T &t3,
226  const T &t4, const T &t5, const T &t6, const T &t7,
227  const T &t8)
228  {
229  array<T, 9> result = { t0, t1, t2, t3, t4, t5, t6, t7, t8 };
230  return result;
231  }
232 #endif // !DOXYGEN
233 
235 
241  template<class T>
242  array<T, 10> make_array(const T &t0, const T &t1, const T &t2, const T &t3,
243  const T &t4, const T &t5, const T &t6, const T &t7,
244  const T &t8, const T &t9)
245  {
246  array<T, 10> result = { t0, t1, t2, t3, t4, t5, t6, t7, t8, t9 };
247  return result;
248  }
249 
252 } // end namespace Dune
253 
254 #endif