]> oss.titaniummirror.com Git - msp430-gcc.git/blobdiff - libstdc++-v3/include/bits/stl_uninitialized.h
Imported gcc-4.4.3
[msp430-gcc.git] / libstdc++-v3 / include / bits / stl_uninitialized.h
index b5f7b8c40b6974843c4e8cdda9a4ecb680ea4e07..11a66c7a57c70b22ce4bafe637fcb1d86f27f7ff 100644 (file)
@@ -1,11 +1,12 @@
 // Raw memory manipulators -*- C++ -*-
 
-// Copyright (C) 2001 Free Software Foundation, Inc.
+// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
+// Free Software Foundation, Inc.
 //
 // This file is part of the GNU ISO C++ Library.  This library is free
 // software; you can redistribute it and/or modify it under the
 // terms of the GNU General Public License as published by the
-// Free Software Foundation; either version 2, or (at your option)
+// Free Software Foundation; either version 3, or (at your option)
 // any later version.
 
 // This library is distributed in the hope that it will be useful,
 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 // GNU General Public License for more details.
 
-// You should have received a copy of the GNU General Public License along
-// with this library; see the file COPYING.  If not, write to the Free
-// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
-// USA.
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
 
-// As a special exception, you may use this file as part of a free software
-// library without restriction.  Specifically, if other files instantiate
-// templates or use macros or inline functions from this file, or you compile
-// this file and link it with other files to produce an executable, this
-// file does not by itself cause the resulting executable to be covered by
-// the GNU General Public License.  This exception does not however
-// invalidate any other reasons why the executable file might be covered by
-// the GNU General Public License.
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
+// <http://www.gnu.org/licenses/>.
 
 /*
  *
  *  You should not attempt to use it directly.
  */
 
-#ifndef _CPP_BITS_STL_UNINITIALIZED_H
-#define _CPP_BITS_STL_UNINITIALIZED_H 1
+#ifndef _STL_UNINITIALIZED_H
+#define _STL_UNINITIALIZED_H 1
 
-#include <cstring>
+_GLIBCXX_BEGIN_NAMESPACE(std)
 
