110 lines
2.7 KiB
Plaintext
110 lines
2.7 KiB
Plaintext
|
// Boost.Units - A C++ library for zero-overhead dimensional analysis and
|
||
|
// unit/quantity manipulation and conversion
|
||
|
//
|
||
|
// Copyright (C) 2003-2008 Matthias Christian Schabel
|
||
|
// Copyright (C) 2008 Steven Watanabe
|
||
|
//
|
||
|
// Distributed under the Boost Software License, Version 1.0. (See
|
||
|
// accompanying file LICENSE_1_0.txt or copy at
|
||
|
// http://www.boost.org/LICENSE_1_0.txt)
|
||
|
|
||
|
#ifndef BOOST_UNITS_DETAIL_SORT_HPP
|
||
|
#define BOOST_UNITS_DETAIL_SORT_HPP
|
||
|
|
||
|
#include <boost/mpl/size.hpp>
|
||
|
#include <boost/mpl/begin.hpp>
|
||
|
#include <boost/mpl/next.hpp>
|
||
|
#include <boost/mpl/deref.hpp>
|
||
|
#include <boost/mpl/push_front.hpp>
|
||
|
#include <boost/mpl/less.hpp>
|
||
|
|
||
|
#include <boost/units/dimensionless_type.hpp>
|
||
|
#include <boost/units/detail/dimension_list.hpp>
|
||
|
|
||
|
namespace boost {
|
||
|
|
||
|
namespace units {
|
||
|
|
||
|
namespace detail {
|
||
|
|
||
|
template<int N>
|
||
|
struct insertion_sort_insert;
|
||
|
|
||
|
template<bool is_greater>
|
||
|
struct insertion_sort_comparison_impl;
|
||
|
|
||
|
// have to recursively add the element to the next sequence.
|
||
|
template<>
|
||
|
struct insertion_sort_comparison_impl<true> {
|
||
|
template<class Begin, int N, class T>
|
||
|
struct apply {
|
||
|
typedef list<
|
||
|
typename Begin::item,
|
||
|
typename insertion_sort_insert<N - 1>::template apply<
|
||
|
typename Begin::next,
|
||
|
T
|
||
|
>::type
|
||
|
> type;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
// prepend the current element
|
||
|
template<>
|
||
|
struct insertion_sort_comparison_impl<false> {
|
||
|
template<class Begin, int N, class T>
|
||
|
struct apply {
|
||
|
typedef list<T, Begin> type;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
template<int N>
|
||
|
struct insertion_sort_insert {
|
||
|
template<class Begin, class T>
|
||
|
struct apply {
|
||
|
typedef typename insertion_sort_comparison_impl<mpl::less<typename Begin::item, T>::value>::template apply<
|
||
|
Begin,
|
||
|
N,
|
||
|
T
|
||
|
>::type type;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
template<>
|
||
|
struct insertion_sort_insert<0> {
|
||
|
template<class Begin, class T>
|
||
|
struct apply {
|
||
|
typedef list<T, dimensionless_type> type;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
template<int N>
|
||
|
struct insertion_sort_impl {
|
||
|
template<class Begin>
|
||
|
struct apply {
|
||
|
typedef typename insertion_sort_impl<N - 1>::template apply<typename Begin::next>::type next;
|
||
|
typedef typename insertion_sort_insert<(next::size::value)>::template apply<next, typename Begin::item>::type type;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
template<>
|
||
|
struct insertion_sort_impl<0> {
|
||
|
template<class Begin>
|
||
|
struct apply {
|
||
|
typedef dimensionless_type type;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
template<class T>
|
||
|
struct insertion_sort
|
||
|
{
|
||
|
typedef typename insertion_sort_impl<T::size::value>::template apply<T>::type type;
|
||
|
};
|
||
|
|
||
|
} // namespace detail
|
||
|
|
||
|
} // namespace units
|
||
|
|
||
|
} // namespace boost
|
||
|
|
||
|
#endif
|