• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 
2 #ifndef BOOST_MPL_IF_HPP_INCLUDED
3 #define BOOST_MPL_IF_HPP_INCLUDED
4 
5 // Copyright Aleksey Gurtovoy 2000-2004
6 //
7 // Distributed under the Boost Software License, Version 1.0.
8 // (See accompanying file LICENSE_1_0.txt or copy at
9 // http://www.boost.org/LICENSE_1_0.txt)
10 //
11 // See http://www.boost.org/libs/mpl for documentation.
12 
13 // $Id$
14 // $Date$
15 // $Revision$
16 
17 #include <boost/mpl/aux_/value_wknd.hpp>
18 #include <boost/mpl/aux_/static_cast.hpp>
19 #include <boost/mpl/aux_/na_spec.hpp>
20 #include <boost/mpl/aux_/lambda_support.hpp>
21 #include <boost/mpl/aux_/config/integral.hpp>
22 #include <boost/mpl/aux_/config/ctps.hpp>
23 #include <boost/mpl/aux_/config/workaround.hpp>
24 
25 namespace boost { namespace mpl {
26 
27 #if !defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION)
28 
29 template<
30       bool C
31     , typename T1
32     , typename T2
33     >
34 struct if_c
35 {
36     typedef T1 type;
37 };
38 
39 template<
40       typename T1
41     , typename T2
42     >
43 struct if_c<false,T1,T2>
44 {
45     typedef T2 type;
46 };
47 
48 // agurt, 05/sep/04: nondescriptive parameter names for the sake of DigitalMars
49 // (and possibly MWCW < 8.0); see https://lists.boost.org/Archives/boost/2004/09/71383.php
50 template<
51       typename BOOST_MPL_AUX_NA_PARAM(T1)
52     , typename BOOST_MPL_AUX_NA_PARAM(T2)
53     , typename BOOST_MPL_AUX_NA_PARAM(T3)
54     >
55 struct if_
56 {
57  private:
58     // agurt, 02/jan/03: two-step 'type' definition for the sake of aCC
59     typedef if_c<
60 #if defined(BOOST_MPL_CFG_BCC_INTEGRAL_CONSTANTS)
61           BOOST_MPL_AUX_VALUE_WKND(T1)::value
62 #else
63           BOOST_MPL_AUX_STATIC_CAST(bool, BOOST_MPL_AUX_VALUE_WKND(T1)::value)
64 #endif
65         , T2
66         , T3
67         > almost_type_;
68 
69  public:
70     typedef typename almost_type_::type type;
71 
72     BOOST_MPL_AUX_LAMBDA_SUPPORT(3,if_,(T1,T2,T3))
73 };
74 
75 #else
76 
77 // no partial class template specialization
78 
79 namespace aux {
80 
81 template< bool C >
82 struct if_impl
83 {
84     template< typename T1, typename T2 > struct result_
85     {
86         typedef T1 type;
87     };
88 };
89 
90 template<>
91 struct if_impl<false>
92 {
93     template< typename T1, typename T2 > struct result_
94     {
95         typedef T2 type;
96     };
97 };
98 
99 } // namespace aux
100 
101 template<
102       bool C_
103     , typename T1
104     , typename T2
105     >
106 struct if_c
107 {
108     typedef typename aux::if_impl< C_ >
109         ::template result_<T1,T2>::type type;
110 };
111 
112 // (almost) copy & paste in order to save one more
113 // recursively nested template instantiation to user
114 template<
115       typename BOOST_MPL_AUX_NA_PARAM(C_)
116     , typename BOOST_MPL_AUX_NA_PARAM(T1)
117     , typename BOOST_MPL_AUX_NA_PARAM(T2)
118     >
119 struct if_
120 {
121     enum { msvc_wknd_ = BOOST_MPL_AUX_MSVC_VALUE_WKND(C_)::value };
122 
123     typedef typename aux::if_impl< BOOST_MPL_AUX_STATIC_CAST(bool, msvc_wknd_) >
124         ::template result_<T1,T2>::type type;
125 
126     BOOST_MPL_AUX_LAMBDA_SUPPORT(3,if_,(C_,T1,T2))
127 };
128 
129 #endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
130 
131 BOOST_MPL_AUX_NA_SPEC(3, if_)
132 
133 }}
134 
135 #endif // BOOST_MPL_IF_HPP_INCLUDED
136