-namespace std
-{
-
-  // uninitialized_copy
-
-  template<typename _InputIter, typename _ForwardIter>
-    inline _ForwardIter 
-    __uninitialized_copy_aux(_InputIter __first, _InputIter __last,
-                            _ForwardIter __result,
-                            __true_type)
-    { return copy(__first, __last, __result); }
-
-  template<typename _InputIter, typename _ForwardIter>
-    _ForwardIter 
-    __uninitialized_copy_aux(_InputIter __first, _InputIter __last,
-                            _ForwardIter __result,
-                            __false_type)
+  template<bool>
+    struct __uninitialized_copy
     {
-      _ForwardIter __cur = __result;
-      try {
-       for ( ; __first != __last; ++__first, ++__cur)
-         _Construct(&*__cur, *__first);
-       return __cur;
-      }
-      catch(...)
-       {
-         _Destroy(__result, __cur);
-         __throw_exception_again; 
+      template<typename _InputIterator, typename _ForwardIterator>
+        static _ForwardIterator
+        uninitialized_copy(_InputIterator __first, _InputIterator __last,
+                          _ForwardIterator __result)
+        {
+         _ForwardIterator __cur = __result;
+         __try
+           {
+             for (; __first != __last; ++__first, ++__cur)
+               ::new(static_cast<void*>(&*__cur)) typename
+                   iterator_traits<_ForwardIterator>::value_type(*__first);
+             return __cur;
+           }
+         __catch(...)
+           {
+             std::_Destroy(__result, __cur);
+             __throw_exception_again;
+           }
        }
-    }
+    };
+
+  template<>
+    struct __uninitialized_copy<true>
+    {
+      template<typename _InputIterator, typename _ForwardIterator>
+        static _ForwardIterator
+        uninitialized_copy(_InputIterator __first, _InputIterator __last,
+                          _ForwardIterator __result)
+        { return std::copy(__first, __last, __result); }
+    };
 
   /**
    *  @brief Copies the range [first,last) into result.
@@ -103,54 +102,53 @@ namespace std
    *
    *  Like copy(), but does not require an initialized output range.
   */
-  template<typename _InputIter, typename _ForwardIter>
-    inline _ForwardIter
-    uninitialized_copy(_InputIter __first, _InputIter __last, _ForwardIter __result)
+  template<typename _InputIterator, typename _ForwardIterator>
+    inline _ForwardIterator
+    uninitialized_copy(_InputIterator __first, _InputIterator __last,
+                      _ForwardIterator __result)
     {
-      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
-      typedef typename __type_traits<_ValueType>::is_POD_type _Is_POD;
-      return __uninitialized_copy_aux(__first, __last, __result, _Is_POD());
+      typedef typename iterator_traits<_InputIterator>::value_type
+       _ValueType1;
+      typedef typename iterator_traits<_ForwardIterator>::value_type
+       _ValueType2;
+
+      return std::__uninitialized_copy<(__is_pod(_ValueType1)
+                                       && __is_pod(_ValueType2))>::
+       uninitialized_copy(__first, __last, __result);
     }
 
-  inline char*
-  uninitialized_copy(const char* __first, const char* __last, char* __result)
-  {
-    memmove(__result, __first, __last - __first);
-    return __result + (__last - __first);
-  }
-
-  inline wchar_t* 
-  uninitialized_copy(const wchar_t* __first, const wchar_t* __last,
-                    wchar_t* __result)
-  {
-    memmove(__result, __first, sizeof(wchar_t) * (__last - __first));
-    return __result + (__last - __first);
-  }
-
-  // Valid if copy construction is equivalent to assignment, and if the
-  // destructor is trivial.
-  template<typename _ForwardIter, typename _Tp>
-    inline void
-    __uninitialized_fill_aux(_ForwardIter __first, _ForwardIter __last, 
-                            const _Tp& __x, __true_type)
-    { fill(__first, __last, __x); }
 
-  template<typename _ForwardIter, typename _Tp>
-    void
-    __uninitialized_fill_aux(_ForwardIter __first, _ForwardIter __last, 
-                            const _Tp& __x, __false_type)
+  template<bool>
+    struct __uninitialized_fill
     {
-      _ForwardIter __cur = __first;
-      try {
-       for ( ; __cur != __last; ++__cur)
-         _Construct(&*__cur, __x);
-      }
-      catch(...)
-       {
-         _Destroy(__first, __cur);
-         __throw_exception_again; 
+      template<typename _ForwardIterator, typename _Tp>
+        static void
+        uninitialized_fill(_ForwardIterator __first,
+                          _ForwardIterator __last, const _Tp& __x)
+        {
+         _ForwardIterator __cur = __first;
+         __try
+           {
+             for (; __cur != __last; ++__cur)
+               std::_Construct(&*__cur, __x);
+           }
+         __catch(...)
+           {
+             std::_Destroy(__first, __cur);
+             __throw_exception_again;
+           }
        }
-    }
+    };
+
+  template<>
+    struct __uninitialized_fill<true>
+    {
+      template<typename _ForwardIterator, typename _Tp>
+        static void
+        uninitialized_fill(_ForwardIterator __first,
+                          _ForwardIterator __last, const _Tp& __x)
+        { std::fill(__first, __last, __x); }
+    };
 
   /**
    *  @brief Copies the value x into the range [first,last).
@@ -161,130 +159,320 @@ namespace std
    *
    *  Like fill(), but does not require an initialized output range.
   */
-  template<typename _ForwardIter, typename _Tp>
+  template<typename _ForwardIterator, typename _Tp>
     inline void
-    uninitialized_fill(_ForwardIter __first, _ForwardIter __last, const _Tp& __x)
+    uninitialized_fill(_ForwardIterator __first, _ForwardIterator __last,
+                      const _Tp& __x)
     {
-      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
-      typedef typename __type_traits<_ValueType>::is_POD_type _Is_POD;
-      __uninitialized_fill_aux(__first, __last, __x, _Is_POD());
-    }
+      typedef typename iterator_traits<_ForwardIterator>::value_type
+       _ValueType;
 
-  // Valid if copy construction is equivalent to assignment, and if the
-  //  destructor is trivial.
-  template<typename _ForwardIter, typename _Size, typename _Tp>
-    inline _ForwardIter
-    __uninitialized_fill_n_aux(_ForwardIter __first, _Size __n,
-                              const _Tp& __x, __true_type)
-    {
-      return fill_n(__first, __n, __x);
+      std::__uninitialized_fill<__is_pod(_ValueType)>::
+       uninitialized_fill(__first, __last, __x);
     }
 
-  template<typename _ForwardIter, typename _Size, typename _Tp>
-    _ForwardIter
-    __uninitialized_fill_n_aux(_ForwardIter __first, _Size __n,
-                              const _Tp& __x, __false_type)
+
+  template<bool>
+    struct __uninitialized_fill_n
     {
-      _ForwardIter __cur = __first;
-      try {
-       for ( ; __n > 0; --__n, ++__cur)
-         _Construct(&*__cur, __x);
-       return __cur;
-      }
-      catch(...)
-       { 
-         _Destroy(__first, __cur);
-         __throw_exception_again; 
+      template<typename _ForwardIterator, typename _Size, typename _Tp>
+        static void
+        uninitialized_fill_n(_ForwardIterator __first, _Size __n,
+                            const _Tp& __x)
+        {
+         _ForwardIterator __cur = __first;
+         __try
+           {
+             for (; __n > 0; --__n, ++__cur)
+               std::_Construct(&*__cur, __x);
+           }
+         __catch(...)
+           {
+             std::_Destroy(__first, __cur);
+             __throw_exception_again;
+           }
        }
-    }
+    };
+
+  template<>
+    struct __uninitialized_fill_n<true>
+    {
+      template<typename _ForwardIterator, typename _Size, typename _Tp>
+        static void
+        uninitialized_fill_n(_ForwardIterator __first, _Size __n,
+                            const _Tp& __x)
+        { std::fill_n(__first, __n, __x); }
+    };
 
   /**
    *  @brief Copies the value x into the range [first,first+n).
    *  @param  first  An input iterator.
    *  @param  n      The number of copies to make.
    *  @param  x      The source value.
-   *  @return   first+n
+   *  @return   Nothing.
    *
    *  Like fill_n(), but does not require an initialized output range.
   */
-  template<typename _ForwardIter, typename _Size, typename _Tp>
-    inline _ForwardIter 
-    uninitialized_fill_n(_ForwardIter __first, _Size __n, const _Tp& __x)
+  template<typename _ForwardIterator, typename _Size, typename _Tp>
+    inline void
+    uninitialized_fill_n(_ForwardIterator __first, _Size __n, const _Tp& __x)
+    {
+      typedef typename iterator_traits<_ForwardIterator>::value_type
+       _ValueType;
+
+      std::__uninitialized_fill_n<__is_pod(_ValueType)>::
+       uninitialized_fill_n(__first, __n, __x);
+    }
+
+  // Extensions: versions of uninitialized_copy, uninitialized_fill,
+  //  and uninitialized_fill_n that take an allocator parameter.
+  //  We dispatch back to the standard versions when we're given the
+  //  default allocator.  For nondefault allocators we do not use 
+  //  any of the POD optimizations.
+
+  template<typename _InputIterator, typename _ForwardIterator,
+          typename _Allocator>
+    _ForwardIterator
+    __uninitialized_copy_a(_InputIterator __first, _InputIterator __last,
+                          _ForwardIterator __result, _Allocator& __alloc)
+    {
+      _ForwardIterator __cur = __result;
+      __try
+       {
+         for (; __first != __last; ++__first, ++__cur)
+           __alloc.construct(&*__cur, *__first);
+         return __cur;
+       }
+      __catch(...)
+       {
+         std::_Destroy(__result, __cur, __alloc);
+         __throw_exception_again;
+       }
+    }
+
+  template<typename _InputIterator, typename _ForwardIterator, typename _Tp>
+    inline _ForwardIterator
+    __uninitialized_copy_a(_InputIterator __first, _InputIterator __last,
+                          _ForwardIterator __result, allocator<_Tp>&)
+    { return std::uninitialized_copy(__first, __last, __result); }
+
+  template<typename _InputIterator, typename _ForwardIterator,
+          typename _Allocator>
+    inline _ForwardIterator
+    __uninitialized_move_a(_InputIterator __first, _InputIterator __last,
+                          _ForwardIterator __result, _Allocator& __alloc)
+    {
+      return std::__uninitialized_copy_a(_GLIBCXX_MAKE_MOVE_ITERATOR(__first),
+                                        _GLIBCXX_MAKE_MOVE_ITERATOR(__last),
+                                        __result, __alloc);
+    }
+
+  template<typename _ForwardIterator, typename _Tp, typename _Allocator>
+    void
+    __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last,
+                          const _Tp& __x, _Allocator& __alloc)
+    {
+      _ForwardIterator __cur = __first;
+      __try
+       {
+         for (; __cur != __last; ++__cur)
+           __alloc.construct(&*__cur, __x);
+       }
+      __catch(...)
+       {
+         std::_Destroy(__first, __cur, __alloc);
+         __throw_exception_again;
+       }
+    }
+
+  template<typename _ForwardIterator, typename _Tp, typename _Tp2>
+    inline void
+    __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last,
+                          const _Tp& __x, allocator<_Tp2>&)
+    { std::uninitialized_fill(__first, __last, __x); }
+
+  template<typename _ForwardIterator, typename _Size, typename _Tp,
+          typename _Allocator>
+    void
+    __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n, 
+                            const _Tp& __x, _Allocator& __alloc)
     {
-      typedef typename iterator_traits<_ForwardIter>::value_type _ValueType;
-      typedef typename __type_traits<_ValueType>::is_POD_type _Is_POD;
-      return __uninitialized_fill_n_aux(__first, __n, __x, _Is_POD());
+      _ForwardIterator __cur = __first;
+      __try
+       {
+         for (; __n > 0; --__n, ++__cur)
+           __alloc.construct(&*__cur, __x);
+       }
+      __catch(...)
+       {
+         std::_Destroy(__first, __cur, __alloc);
+         __throw_exception_again;
+       }
     }
 
