1 // Copyright (C) 2007, 2008 Steven Watanabe, Joseph Gauterin, Niels Dekker
2 //
3 // Distributed under the Boost Software License, Version 1.0. (See
4 // accompanying file LICENSE_1_0.txt or copy at
5 // http://www.boost.org/LICENSE_1_0.txt)
6 // For more information, see http://www.boost.org
7 
8 
9 #ifndef BOOST_UTILITY_SWAP_HPP
10 #define BOOST_UTILITY_SWAP_HPP
11 
12 // Note: the implementation of this utility contains various workarounds:
13 // - swap_impl is put outside the boost namespace, to avoid infinite
14 // recursion (causing stack overflow) when swapping objects of a primitive
15 // type.
16 // - swap_impl has a using-directive, rather than a using-declaration,
17 // because some compilers (including MSVC 7.1, Borland 5.9.3, and
18 // Intel 8.1) don't do argument-dependent lookup when it has a
19 // using-declaration instead.
20 // - boost::swap has two template arguments, instead of one, to
21 // avoid ambiguity when swapping objects of a Boost type that does
22 // not have its own boost::swap overload.
23 
24 #include <algorithm> //for std::swap
25 #include <cstddef> //for std::size_t
26 
27 namespace boost_swap_impl
28 {
29   template<class T>
swap_impl(T & left,T & right)30   void swap_impl(T& left, T& right)
31   {
32     using namespace std;//use std::swap if argument dependent lookup fails
33     swap(left,right);
34   }
35 
36   template<class T, std::size_t N>
swap_impl(T (& left)[N],T (& right)[N])37   void swap_impl(T (& left)[N], T (& right)[N])
38   {
39     for (std::size_t i = 0; i < N; ++i)
40     {
41       ::boost_swap_impl::swap_impl(left[i], right[i]);
42     }
43   }
44 }
45 
46 namespace boost
47 {
48   template<class T1, class T2>
swap(T1 & left,T2 & right)49   void swap(T1& left, T2& right)
50   {
51     ::boost_swap_impl::swap_impl(left, right);
52   }
53 }
54 
55 #endif
56