1*38fd1498Szrj // <bits/enable_special_members.h> -*- C++ -*-
2*38fd1498Szrj
3*38fd1498Szrj // Copyright (C) 2013-2018 Free Software Foundation, Inc.
4*38fd1498Szrj //
5*38fd1498Szrj // This file is part of the GNU ISO C++ Library. This library is free
6*38fd1498Szrj // software; you can redistribute it and/or modify it under the
7*38fd1498Szrj // terms of the GNU General Public License as published by the
8*38fd1498Szrj // Free Software Foundation; either version 3, or (at your option)
9*38fd1498Szrj // any later version.
10*38fd1498Szrj
11*38fd1498Szrj // This library is distributed in the hope that it will be useful,
12*38fd1498Szrj // but WITHOUT ANY WARRANTY; without even the implied warranty of
13*38fd1498Szrj // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14*38fd1498Szrj // GNU General Public License for more details.
15*38fd1498Szrj
16*38fd1498Szrj // Under Section 7 of GPL version 3, you are granted additional
17*38fd1498Szrj // permissions described in the GCC Runtime Library Exception, version
18*38fd1498Szrj // 3.1, as published by the Free Software Foundation.
19*38fd1498Szrj
20*38fd1498Szrj // You should have received a copy of the GNU General Public License and
21*38fd1498Szrj // a copy of the GCC Runtime Library Exception along with this program;
22*38fd1498Szrj // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23*38fd1498Szrj // <http://www.gnu.org/licenses/>.
24*38fd1498Szrj
25*38fd1498Szrj /** @file bits/enable_special_members.h
26*38fd1498Szrj * This is an internal header file, included by other library headers.
27*38fd1498Szrj * Do not attempt to use it directly.
28*38fd1498Szrj */
29*38fd1498Szrj
30*38fd1498Szrj #ifndef _ENABLE_SPECIAL_MEMBERS_H
31*38fd1498Szrj #define _ENABLE_SPECIAL_MEMBERS_H 1
32*38fd1498Szrj
33*38fd1498Szrj #pragma GCC system_header
34*38fd1498Szrj
_GLIBCXX_VISIBILITY(default)35*38fd1498Szrj namespace std _GLIBCXX_VISIBILITY(default)
36*38fd1498Szrj {
37*38fd1498Szrj _GLIBCXX_BEGIN_NAMESPACE_VERSION
38*38fd1498Szrj
39*38fd1498Szrj struct _Enable_default_constructor_tag
40*38fd1498Szrj {
41*38fd1498Szrj explicit constexpr _Enable_default_constructor_tag() = default;
42*38fd1498Szrj };
43*38fd1498Szrj
44*38fd1498Szrj /**
45*38fd1498Szrj * @brief A mixin helper to conditionally enable or disable the default
46*38fd1498Szrj * constructor.
47*38fd1498Szrj * @sa _Enable_special_members
48*38fd1498Szrj */
49*38fd1498Szrj template<bool _Switch, typename _Tag = void>
50*38fd1498Szrj struct _Enable_default_constructor
51*38fd1498Szrj {
52*38fd1498Szrj constexpr _Enable_default_constructor() noexcept = default;
53*38fd1498Szrj constexpr _Enable_default_constructor(_Enable_default_constructor const&)
54*38fd1498Szrj noexcept = default;
55*38fd1498Szrj constexpr _Enable_default_constructor(_Enable_default_constructor&&)
56*38fd1498Szrj noexcept = default;
57*38fd1498Szrj _Enable_default_constructor&
58*38fd1498Szrj operator=(_Enable_default_constructor const&) noexcept = default;
59*38fd1498Szrj _Enable_default_constructor&
60*38fd1498Szrj operator=(_Enable_default_constructor&&) noexcept = default;
61*38fd1498Szrj
62*38fd1498Szrj // Can be used in other ctors.
63*38fd1498Szrj constexpr explicit
64*38fd1498Szrj _Enable_default_constructor(_Enable_default_constructor_tag) { }
65*38fd1498Szrj };
66*38fd1498Szrj
67*38fd1498Szrj
68*38fd1498Szrj /**
69*38fd1498Szrj * @brief A mixin helper to conditionally enable or disable the default
70*38fd1498Szrj * destructor.
71*38fd1498Szrj * @sa _Enable_special_members
72*38fd1498Szrj */
73*38fd1498Szrj template<bool _Switch, typename _Tag = void>
74*38fd1498Szrj struct _Enable_destructor { };
75*38fd1498Szrj
76*38fd1498Szrj /**
77*38fd1498Szrj * @brief A mixin helper to conditionally enable or disable the copy/move
78*38fd1498Szrj * special members.
79*38fd1498Szrj * @sa _Enable_special_members
80*38fd1498Szrj */
81*38fd1498Szrj template<bool _Copy, bool _CopyAssignment,
82*38fd1498Szrj bool _Move, bool _MoveAssignment,
83*38fd1498Szrj typename _Tag = void>
84*38fd1498Szrj struct _Enable_copy_move { };
85*38fd1498Szrj
86*38fd1498Szrj /**
87*38fd1498Szrj * @brief A mixin helper to conditionally enable or disable the special
88*38fd1498Szrj * members.
89*38fd1498Szrj *
90*38fd1498Szrj * The @c _Tag type parameter is to make mixin bases unique and thus avoid
91*38fd1498Szrj * ambiguities.
92*38fd1498Szrj */
93*38fd1498Szrj template<bool _Default, bool _Destructor,
94*38fd1498Szrj bool _Copy, bool _CopyAssignment,
95*38fd1498Szrj bool _Move, bool _MoveAssignment,
96*38fd1498Szrj typename _Tag = void>
97*38fd1498Szrj struct _Enable_special_members
98*38fd1498Szrj : private _Enable_default_constructor<_Default, _Tag>,
99*38fd1498Szrj private _Enable_destructor<_Destructor, _Tag>,
100*38fd1498Szrj private _Enable_copy_move<_Copy, _CopyAssignment,
101*38fd1498Szrj _Move, _MoveAssignment,
102*38fd1498Szrj _Tag>
103*38fd1498Szrj { };
104*38fd1498Szrj
105*38fd1498Szrj // Boilerplate follows.
106*38fd1498Szrj
107*38fd1498Szrj template<typename _Tag>
108*38fd1498Szrj struct _Enable_default_constructor<false, _Tag>
109*38fd1498Szrj {
110*38fd1498Szrj constexpr _Enable_default_constructor() noexcept = delete;
111*38fd1498Szrj constexpr _Enable_default_constructor(_Enable_default_constructor const&)
112*38fd1498Szrj noexcept = default;
113*38fd1498Szrj constexpr _Enable_default_constructor(_Enable_default_constructor&&)
114*38fd1498Szrj noexcept = default;
115*38fd1498Szrj _Enable_default_constructor&
116*38fd1498Szrj operator=(_Enable_default_constructor const&) noexcept = default;
117*38fd1498Szrj _Enable_default_constructor&
118*38fd1498Szrj operator=(_Enable_default_constructor&&) noexcept = default;
119*38fd1498Szrj
120*38fd1498Szrj // Can be used in other ctors.
121*38fd1498Szrj constexpr explicit
122*38fd1498Szrj _Enable_default_constructor(_Enable_default_constructor_tag) { }
123*38fd1498Szrj };
124*38fd1498Szrj
125*38fd1498Szrj template<typename _Tag>
126*38fd1498Szrj struct _Enable_destructor<false, _Tag>
127*38fd1498Szrj { ~_Enable_destructor() noexcept = delete; };
128*38fd1498Szrj
129*38fd1498Szrj template<typename _Tag>
130*38fd1498Szrj struct _Enable_copy_move<false, true, true, true, _Tag>
131*38fd1498Szrj {
132*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
133*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
134*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = default;
135*38fd1498Szrj _Enable_copy_move&
136*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = default;
137*38fd1498Szrj _Enable_copy_move&
138*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = default;
139*38fd1498Szrj };
140*38fd1498Szrj
141*38fd1498Szrj template<typename _Tag>
142*38fd1498Szrj struct _Enable_copy_move<true, false, true, true, _Tag>
143*38fd1498Szrj {
144*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
145*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = default;
146*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = default;
147*38fd1498Szrj _Enable_copy_move&
148*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
149*38fd1498Szrj _Enable_copy_move&
150*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = default;
151*38fd1498Szrj };
152*38fd1498Szrj
153*38fd1498Szrj template<typename _Tag>
154*38fd1498Szrj struct _Enable_copy_move<false, false, true, true, _Tag>
155*38fd1498Szrj {
156*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
157*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
158*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = default;
159*38fd1498Szrj _Enable_copy_move&
160*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
161*38fd1498Szrj _Enable_copy_move&
162*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = default;
163*38fd1498Szrj };
164*38fd1498Szrj
165*38fd1498Szrj template<typename _Tag>
166*38fd1498Szrj struct _Enable_copy_move<true, true, false, true, _Tag>
167*38fd1498Szrj {
168*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
169*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = default;
170*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
171*38fd1498Szrj _Enable_copy_move&
172*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = default;
173*38fd1498Szrj _Enable_copy_move&
174*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = default;
175*38fd1498Szrj };
176*38fd1498Szrj
177*38fd1498Szrj template<typename _Tag>
178*38fd1498Szrj struct _Enable_copy_move<false, true, false, true, _Tag>
179*38fd1498Szrj {
180*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
181*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
182*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
183*38fd1498Szrj _Enable_copy_move&
184*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = default;
185*38fd1498Szrj _Enable_copy_move&
186*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = default;
187*38fd1498Szrj };
188*38fd1498Szrj
189*38fd1498Szrj template<typename _Tag>
190*38fd1498Szrj struct _Enable_copy_move<true, false, false, true, _Tag>
191*38fd1498Szrj {
192*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
193*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = default;
194*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
195*38fd1498Szrj _Enable_copy_move&
196*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
197*38fd1498Szrj _Enable_copy_move&
198*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = default;
199*38fd1498Szrj };
200*38fd1498Szrj
201*38fd1498Szrj template<typename _Tag>
202*38fd1498Szrj struct _Enable_copy_move<false, false, false, true, _Tag>
203*38fd1498Szrj {
204*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
205*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
206*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
207*38fd1498Szrj _Enable_copy_move&
208*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
209*38fd1498Szrj _Enable_copy_move&
210*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = default;
211*38fd1498Szrj };
212*38fd1498Szrj
213*38fd1498Szrj template<typename _Tag>
214*38fd1498Szrj struct _Enable_copy_move<true, true, true, false, _Tag>
215*38fd1498Szrj {
216*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
217*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = default;
218*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = default;
219*38fd1498Szrj _Enable_copy_move&
220*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = default;
221*38fd1498Szrj _Enable_copy_move&
222*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
223*38fd1498Szrj };
224*38fd1498Szrj
225*38fd1498Szrj template<typename _Tag>
226*38fd1498Szrj struct _Enable_copy_move<false, true, true, false, _Tag>
227*38fd1498Szrj {
228*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
229*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
230*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = default;
231*38fd1498Szrj _Enable_copy_move&
232*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = default;
233*38fd1498Szrj _Enable_copy_move&
234*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
235*38fd1498Szrj };
236*38fd1498Szrj
237*38fd1498Szrj template<typename _Tag>
238*38fd1498Szrj struct _Enable_copy_move<true, false, true, false, _Tag>
239*38fd1498Szrj {
240*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
241*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = default;
242*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = default;
243*38fd1498Szrj _Enable_copy_move&
244*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
245*38fd1498Szrj _Enable_copy_move&
246*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
247*38fd1498Szrj };
248*38fd1498Szrj
249*38fd1498Szrj template<typename _Tag>
250*38fd1498Szrj struct _Enable_copy_move<false, false, true, false, _Tag>
251*38fd1498Szrj {
252*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
253*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
254*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = default;
255*38fd1498Szrj _Enable_copy_move&
256*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
257*38fd1498Szrj _Enable_copy_move&
258*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
259*38fd1498Szrj };
260*38fd1498Szrj
261*38fd1498Szrj template<typename _Tag>
262*38fd1498Szrj struct _Enable_copy_move<true, true, false, false, _Tag>
263*38fd1498Szrj {
264*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
265*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = default;
266*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
267*38fd1498Szrj _Enable_copy_move&
268*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = default;
269*38fd1498Szrj _Enable_copy_move&
270*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
271*38fd1498Szrj };
272*38fd1498Szrj
273*38fd1498Szrj template<typename _Tag>
274*38fd1498Szrj struct _Enable_copy_move<false, true, false, false, _Tag>
275*38fd1498Szrj {
276*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
277*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
278*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
279*38fd1498Szrj _Enable_copy_move&
280*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = default;
281*38fd1498Szrj _Enable_copy_move&
282*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
283*38fd1498Szrj };
284*38fd1498Szrj
285*38fd1498Szrj template<typename _Tag>
286*38fd1498Szrj struct _Enable_copy_move<true, false, false, false, _Tag>
287*38fd1498Szrj {
288*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
289*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = default;
290*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
291*38fd1498Szrj _Enable_copy_move&
292*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
293*38fd1498Szrj _Enable_copy_move&
294*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
295*38fd1498Szrj };
296*38fd1498Szrj
297*38fd1498Szrj template<typename _Tag>
298*38fd1498Szrj struct _Enable_copy_move<false, false, false, false, _Tag>
299*38fd1498Szrj {
300*38fd1498Szrj constexpr _Enable_copy_move() noexcept = default;
301*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move const&) noexcept = delete;
302*38fd1498Szrj constexpr _Enable_copy_move(_Enable_copy_move&&) noexcept = delete;
303*38fd1498Szrj _Enable_copy_move&
304*38fd1498Szrj operator=(_Enable_copy_move const&) noexcept = delete;
305*38fd1498Szrj _Enable_copy_move&
306*38fd1498Szrj operator=(_Enable_copy_move&&) noexcept = delete;
307*38fd1498Szrj };
308*38fd1498Szrj
309*38fd1498Szrj _GLIBCXX_END_NAMESPACE_VERSION
310*38fd1498Szrj } // namespace std
311*38fd1498Szrj
312*38fd1498Szrj #endif // _ENABLE_SPECIAL_MEMBERS_H
313