-  // Extensions: __uninitialized_copy_copy, __uninitialized_copy_fill, 
-  // __uninitialized_fill_copy.
+  template<typename _ForwardIterator, typename _Size, typename _Tp,
+          typename _Tp2>
+    inline void
+    __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n, 
+                            const _Tp& __x, allocator<_Tp2>&)
+    { std::uninitialized_fill_n(__first, __n, __x); }
+
+
+  // Extensions: __uninitialized_copy_move, __uninitialized_move_copy,
+  // __uninitialized_fill_move, __uninitialized_move_fill.
+  // All of these algorithms take a user-supplied allocator, which is used
+  // for construction and destruction.
 
-  // __uninitialized_copy_copy
+  // __uninitialized_copy_move
   // Copies [first1, last1) into [result, result + (last1 - first1)), and
-  //  copies [first2, last2) into
+  //  move [first2, last2) into
   //  [result, result + (last1 - first1) + (last2 - first2)).
-
-  template<typename _InputIter1, typename _InputIter2, typename _ForwardIter>
-    inline _ForwardIter
-    __uninitialized_copy_copy(_InputIter1 __first1, _InputIter1 __last1,
-                             _InputIter2 __first2, _InputIter2 __last2,
-                             _ForwardIter __result)
+  template<typename _InputIterator1, typename _InputIterator2,
+          typename _ForwardIterator, typename _Allocator>
+    inline _ForwardIterator
+    __uninitialized_copy_move(_InputIterator1 __first1,
+                             _InputIterator1 __last1,
+                             _InputIterator2 __first2,
+                             _InputIterator2 __last2,
+                             _ForwardIterator __result,
+                             _Allocator& __alloc)
     {
-      _ForwardIter __mid = uninitialized_copy(__first1, __last1, __result);
-      try {
-       return uninitialized_copy(__first2, __last2, __mid);
-      }
-      catch(...)
-       { 
-         _Destroy(__result, __mid);
-         __throw_exception_again; 
+      _ForwardIterator __mid = std::__uninitialized_copy_a(__first1, __last1,
+                                                          __result,
+                                                          __alloc);
+      __try
+       {
+         return std::__uninitialized_move_a(__first2, __last2, __mid, __alloc);
+       }
+      __catch(...)
+       {
+         std::_Destroy(__result, __mid, __alloc);
+         __throw_exception_again;
        }
     }
 
-  // __uninitialized_fill_copy
-  // Fills [result, mid) with x, and copies [first, last) into
+  // __uninitialized_move_copy
+  // Moves [first1, last1) into [result, result + (last1 - first1)), and
+  //  copies [first2, last2) into
+  //  [result, result + (last1 - first1) + (last2 - first2)).
+  template<typename _InputIterator1, typename _InputIterator2,
+          typename _ForwardIterator, typename _Allocator>
+    inline _ForwardIterator
+    __uninitialized_move_copy(_InputIterator1 __first1,
+                             _InputIterator1 __last1,
+                             _InputIterator2 __first2,
+                             _InputIterator2 __last2,
+                             _ForwardIterator __result,
+                             _Allocator& __alloc)
+    {
+      _ForwardIterator __mid = std::__uninitialized_move_a(__first1, __last1,
+                                                          __result,
+                                                          __alloc);
+      __try
+       {
+         return std::__uninitialized_copy_a(__first2, __last2, __mid, __alloc);
+       }
+      __catch(...)
+       {
+         std::_Destroy(__result, __mid, __alloc);
+         __throw_exception_again;
+       }
+    }
+  
+  // __uninitialized_fill_move
+  // Fills [result, mid) with x, and moves [first, last) into
   //  [mid, mid + (last - first)).
-  template<typename _ForwardIter, typename _Tp, typename _InputIter>
-    inline _ForwardIter 
-    __uninitialized_fill_copy(_ForwardIter __result, _ForwardIter __mid,
-                             const _Tp& __x,
-                             _InputIter __first, _InputIter __last)
+  template<typename _ForwardIterator, typename _Tp, typename _InputIterator,
+          typename _Allocator>
+    inline _ForwardIterator
+    __uninitialized_fill_move(_ForwardIterator __result, _ForwardIterator __mid,
+                             const _Tp& __x, _InputIterator __first,
+                             _InputIterator __last, _Allocator& __alloc)
     {
-      uninitialized_fill(__result, __mid, __x);
-      try {
-       return uninitialized_copy(__first, __last, __mid);
-      }
-      catch(...)
+      std::__uninitialized_fill_a(__result, __mid, __x, __alloc);
+      __try
+       {
+         return std::__uninitialized_move_a(__first, __last, __mid, __alloc);
+       }
+      __catch(...)
        {
-         _Destroy(__result, __mid);
-         __throw_exception_again; 
+         std::_Destroy(__result, __mid, __alloc);
+         __throw_exception_again;
        }
     }
 
-  // __uninitialized_copy_fill
-  // Copies [first1, last1) into [first2, first2 + (last1 - first1)), and
+  // __uninitialized_move_fill
+  // Moves [first1, last1) into [first2, first2 + (last1 - first1)), and
   //  fills [first2 + (last1 - first1), last2) with x.
-  template<typename _InputIter, typename _ForwardIter, typename _Tp>
+  template<typename _InputIterator, typename _ForwardIterator, typename _Tp,
+          typename _Allocator>
     inline void
-    __uninitialized_copy_fill(_InputIter __first1, _InputIter __last1,
-                             _ForwardIter __first2, _ForwardIter __last2,
-                             const _Tp& __x)
+    __uninitialized_move_fill(_InputIterator __first1, _InputIterator __last1,
+                             _ForwardIterator __first2,
+                             _ForwardIterator __last2, const _Tp& __x,
+                             _Allocator& __alloc)
     {
-      _ForwardIter __mid2 = uninitialized_copy(__first1, __last1, __first2);
-      try {
-       uninitialized_fill(__mid2, __last2, __x);
-      }
-      catch(...)
+      _ForwardIterator __mid2 = std::__uninitialized_move_a(__first1, __last1,
+                                                           __first2,
+                                                           __alloc);
+      __try
        {
-         _Destroy(__first2, __mid2);
-         __throw_exception_again; 
+         std::__uninitialized_fill_a(__mid2, __last2, __x, __alloc);
+       }
+      __catch(...)
+       {
+         std::_Destroy(__first2, __mid2, __alloc);
+         __throw_exception_again;
        }
     }
 
-} // namespace std
+#ifdef __GXX_EXPERIMENTAL_CXX0X__
+  template<typename _InputIterator, typename _Size,
+          typename _ForwardIterator>
+    _ForwardIterator
+    __uninitialized_copy_n(_InputIterator __first, _Size __n,
+                          _ForwardIterator __result, input_iterator_tag)
+    {
+      _ForwardIterator __cur = __result;
+      __try
+       {
+         for (; __n > 0; --__n, ++__first, ++__cur)
+           ::new(static_cast<void*>(&*__cur)) typename
+               iterator_traits<_ForwardIterator>::value_type(*__first);
+         return __cur;
+       }
+      __catch(...)
+       {
+         std::_Destroy(__result, __cur);
+         __throw_exception_again;
+       }
+    }
+
+  template<typename _RandomAccessIterator, typename _Size,
+          typename _ForwardIterator>
+    inline _ForwardIterator
+    __uninitialized_copy_n(_RandomAccessIterator __first, _Size __n,
+                          _ForwardIterator __result,
+                          random_access_iterator_tag)
+    { return std::uninitialized_copy(__first, __first + __n, __result); }
+
+  /**
+   *  @brief Copies the range [first,first+n) into result.
+   *  @param  first  An input iterator.
+   *  @param  n      The number of elements to copy.
+   *  @param  result An output iterator.
+   *  @return  result + n
+   *
+   *  Like copy_n(), but does not require an initialized output range.
+  */
+  template<typename _InputIterator, typename _Size, typename _ForwardIterator>
+    inline _ForwardIterator
+    uninitialized_copy_n(_InputIterator __first, _Size __n,
+                        _ForwardIterator __result)
+    { return std::__uninitialized_copy_n(__first, __n, __result,
+                                        std::__iterator_category(__first)); }
+#endif
 
-#endif /* _CPP_BITS_STL_UNINITIALIZED_H */
+_GLIBCXX_END_NAMESPACE
 
-// Local Variables:
-// mode:C++
-// End:
+#endif /* _STL_UNINITIALIZED_H */