New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
aligned_storage.hpp in vendors/XIOS/current/extern/boost/include/boost – NEMO

source: vendors/XIOS/current/extern/boost/include/boost/aligned_storage.hpp @ 3428

Last change on this file since 3428 was 3428, checked in by rblod, 12 years ago

importing initial XIOS vendor drop

File size: 4.2 KB
Line 
1//-----------------------------------------------------------------------------
2// boost aligned_storage.hpp header file
3// See http://www.boost.org for updates, documentation, and revision history.
4//-----------------------------------------------------------------------------
5//
6// Copyright (c) 2002-2003
7// Eric Friedman, Itay Maman
8//
9// Distributed under the Boost Software License, Version 1.0. (See
10// accompanying file LICENSE_1_0.txt or copy at
11// http://www.boost.org/LICENSE_1_0.txt)
12
13#ifndef BOOST_ALIGNED_STORAGE_HPP
14#define BOOST_ALIGNED_STORAGE_HPP
15
16#include <cstddef> // for std::size_t
17
18#include "boost/config.hpp"
19#include "boost/detail/workaround.hpp"
20#include "boost/type_traits/alignment_of.hpp"
21#include "boost/type_traits/type_with_alignment.hpp"
22#include "boost/type_traits/is_pod.hpp"
23
24#include "boost/mpl/eval_if.hpp"
25#include "boost/mpl/identity.hpp"
26
27#include "boost/type_traits/detail/bool_trait_def.hpp"
28
29namespace boost {
30
31namespace detail { namespace aligned_storage {
32
33BOOST_STATIC_CONSTANT(
34      std::size_t
35    , alignment_of_max_align = ::boost::alignment_of<max_align>::value
36    );
37
38//
39// To be TR1 conforming this must be a POD type:
40//
41template <
42      std::size_t size_
43    , std::size_t alignment_
44>
45struct aligned_storage_imp
46{
47    union data_t
48    {
49        char buf[size_];
50
51        typename mpl::eval_if_c<
52              alignment_ == std::size_t(-1)
53            , mpl::identity<detail::max_align>
54            , type_with_alignment<alignment_>
55            >::type align_;
56    } data_;
57    void* address() const { return const_cast<aligned_storage_imp*>(this); }
58};
59
60template< std::size_t alignment_ >
61struct aligned_storage_imp<0u,alignment_>
62{
63    /* intentionally empty */
64    void* address() const { return 0; }
65};
66
67}} // namespace detail::aligned_storage
68
69template <
70      std::size_t size_
71    , std::size_t alignment_ = std::size_t(-1)
72>
73class aligned_storage : 
74#ifndef __BORLANDC__
75   private 
76#else
77   public
78#endif
79   detail::aligned_storage::aligned_storage_imp<size_, alignment_> 
80{
81 
82public: // constants
83
84    typedef detail::aligned_storage::aligned_storage_imp<size_, alignment_> type;
85
86    BOOST_STATIC_CONSTANT(
87          std::size_t
88        , size = size_
89        );
90    BOOST_STATIC_CONSTANT(
91          std::size_t
92        , alignment = (
93              alignment_ == std::size_t(-1)
94            ? ::boost::detail::aligned_storage::alignment_of_max_align
95            : alignment_
96            )
97        );
98
99#if defined(__GNUC__) &&\
100    (__GNUC__ >  3) ||\
101    (__GNUC__ == 3 && (__GNUC_MINOR__ >  2 ||\
102                      (__GNUC_MINOR__ == 2 && __GNUC_PATCHLEVEL__ >=3)))
103
104private: // noncopyable
105
106    aligned_storage(const aligned_storage&);
107    aligned_storage& operator=(const aligned_storage&);
108
109#else // gcc less than 3.2.3
110
111public: // _should_ be noncopyable, but GCC compiler emits error
112
113    aligned_storage(const aligned_storage&);
114    aligned_storage& operator=(const aligned_storage&);
115
116#endif // gcc < 3.2.3 workaround
117
118public: // structors
119
120    aligned_storage()
121    {
122    }
123
124    ~aligned_storage()
125    {
126    }
127
128public: // accessors
129
130    void* address()
131    {
132        return static_cast<type*>(this)->address();
133    }
134
135#if !BOOST_WORKAROUND(BOOST_MSVC, < 1300)
136
137    const void* address() const
138    {
139        return static_cast<const type*>(this)->address();
140    }
141
142#else // MSVC6
143
144    const void* address() const;
145
146#endif // MSVC6 workaround
147
148};
149
150#if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
151
152// MSVC6 seems not to like inline functions with const void* returns, so we
153// declare the following here:
154
155template <std::size_t S, std::size_t A>
156const void* aligned_storage<S,A>::address() const
157{
158    return const_cast< aligned_storage<S,A>* >(this)->address();
159}
160
161#endif // MSVC6 workaround
162
163#ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
164//
165// Make sure that is_pod recognises aligned_storage<>::type
166// as a POD (Note that aligned_storage<> itself is not a POD):
167//
168template <std::size_t size_, std::size_t alignment_>
169struct is_pod<boost::detail::aligned_storage::aligned_storage_imp<size_,alignment_> >
170   BOOST_TT_AUX_BOOL_C_BASE(true)
171{ 
172    BOOST_TT_AUX_BOOL_TRAIT_VALUE_DECL(true)
173}; 
174#endif
175
176
177} // namespace boost
178
179#include "boost/type_traits/detail/bool_trait_undef.hpp"
180
181#endif // BOOST_ALIGNED_STORAGE_HPP
Note: See TracBrowser for help on using the repository browser.