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