OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc4/] [libstdc++-v3/] [include/] [bits/] [stl_uninitialized.h] - Diff between revs 424 and 519

Only display areas with differences | Details | Blame | View Log

Rev 424 Rev 519
// Raw memory manipulators -*- C++ -*-
// Raw memory manipulators -*- C++ -*-
 
 
// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
// Free Software Foundation, Inc.
// Free Software Foundation, Inc.
//
//
// This file is part of the GNU ISO C++ Library.  This library is free
// 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
// software; you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the
// terms of the GNU General Public License as published by the
// Free Software Foundation; either version 3, or (at your option)
// Free Software Foundation; either version 3, or (at your option)
// any later version.
// any later version.
 
 
// This library is distributed in the hope that it will be useful,
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
// GNU General Public License for more details.
 
 
// Under Section 7 of GPL version 3, you are granted additional
// Under Section 7 of GPL version 3, you are granted additional
// permissions described in the GCC Runtime Library Exception, version
// permissions described in the GCC Runtime Library Exception, version
// 3.1, as published by the Free Software Foundation.
// 3.1, as published by the Free Software Foundation.
 
 
// You should have received a copy of the GNU General Public License and
// 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;
// a copy of the GCC Runtime Library Exception along with this program;
// see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
// see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
// <http://www.gnu.org/licenses/>.
// <http://www.gnu.org/licenses/>.
 
 
/*
/*
 *
 *
 * Copyright (c) 1994
 * Copyright (c) 1994
 * Hewlett-Packard Company
 * Hewlett-Packard Company
 *
 *
 * Permission to use, copy, modify, distribute and sell this software
 * Permission to use, copy, modify, distribute and sell this software
 * and its documentation for any purpose is hereby granted without fee,
 * and its documentation for any purpose is hereby granted without fee,
 * provided that the above copyright notice appear in all copies and
 * provided that the above copyright notice appear in all copies and
 * that both that copyright notice and this permission notice appear
 * that both that copyright notice and this permission notice appear
 * in supporting documentation.  Hewlett-Packard Company makes no
 * in supporting documentation.  Hewlett-Packard Company makes no
 * representations about the suitability of this software for any
 * representations about the suitability of this software for any
 * purpose.  It is provided "as is" without express or implied warranty.
 * purpose.  It is provided "as is" without express or implied warranty.
 *
 *
 *
 *
 * Copyright (c) 1996,1997
 * Copyright (c) 1996,1997
 * Silicon Graphics Computer Systems, Inc.
 * Silicon Graphics Computer Systems, Inc.
 *
 *
 * Permission to use, copy, modify, distribute and sell this software
 * Permission to use, copy, modify, distribute and sell this software
 * and its documentation for any purpose is hereby granted without fee,
 * and its documentation for any purpose is hereby granted without fee,
 * provided that the above copyright notice appear in all copies and
 * provided that the above copyright notice appear in all copies and
 * that both that copyright notice and this permission notice appear
 * that both that copyright notice and this permission notice appear
 * in supporting documentation.  Silicon Graphics makes no
 * in supporting documentation.  Silicon Graphics makes no
 * representations about the suitability of this software for any
 * representations about the suitability of this software for any
 * purpose.  It is provided "as is" without express or implied warranty.
 * purpose.  It is provided "as is" without express or implied warranty.
 */
 */
 
 
/** @file stl_uninitialized.h
/** @file stl_uninitialized.h
 *  This is an internal header file, included by other library headers.
 *  This is an internal header file, included by other library headers.
 *  You should not attempt to use it directly.
 *  You should not attempt to use it directly.
 */
 */
 
 
