blob: 6f4e366ef7083b47fdd1598c12e8511b0238281c [file] [log] [blame]
Jeff Thompsona28eed82013-08-22 16:21:10 -07001// 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// - ndnboost::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 ndnboost::swap overload.
23
24#include <algorithm> //for std::swap
25#include <cstddef> //for std::size_t
26
27namespace ndnboost_swap_impl
28{
29 template<class T>
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>
37 void swap_impl(T (& left)[N], T (& right)[N])
38 {
39 for (std::size_t i = 0; i < N; ++i)
40 {
41 ::ndnboost_swap_impl::swap_impl(left[i], right[i]);
42 }
43 }
44}
45
46namespace ndnboost
47{
48 template<class T1, class T2>
49 void swap(T1& left, T2& right)
50 {
51 ::ndnboost_swap_impl::swap_impl(left, right);
52 }
53}
54
55#endif