The Gaudi Framework  v30r3 (a5ef0a68)
reverse.h
Go to the documentation of this file.
1 #ifndef GAUDIKERNEL_REVERSE_H
2 #define GAUDIKERNEL_REVERSE_H
3 //
4 // provide a generic 'reverse' function for use in range-based for loops.
5 //
6 // example:
7 //
8 // #include "GaudiKernel/reverse.h"
9 // auto l = { 1,2,3,4 };
10 // for ( const auto& i : reverse( l ) ) std::cout << i << std::endl;
11 //
12 // Note that it is perfectly fine to reverse a temporary. The temporary
13 // will be moved into the reverse_wrapper, and thus kept alive for the
14 // duration of the loop. In case reverse is called on an lvalue, the wrapper
15 // will take a reference, so no copy will be performed. (if you wonder how
16 // the code below (very implicitly) distinguishes between the two cases,
17 // google for 'C++11 reference collapsing' -- short version: C++ does not
18 // allow references to references, so in cases where this would happen,
19 // one gets an lvalue reference)
20 //
21 // Also note that reverse_wrapper does not have a constructor, but this
22 // implies that it does meet the requirements for aggregate initializaton,
23 // which allows for {} initialization of its member.
24 //
25 
26 #include <iterator>
27 #include <utility>
28 
29 namespace details
30 {
31 
32  template <typename Iterable>
33  struct reverse_wrapper {
34  Iterable iterable;
35  };
36 
37  template <typename T>
39  {
40  using std::rbegin;
41  return rbegin( w.iterable );
42  }
43  template <typename T>
45  {
46  using std::rend;
47  return rend( w.iterable );
48  }
49 }
50 
51 template <typename T>
53 {
54  return {std::forward<T>( iterable )};
55 }
56 
57 #endif
auto end(reverse_wrapper< T > &w)
Definition: reverse.h:44
details::reverse_wrapper< T > reverse(T &&iterable)
Definition: reverse.h:52
auto begin(reverse_wrapper< T > &w)
Definition: reverse.h:38