123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 |
- /*
- * Copyright (c) 2012 Glen Joseph Fernandes
- * glenfe at live dot com
- *
- * Distributed under the Boost Software License,
- * Version 1.0. (See accompanying file LICENSE_1_0.txt
- * or copy at http://boost.org/LICENSE_1_0.txt)
- */
- #ifndef BOOST_SMART_PTR_DETAIL_ARRAY_UTILITY_HPP
- #define BOOST_SMART_PTR_DETAIL_ARRAY_UTILITY_HPP
- #include <boost/config.hpp>
- #include <boost/type_traits/has_trivial_constructor.hpp>
- #include <boost/type_traits/has_trivial_destructor.hpp>
- namespace boost {
- namespace detail {
- template<typename T>
- inline void array_destroy(T*, std::size_t, boost::true_type) {
- }
- template<typename T>
- inline void array_destroy(T* memory, std::size_t size, boost::false_type) {
- for (std::size_t i = size; i > 0; ) {
- memory[--i].~T();
- }
- }
- template<typename T>
- inline void array_destroy(T* memory, std::size_t size) {
- boost::has_trivial_destructor<T> type;
- array_destroy(memory, size, type);
- }
- template<typename T>
- inline void array_init(T* memory, std::size_t size, boost::true_type) {
- for (std::size_t i = 0; i < size; i++) {
- memory[i] = T();
- }
- }
- template<typename T>
- inline void array_init(T* memory, std::size_t size, boost::false_type) {
- #if !defined(BOOST_NO_EXCEPTIONS)
- std::size_t i = 0;
- try {
- for (; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T();
- }
- } catch (...) {
- array_destroy(memory, i);
- throw;
- }
- #else
- for (std::size_t i = 0; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T();
- }
- #endif
- }
- template<typename T>
- inline void array_init(T* memory, std::size_t size) {
- boost::has_trivial_default_constructor<T> type;
- array_init(memory, size, type);
- }
- #if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES)
- template<typename T>
- inline void array_init_value(T* memory, std::size_t size, T&& value) {
- #if !defined(BOOST_NO_EXCEPTIONS)
- std::size_t i = 0;
- try {
- for (; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(value);
- }
- } catch (...) {
- array_destroy(memory, i);
- throw;
- }
- #else
- for (std::size_t i = 0; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(value);
- }
- #endif
- }
- #if !defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES)
- template<typename T, typename... Args>
- inline void array_init_args(T* memory, std::size_t size, Args&&... args) {
- #if !defined(BOOST_NO_EXCEPTIONS)
- std::size_t i = 0;
- try {
- for (; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(args...);
- }
- } catch (...) {
- array_destroy(memory, i);
- throw;
- }
- #else
- for (std::size_t i = 0; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(args...);
- }
- #endif
- }
- #endif
- #endif
- template<typename T>
- inline void array_init_list(T* memory, std::size_t size, const T* list) {
- #if !defined(BOOST_NO_EXCEPTIONS)
- std::size_t i = 0;
- try {
- for (; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(list[i]);
- }
- } catch (...) {
- array_destroy(memory, i);
- throw;
- }
- #else
- for (std::size_t i = 0; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(list[i]);
- }
- #endif
- }
- template<typename T, std::size_t N>
- inline void array_init_list(T* memory, std::size_t size, const T* list) {
- #if !defined(BOOST_NO_EXCEPTIONS)
- std::size_t i = 0;
- try {
- for (; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(list[i % N]);
- }
- } catch (...) {
- array_destroy(memory, i);
- throw;
- }
- #else
- for (std::size_t i = 0; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T(list[i % N]);
- }
- #endif
- }
- template<typename T>
- inline void array_noinit(T*, std::size_t, boost::true_type) {
- }
- template<typename T>
- inline void array_noinit(T* memory, std::size_t size, boost::false_type) {
- #if !defined(BOOST_NO_EXCEPTIONS)
- std::size_t i = 0;
- try {
- for (; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T;
- }
- } catch (...) {
- array_destroy(memory, i);
- throw;
- }
- #else
- for (std::size_t i = 0; i < size; i++) {
- void* p1 = memory + i;
- ::new(p1) T;
- }
- #endif
- }
- template<typename T>
- inline void array_noinit(T* memory, std::size_t size) {
- boost::has_trivial_default_constructor<T> type;
- array_noinit(memory, size, type);
- }
- }
- }
- #endif
|