#ifndef _STL_UNINITIALIZED_H
#ifndef _STL_UNINITIALIZED_H
#define _STL_UNINITIALIZED_H 1
#define _STL_UNINITIALIZED_H 1
 
 
_GLIBCXX_BEGIN_NAMESPACE(std)
_GLIBCXX_BEGIN_NAMESPACE(std)
 
 
  template<bool>
  template<bool>
    struct __uninitialized_copy
    struct __uninitialized_copy
    {
    {
      template<typename _InputIterator, typename _ForwardIterator>
      template<typename _InputIterator, typename _ForwardIterator>
        static _ForwardIterator
        static _ForwardIterator
        uninitialized_copy(_InputIterator __first, _InputIterator __last,
        uninitialized_copy(_InputIterator __first, _InputIterator __last,
                           _ForwardIterator __result)
                           _ForwardIterator __result)
        {
        {
          _ForwardIterator __cur = __result;
          _ForwardIterator __cur = __result;
          __try
          __try
            {
            {
              for (; __first != __last; ++__first, ++__cur)
              for (; __first != __last; ++__first, ++__cur)
                std::_Construct(&*__cur, *__first);
                std::_Construct(&*__cur, *__first);
              return __cur;
              return __cur;
            }
            }
          __catch(...)
          __catch(...)
            {
            {
              std::_Destroy(__result, __cur);
              std::_Destroy(__result, __cur);
              __throw_exception_again;
              __throw_exception_again;
            }
            }
        }
        }
    };
    };
 
 
  template<>
  template<>
    struct __uninitialized_copy<true>
    struct __uninitialized_copy<true>
    {
    {
      template<typename _InputIterator, typename _ForwardIterator>
      template<typename _InputIterator, typename _ForwardIterator>
        static _ForwardIterator
        static _ForwardIterator
        uninitialized_copy(_InputIterator __first, _InputIterator __last,
        uninitialized_copy(_InputIterator __first, _InputIterator __last,
                           _ForwardIterator __result)
                           _ForwardIterator __result)
        { return std::copy(__first, __last, __result); }
        { return std::copy(__first, __last, __result); }
    };
    };
 
 
  /**
  /**
   *  @brief Copies the range [first,last) into result.
   *  @brief Copies the range [first,last) into result.
   *  @param  first  An input iterator.
   *  @param  first  An input iterator.
   *  @param  last   An input iterator.
   *  @param  last   An input iterator.
   *  @param  result An output iterator.
   *  @param  result An output iterator.
   *  @return   result + (first - last)
   *  @return   result + (first - last)
   *
   *
   *  Like copy(), but does not require an initialized output range.
   *  Like copy(), but does not require an initialized output range.
  */
  */
  template<typename _InputIterator, typename _ForwardIterator>
  template<typename _InputIterator, typename _ForwardIterator>
    inline _ForwardIterator
    inline _ForwardIterator
    uninitialized_copy(_InputIterator __first, _InputIterator __last,
    uninitialized_copy(_InputIterator __first, _InputIterator __last,
                       _ForwardIterator __result)
                       _ForwardIterator __result)
    {
    {
      typedef typename iterator_traits<_InputIterator>::value_type
      typedef typename iterator_traits<_InputIterator>::value_type
        _ValueType1;
        _ValueType1;
      typedef typename iterator_traits<_ForwardIterator>::value_type
      typedef typename iterator_traits<_ForwardIterator>::value_type
        _ValueType2;
        _ValueType2;
 
 
      return std::__uninitialized_copy<(__is_pod(_ValueType1)
      return std::__uninitialized_copy<(__is_pod(_ValueType1)
                                        && __is_pod(_ValueType2))>::
                                        && __is_pod(_ValueType2))>::
        uninitialized_copy(__first, __last, __result);
        uninitialized_copy(__first, __last, __result);
    }
    }
 
 
 
 
  template<bool>
  template<bool>
    struct __uninitialized_fill
    struct __uninitialized_fill
    {
    {
      template<typename _ForwardIterator, typename _Tp>
      template<typename _ForwardIterator, typename _Tp>
        static void
        static void
        uninitialized_fill(_ForwardIterator __first,
        uninitialized_fill(_ForwardIterator __first,
                           _ForwardIterator __last, const _Tp& __x)
                           _ForwardIterator __last, const _Tp& __x)
        {
        {
          _ForwardIterator __cur = __first;
          _ForwardIterator __cur = __first;
          __try
          __try
            {
            {
              for (; __cur != __last; ++__cur)
              for (; __cur != __last; ++__cur)
                std::_Construct(&*__cur, __x);
                std::_Construct(&*__cur, __x);
            }
            }
          __catch(...)
          __catch(...)
            {
            {
              std::_Destroy(__first, __cur);
              std::_Destroy(__first, __cur);
              __throw_exception_again;
              __throw_exception_again;
            }
            }
        }
        }
    };
    };
 
 
  template<>
  template<>
    struct __uninitialized_fill<true>
    struct __uninitialized_fill<true>
    {
    {
      template<typename _ForwardIterator, typename _Tp>
      template<typename _ForwardIterator, typename _Tp>
        static void
        static void
        uninitialized_fill(_ForwardIterator __first,
        uninitialized_fill(_ForwardIterator __first,
                           _ForwardIterator __last, const _Tp& __x)
                           _ForwardIterator __last, const _Tp& __x)
        { std::fill(__first, __last, __x); }
        { std::fill(__first, __last, __x); }
    };
    };
 
 
  /**
  /**
   *  @brief Copies the value x into the range [first,last).
   *  @brief Copies the value x into the range [first,last).
   *  @param  first  An input iterator.
   *  @param  first  An input iterator.
   *  @param  last   An input iterator.
   *  @param  last   An input iterator.
   *  @param  x      The source value.
   *  @param  x      The source value.
   *  @return   Nothing.
   *  @return   Nothing.
   *
   *
   *  Like fill(), but does not require an initialized output range.
   *  Like fill(), but does not require an initialized output range.
  */
  */
  template<typename _ForwardIterator, typename _Tp>
  template<typename _ForwardIterator, typename _Tp>
    inline void
    inline void
    uninitialized_fill(_ForwardIterator __first, _ForwardIterator __last,
    uninitialized_fill(_ForwardIterator __first, _ForwardIterator __last,
                       const _Tp& __x)
                       const _Tp& __x)
    {
    {
      typedef typename iterator_traits<_ForwardIterator>::value_type
      typedef typename iterator_traits<_ForwardIterator>::value_type
        _ValueType;
        _ValueType;
 
 
      std::__uninitialized_fill<__is_pod(_ValueType)>::
      std::__uninitialized_fill<__is_pod(_ValueType)>::
        uninitialized_fill(__first, __last, __x);
        uninitialized_fill(__first, __last, __x);
    }
    }
 
 
 
 
  template<bool>
  template<bool>
    struct __uninitialized_construct_range_dispatch
    struct __uninitialized_construct_range_dispatch
    {
    {
      template<typename _ForwardIterator, typename _Tp>
      template<typename _ForwardIterator, typename _Tp>
        static void
        static void
        __ucr(_ForwardIterator __first, _ForwardIterator __last,
        __ucr(_ForwardIterator __first, _ForwardIterator __last,
              _Tp& __value)
              _Tp& __value)
        {
        {
          if(__first == __last)
          if(__first == __last)
            return;
            return;
 
 
          _ForwardIterator __cur = __first;
          _ForwardIterator __cur = __first;
          __try
          __try
            {
            {
              std::_Construct(&*__first, _GLIBCXX_MOVE(__value));
              std::_Construct(&*__first, _GLIBCXX_MOVE(__value));
              _ForwardIterator __prev = __cur;
              _ForwardIterator __prev = __cur;
              ++__cur;
              ++__cur;
              for(; __cur != __last; ++__cur, ++__prev)
              for(; __cur != __last; ++__cur, ++__prev)
                std::_Construct(&*__cur, _GLIBCXX_MOVE(*__prev));
                std::_Construct(&*__cur, _GLIBCXX_MOVE(*__prev));
              __value = _GLIBCXX_MOVE(*__prev);
              __value = _GLIBCXX_MOVE(*__prev);
            }
            }
          __catch(...)
          __catch(...)
            {
            {
              std::_Destroy(__first, __cur);
              std::_Destroy(__first, __cur);
              __throw_exception_again;
              __throw_exception_again;
            }
            }
        }
        }
    };
    };
 
 
  template<>
  template<>
    struct __uninitialized_construct_range_dispatch<true>
    struct __uninitialized_construct_range_dispatch<true>
    {
    {
      template<typename _ForwardIterator, typename _Tp>
      template<typename _ForwardIterator, typename _Tp>
        static void
        static void
        __ucr(_ForwardIterator, _ForwardIterator, _Tp&) { }
        __ucr(_ForwardIterator, _ForwardIterator, _Tp&) { }
    };
    };
 
 
  // Constructs objects in the range [first, last).
  // Constructs objects in the range [first, last).
  // Note that while these new objects will take valid values,
  // Note that while these new objects will take valid values,
  // their exact value is not defined. In particular they may
  // their exact value is not defined. In particular they may
  // be 'moved from'.
  // be 'moved from'.
  //
  //
  // While __value may altered during this algorithm, it will have
  // While __value may altered during this algorithm, it will have
  // the same value when the algorithm finishes, unless one of the
  // the same value when the algorithm finishes, unless one of the
  // constructions throws.
  // constructions throws.
  //
  //
  // Requirements: _ForwardIterator::value_type(_Tp&&) is valid.
  // Requirements: _ForwardIterator::value_type(_Tp&&) is valid.
  template<typename _ForwardIterator, typename _Tp>
  template<typename _ForwardIterator, typename _Tp>
    inline void
    inline void
    __uninitialized_construct_range(_ForwardIterator __first,
    __uninitialized_construct_range(_ForwardIterator __first,
                                    _ForwardIterator __last,
                                    _ForwardIterator __last,
                                    _Tp& __value)
                                    _Tp& __value)
    {
    {
      typedef typename std::iterator_traits<_ForwardIterator>::value_type
      typedef typename std::iterator_traits<_ForwardIterator>::value_type
        _ValueType;
        _ValueType;
 
 
      std::__uninitialized_construct_range_dispatch<
      std::__uninitialized_construct_range_dispatch<
        __has_trivial_constructor(_ValueType)>::
        __has_trivial_constructor(_ValueType)>::
          __ucr(__first, __last, __value);
          __ucr(__first, __last, __value);
    }
    }
 
 
 
 
  template<bool>
  template<bool>
    struct __uninitialized_fill_n
    struct __uninitialized_fill_n
    {
    {
      template<typename _ForwardIterator, typename _Size, typename _Tp>
      template<typename _ForwardIterator, typename _Size, typename _Tp>
        static void
        static void
        uninitialized_fill_n(_ForwardIterator __first, _Size __n,
        uninitialized_fill_n(_ForwardIterator __first, _Size __n,
                             const _Tp& __x)
                             const _Tp& __x)
        {
        {
          _ForwardIterator __cur = __first;
          _ForwardIterator __cur = __first;
          __try
          __try
            {
            {
              for (; __n > 0; --__n, ++__cur)
              for (; __n > 0; --__n, ++__cur)
                std::_Construct(&*__cur, __x);
                std::_Construct(&*__cur, __x);
            }
            }
          __catch(...)
          __catch(...)
            {
            {
              std::_Destroy(__first, __cur);
              std::_Destroy(__first, __cur);
              __throw_exception_again;
              __throw_exception_again;
            }
            }
        }
        }
    };
    };
 
 
  template<>
  template<>
    struct __uninitialized_fill_n<true>
    struct __uninitialized_fill_n<true>
    {
    {
      template<typename _ForwardIterator, typename _Size, typename _Tp>
      template<typename _ForwardIterator, typename _Size, typename _Tp>
        static void
        static void
        uninitialized_fill_n(_ForwardIterator __first, _Size __n,
        uninitialized_fill_n(_ForwardIterator __first, _Size __n,
                             const _Tp& __x)
                             const _Tp& __x)
        { std::fill_n(__first, __n, __x); }
        { std::fill_n(__first, __n, __x); }
    };
    };
 
 
  /**
  /**
   *  @brief Copies the value x into the range [first,first+n).
   *  @brief Copies the value x into the range [first,first+n).
   *  @param  first  An input iterator.
   *  @param  first  An input iterator.
   *  @param  n      The number of copies to make.
   *  @param  n      The number of copies to make.
   *  @param  x      The source value.
   *  @param  x      The source value.
   *  @return   Nothing.
   *  @return   Nothing.
   *
   *
   *  Like fill_n(), but does not require an initialized output range.
   *  Like fill_n(), but does not require an initialized output range.
  */
  */
  template<typename _ForwardIterator, typename _Size, typename _Tp>
  template<typename _ForwardIterator, typename _Size, typename _Tp>
    inline void
    inline void
    uninitialized_fill_n(_ForwardIterator __first, _Size __n, const _Tp& __x)
    uninitialized_fill_n(_ForwardIterator __first, _Size __n, const _Tp& __x)
    {
    {
      typedef typename iterator_traits<_ForwardIterator>::value_type
      typedef typename iterator_traits<_ForwardIterator>::value_type
        _ValueType;
        _ValueType;
 
 
      std::__uninitialized_fill_n<__is_pod(_ValueType)>::
      std::__uninitialized_fill_n<__is_pod(_ValueType)>::
        uninitialized_fill_n(__first, __n, __x);
        uninitialized_fill_n(__first, __n, __x);
    }
    }
 
 
  // Extensions: versions of uninitialized_copy, uninitialized_fill,
  // Extensions: versions of uninitialized_copy, uninitialized_fill,
  //  and uninitialized_fill_n that take an allocator parameter.
  //  and uninitialized_fill_n that take an allocator parameter.
  //  We dispatch back to the standard versions when we're given the
  //  We dispatch back to the standard versions when we're given the
  //  default allocator.  For nondefault allocators we do not use 
  //  default allocator.  For nondefault allocators we do not use 
  //  any of the POD optimizations.
  //  any of the POD optimizations.
 
 
  template<typename _InputIterator, typename _ForwardIterator,
  template<typename _InputIterator, typename _ForwardIterator,
           typename _Allocator>
           typename _Allocator>
    _ForwardIterator
    _ForwardIterator
    __uninitialized_copy_a(_InputIterator __first, _InputIterator __last,
    __uninitialized_copy_a(_InputIterator __first, _InputIterator __last,
                           _ForwardIterator __result, _Allocator& __alloc)
                           _ForwardIterator __result, _Allocator& __alloc)
    {
    {
      _ForwardIterator __cur = __result;
      _ForwardIterator __cur = __result;
      __try
      __try
        {
        {
          for (; __first != __last; ++__first, ++__cur)
          for (; __first != __last; ++__first, ++__cur)
            __alloc.construct(&*__cur, *__first);
            __alloc.construct(&*__cur, *__first);
          return __cur;
          return __cur;
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__result, __cur, __alloc);
          std::_Destroy(__result, __cur, __alloc);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
  template<typename _InputIterator, typename _ForwardIterator, typename _Tp>
  template<typename _InputIterator, typename _ForwardIterator, typename _Tp>
    inline _ForwardIterator
    inline _ForwardIterator
    __uninitialized_copy_a(_InputIterator __first, _InputIterator __last,
    __uninitialized_copy_a(_InputIterator __first, _InputIterator __last,
                           _ForwardIterator __result, allocator<_Tp>&)
                           _ForwardIterator __result, allocator<_Tp>&)
    { return std::uninitialized_copy(__first, __last, __result); }
    { return std::uninitialized_copy(__first, __last, __result); }
 
 
  template<typename _InputIterator, typename _ForwardIterator,
  template<typename _InputIterator, typename _ForwardIterator,
           typename _Allocator>
           typename _Allocator>
    inline _ForwardIterator
    inline _ForwardIterator
    __uninitialized_move_a(_InputIterator __first, _InputIterator __last,
    __uninitialized_move_a(_InputIterator __first, _InputIterator __last,
                           _ForwardIterator __result, _Allocator& __alloc)
                           _ForwardIterator __result, _Allocator& __alloc)
    {
    {
      return std::__uninitialized_copy_a(_GLIBCXX_MAKE_MOVE_ITERATOR(__first),
      return std::__uninitialized_copy_a(_GLIBCXX_MAKE_MOVE_ITERATOR(__first),
                                         _GLIBCXX_MAKE_MOVE_ITERATOR(__last),
                                         _GLIBCXX_MAKE_MOVE_ITERATOR(__last),
                                         __result, __alloc);
                                         __result, __alloc);
    }
    }
 
 
  template<typename _ForwardIterator, typename _Tp, typename _Allocator>
  template<typename _ForwardIterator, typename _Tp, typename _Allocator>
    void
    void
    __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last,
    __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last,
                           const _Tp& __x, _Allocator& __alloc)
                           const _Tp& __x, _Allocator& __alloc)
    {
    {
      _ForwardIterator __cur = __first;
      _ForwardIterator __cur = __first;
      __try
      __try
        {
        {
          for (; __cur != __last; ++__cur)
          for (; __cur != __last; ++__cur)
            __alloc.construct(&*__cur, __x);
            __alloc.construct(&*__cur, __x);
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__first, __cur, __alloc);
          std::_Destroy(__first, __cur, __alloc);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
  template<typename _ForwardIterator, typename _Tp, typename _Tp2>
  template<typename _ForwardIterator, typename _Tp, typename _Tp2>
    inline void
    inline void
    __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last,
    __uninitialized_fill_a(_ForwardIterator __first, _ForwardIterator __last,
                           const _Tp& __x, allocator<_Tp2>&)
                           const _Tp& __x, allocator<_Tp2>&)
    { std::uninitialized_fill(__first, __last, __x); }
    { std::uninitialized_fill(__first, __last, __x); }
 
 
  template<typename _ForwardIterator, typename _Size, typename _Tp,
  template<typename _ForwardIterator, typename _Size, typename _Tp,
           typename _Allocator>
           typename _Allocator>
    void
    void
    __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n,
    __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n,
                             const _Tp& __x, _Allocator& __alloc)
                             const _Tp& __x, _Allocator& __alloc)
    {
    {
      _ForwardIterator __cur = __first;
      _ForwardIterator __cur = __first;
      __try
      __try
        {
        {
          for (; __n > 0; --__n, ++__cur)
          for (; __n > 0; --__n, ++__cur)
            __alloc.construct(&*__cur, __x);
            __alloc.construct(&*__cur, __x);
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__first, __cur, __alloc);
          std::_Destroy(__first, __cur, __alloc);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
  template<typename _ForwardIterator, typename _Size, typename _Tp,
  template<typename _ForwardIterator, typename _Size, typename _Tp,
           typename _Tp2>
           typename _Tp2>
    inline void
    inline void
    __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n,
    __uninitialized_fill_n_a(_ForwardIterator __first, _Size __n,
                             const _Tp& __x, allocator<_Tp2>&)
                             const _Tp& __x, allocator<_Tp2>&)
    { std::uninitialized_fill_n(__first, __n, __x); }
    { std::uninitialized_fill_n(__first, __n, __x); }
 
 
 
 
  // Extensions: __uninitialized_copy_move, __uninitialized_move_copy,
  // Extensions: __uninitialized_copy_move, __uninitialized_move_copy,
  // __uninitialized_fill_move, __uninitialized_move_fill.
  // __uninitialized_fill_move, __uninitialized_move_fill.
  // All of these algorithms take a user-supplied allocator, which is used
  // All of these algorithms take a user-supplied allocator, which is used
  // for construction and destruction.
  // for construction and destruction.
 
 
  // __uninitialized_copy_move
  // __uninitialized_copy_move
  // Copies [first1, last1) into [result, result + (last1 - first1)), and
  // Copies [first1, last1) into [result, result + (last1 - first1)), and
  //  move [first2, last2) into
  //  move [first2, last2) into
  //  [result, result + (last1 - first1) + (last2 - first2)).
  //  [result, result + (last1 - first1) + (last2 - first2)).
  template<typename _InputIterator1, typename _InputIterator2,
  template<typename _InputIterator1, typename _InputIterator2,
           typename _ForwardIterator, typename _Allocator>
           typename _ForwardIterator, typename _Allocator>
    inline _ForwardIterator
    inline _ForwardIterator
    __uninitialized_copy_move(_InputIterator1 __first1,
    __uninitialized_copy_move(_InputIterator1 __first1,
                              _InputIterator1 __last1,
                              _InputIterator1 __last1,
                              _InputIterator2 __first2,
                              _InputIterator2 __first2,
                              _InputIterator2 __last2,
                              _InputIterator2 __last2,
                              _ForwardIterator __result,
                              _ForwardIterator __result,
                              _Allocator& __alloc)
                              _Allocator& __alloc)
    {
    {
      _ForwardIterator __mid = std::__uninitialized_copy_a(__first1, __last1,
      _ForwardIterator __mid = std::__uninitialized_copy_a(__first1, __last1,
                                                           __result,
                                                           __result,
                                                           __alloc);
                                                           __alloc);
      __try
      __try
        {
        {
          return std::__uninitialized_move_a(__first2, __last2, __mid, __alloc);
          return std::__uninitialized_move_a(__first2, __last2, __mid, __alloc);
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__result, __mid, __alloc);
          std::_Destroy(__result, __mid, __alloc);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
  // __uninitialized_move_copy
  // __uninitialized_move_copy
  // Moves [first1, last1) into [result, result + (last1 - first1)), and
  // Moves [first1, last1) into [result, result + (last1 - first1)), and
  //  copies [first2, last2) into
  //  copies [first2, last2) into
  //  [result, result + (last1 - first1) + (last2 - first2)).
  //  [result, result + (last1 - first1) + (last2 - first2)).
  template<typename _InputIterator1, typename _InputIterator2,
  template<typename _InputIterator1, typename _InputIterator2,
           typename _ForwardIterator, typename _Allocator>
           typename _ForwardIterator, typename _Allocator>
    inline _ForwardIterator
    inline _ForwardIterator
    __uninitialized_move_copy(_InputIterator1 __first1,
    __uninitialized_move_copy(_InputIterator1 __first1,
                              _InputIterator1 __last1,
                              _InputIterator1 __last1,
                              _InputIterator2 __first2,
                              _InputIterator2 __first2,
                              _InputIterator2 __last2,
                              _InputIterator2 __last2,
                              _ForwardIterator __result,
                              _ForwardIterator __result,
                              _Allocator& __alloc)
                              _Allocator& __alloc)
    {
    {
      _ForwardIterator __mid = std::__uninitialized_move_a(__first1, __last1,
      _ForwardIterator __mid = std::__uninitialized_move_a(__first1, __last1,
                                                           __result,
                                                           __result,
                                                           __alloc);
                                                           __alloc);
      __try
      __try
        {
        {
          return std::__uninitialized_copy_a(__first2, __last2, __mid, __alloc);
          return std::__uninitialized_copy_a(__first2, __last2, __mid, __alloc);
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__result, __mid, __alloc);
          std::_Destroy(__result, __mid, __alloc);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
  // __uninitialized_fill_move
  // __uninitialized_fill_move
  // Fills [result, mid) with x, and moves [first, last) into
  // Fills [result, mid) with x, and moves [first, last) into
  //  [mid, mid + (last - first)).
  //  [mid, mid + (last - first)).
  template<typename _ForwardIterator, typename _Tp, typename _InputIterator,
  template<typename _ForwardIterator, typename _Tp, typename _InputIterator,
           typename _Allocator>
           typename _Allocator>
    inline _ForwardIterator
    inline _ForwardIterator
    __uninitialized_fill_move(_ForwardIterator __result, _ForwardIterator __mid,
    __uninitialized_fill_move(_ForwardIterator __result, _ForwardIterator __mid,
                              const _Tp& __x, _InputIterator __first,
                              const _Tp& __x, _InputIterator __first,
                              _InputIterator __last, _Allocator& __alloc)
                              _InputIterator __last, _Allocator& __alloc)
    {
    {
      std::__uninitialized_fill_a(__result, __mid, __x, __alloc);
      std::__uninitialized_fill_a(__result, __mid, __x, __alloc);
      __try
      __try
        {
        {
          return std::__uninitialized_move_a(__first, __last, __mid, __alloc);
          return std::__uninitialized_move_a(__first, __last, __mid, __alloc);
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__result, __mid, __alloc);
          std::_Destroy(__result, __mid, __alloc);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
  // __uninitialized_move_fill
  // __uninitialized_move_fill
  // Moves [first1, last1) into [first2, first2 + (last1 - first1)), and
  // Moves [first1, last1) into [first2, first2 + (last1 - first1)), and
  //  fills [first2 + (last1 - first1), last2) with x.
  //  fills [first2 + (last1 - first1), last2) with x.
  template<typename _InputIterator, typename _ForwardIterator, typename _Tp,
  template<typename _InputIterator, typename _ForwardIterator, typename _Tp,
           typename _Allocator>
           typename _Allocator>
    inline void
    inline void
    __uninitialized_move_fill(_InputIterator __first1, _InputIterator __last1,
    __uninitialized_move_fill(_InputIterator __first1, _InputIterator __last1,
                              _ForwardIterator __first2,
                              _ForwardIterator __first2,
                              _ForwardIterator __last2, const _Tp& __x,
                              _ForwardIterator __last2, const _Tp& __x,
                              _Allocator& __alloc)
                              _Allocator& __alloc)
    {
    {
      _ForwardIterator __mid2 = std::__uninitialized_move_a(__first1, __last1,
      _ForwardIterator __mid2 = std::__uninitialized_move_a(__first1, __last1,
                                                            __first2,
                                                            __first2,
                                                            __alloc);
                                                            __alloc);
      __try
      __try
        {
        {
          std::__uninitialized_fill_a(__mid2, __last2, __x, __alloc);
          std::__uninitialized_fill_a(__mid2, __last2, __x, __alloc);
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__first2, __mid2, __alloc);
          std::_Destroy(__first2, __mid2, __alloc);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
#ifdef __GXX_EXPERIMENTAL_CXX0X__
#ifdef __GXX_EXPERIMENTAL_CXX0X__
  template<typename _InputIterator, typename _Size,
  template<typename _InputIterator, typename _Size,
           typename _ForwardIterator>
           typename _ForwardIterator>
    _ForwardIterator
    _ForwardIterator
    __uninitialized_copy_n(_InputIterator __first, _Size __n,
    __uninitialized_copy_n(_InputIterator __first, _Size __n,
                           _ForwardIterator __result, input_iterator_tag)
                           _ForwardIterator __result, input_iterator_tag)
    {
    {
      _ForwardIterator __cur = __result;
      _ForwardIterator __cur = __result;
      __try
      __try
        {
        {
          for (; __n > 0; --__n, ++__first, ++__cur)
          for (; __n > 0; --__n, ++__first, ++__cur)
            ::new(static_cast<void*>(&*__cur)) typename
            ::new(static_cast<void*>(&*__cur)) typename
                iterator_traits<_ForwardIterator>::value_type(*__first);
                iterator_traits<_ForwardIterator>::value_type(*__first);
          return __cur;
          return __cur;
        }
        }
      __catch(...)
      __catch(...)
        {
        {
          std::_Destroy(__result, __cur);
          std::_Destroy(__result, __cur);
          __throw_exception_again;
          __throw_exception_again;
        }
        }
    }
    }
 
 
  template<typename _RandomAccessIterator, typename _Size,
  template<typename _RandomAccessIterator, typename _Size,
           typename _ForwardIterator>
           typename _ForwardIterator>
    inline _ForwardIterator
    inline _ForwardIterator
    __uninitialized_copy_n(_RandomAccessIterator __first, _Size __n,
    __uninitialized_copy_n(_RandomAccessIterator __first, _Size __n,
                           _ForwardIterator __result,
                           _ForwardIterator __result,
                           random_access_iterator_tag)
                           random_access_iterator_tag)
    { return std::uninitialized_copy(__first, __first + __n, __result); }
    { return std::uninitialized_copy(__first, __first + __n, __result); }
 
 
  /**
  /**
   *  @brief Copies the range [first,first+n) into result.
   *  @brief Copies the range [first,first+n) into result.
   *  @param  first  An input iterator.
   *  @param  first  An input iterator.
   *  @param  n      The number of elements to copy.
   *  @param  n      The number of elements to copy.
   *  @param  result An output iterator.
   *  @param  result An output iterator.
   *  @return  result + n
   *  @return  result + n
   *
   *
   *  Like copy_n(), but does not require an initialized output range.
   *  Like copy_n(), but does not require an initialized output range.
  */
  */
  template<typename _InputIterator, typename _Size, typename _ForwardIterator>
  template<typename _InputIterator, typename _Size, typename _ForwardIterator>
    inline _ForwardIterator
    inline _ForwardIterator
    uninitialized_copy_n(_InputIterator __first, _Size __n,
    uninitialized_copy_n(_InputIterator __first, _Size __n,
                         _ForwardIterator __result)
                         _ForwardIterator __result)
    { return std::__uninitialized_copy_n(__first, __n, __result,
    { return std::__uninitialized_copy_n(__first, __n, __result,
                                         std::__iterator_category(__first)); }
                                         std::__iterator_category(__first)); }
#endif
#endif
 
 
_GLIBCXX_END_NAMESPACE
_GLIBCXX_END_NAMESPACE
 
 
#endif /* _STL_UNINITIALIZED_H */
#endif /* _STL_UNINITIALIZED_H */
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.