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 |