Chris@16
|
1 // Boost.Units - A C++ library for zero-overhead dimensional analysis and
|
Chris@16
|
2 // unit/quantity manipulation and conversion
|
Chris@16
|
3 //
|
Chris@16
|
4 // Copyright (C) 2003-2008 Matthias Christian Schabel
|
Chris@16
|
5 // Copyright (C) 2008 Steven Watanabe
|
Chris@16
|
6 //
|
Chris@16
|
7 // Distributed under the Boost Software License, Version 1.0. (See
|
Chris@16
|
8 // accompanying file LICENSE_1_0.txt or copy at
|
Chris@16
|
9 // http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
10
|
Chris@16
|
11 #ifndef BOOST_UNITS_DETAIL_SORT_HPP
|
Chris@16
|
12 #define BOOST_UNITS_DETAIL_SORT_HPP
|
Chris@16
|
13
|
Chris@16
|
14 #include <boost/mpl/size.hpp>
|
Chris@16
|
15 #include <boost/mpl/begin.hpp>
|
Chris@16
|
16 #include <boost/mpl/next.hpp>
|
Chris@16
|
17 #include <boost/mpl/deref.hpp>
|
Chris@16
|
18 #include <boost/mpl/push_front.hpp>
|
Chris@16
|
19 #include <boost/mpl/less.hpp>
|
Chris@16
|
20
|
Chris@16
|
21 #include <boost/units/dimensionless_type.hpp>
|
Chris@16
|
22 #include <boost/units/detail/dimension_list.hpp>
|
Chris@16
|
23
|
Chris@16
|
24 namespace boost {
|
Chris@16
|
25
|
Chris@16
|
26 namespace units {
|
Chris@16
|
27
|
Chris@16
|
28 namespace detail {
|
Chris@16
|
29
|
Chris@16
|
30 template<int N>
|
Chris@16
|
31 struct insertion_sort_insert;
|
Chris@16
|
32
|
Chris@16
|
33 template<bool is_greater>
|
Chris@16
|
34 struct insertion_sort_comparison_impl;
|
Chris@16
|
35
|
Chris@16
|
36 // have to recursively add the element to the next sequence.
|
Chris@16
|
37 template<>
|
Chris@16
|
38 struct insertion_sort_comparison_impl<true> {
|
Chris@16
|
39 template<class Begin, int N, class T>
|
Chris@16
|
40 struct apply {
|
Chris@16
|
41 typedef list<
|
Chris@16
|
42 typename Begin::item,
|
Chris@16
|
43 typename insertion_sort_insert<N - 1>::template apply<
|
Chris@16
|
44 typename Begin::next,
|
Chris@16
|
45 T
|
Chris@16
|
46 >::type
|
Chris@16
|
47 > type;
|
Chris@16
|
48 };
|
Chris@16
|
49 };
|
Chris@16
|
50
|
Chris@16
|
51 // prepend the current element
|
Chris@16
|
52 template<>
|
Chris@16
|
53 struct insertion_sort_comparison_impl<false> {
|
Chris@16
|
54 template<class Begin, int N, class T>
|
Chris@16
|
55 struct apply {
|
Chris@16
|
56 typedef list<T, Begin> type;
|
Chris@16
|
57 };
|
Chris@16
|
58 };
|
Chris@16
|
59
|
Chris@16
|
60 template<int N>
|
Chris@16
|
61 struct insertion_sort_insert {
|
Chris@16
|
62 template<class Begin, class T>
|
Chris@16
|
63 struct apply {
|
Chris@16
|
64 typedef typename insertion_sort_comparison_impl<mpl::less<typename Begin::item, T>::value>::template apply<
|
Chris@16
|
65 Begin,
|
Chris@16
|
66 N,
|
Chris@16
|
67 T
|
Chris@16
|
68 >::type type;
|
Chris@16
|
69 };
|
Chris@16
|
70 };
|
Chris@16
|
71
|
Chris@16
|
72 template<>
|
Chris@16
|
73 struct insertion_sort_insert<0> {
|
Chris@16
|
74 template<class Begin, class T>
|
Chris@16
|
75 struct apply {
|
Chris@16
|
76 typedef list<T, dimensionless_type> type;
|
Chris@16
|
77 };
|
Chris@16
|
78 };
|
Chris@16
|
79
|
Chris@16
|
80 template<int N>
|
Chris@16
|
81 struct insertion_sort_impl {
|
Chris@16
|
82 template<class Begin>
|
Chris@16
|
83 struct apply {
|
Chris@16
|
84 typedef typename insertion_sort_impl<N - 1>::template apply<typename Begin::next>::type next;
|
Chris@16
|
85 typedef typename insertion_sort_insert<(next::size::value)>::template apply<next, typename Begin::item>::type type;
|
Chris@16
|
86 };
|
Chris@16
|
87 };
|
Chris@16
|
88
|
Chris@16
|
89 template<>
|
Chris@16
|
90 struct insertion_sort_impl<0> {
|
Chris@16
|
91 template<class Begin>
|
Chris@16
|
92 struct apply {
|
Chris@16
|
93 typedef dimensionless_type type;
|
Chris@16
|
94 };
|
Chris@16
|
95 };
|
Chris@16
|
96
|
Chris@16
|
97 template<class T>
|
Chris@16
|
98 struct insertion_sort
|
Chris@16
|
99 {
|
Chris@16
|
100 typedef typename insertion_sort_impl<T::size::value>::template apply<T>::type type;
|
Chris@16
|
101 };
|
Chris@16
|
102
|
Chris@16
|
103 } // namespace detail
|
Chris@16
|
104
|
Chris@16
|
105 } // namespace units
|
Chris@16
|
106
|
Chris@16
|
107 } // namespace boost
|
Chris@16
|
108
|
Chris@16
|
109 #endif
|