Imported Upstream version 1.72.0
[platform/upstream/boost.git] / boost / multiprecision / traits / is_backend.hpp
index 2a26b19..5e3f3ec 100644 (file)
 #include <boost/type_traits/is_convertible.hpp>
 #include <boost/multiprecision/detail/number_base.hpp>
 
-namespace boost{ namespace multiprecision{  namespace detail{
-
-   BOOST_MPL_HAS_XXX_TRAIT_DEF(signed_types)
-   BOOST_MPL_HAS_XXX_TRAIT_DEF(unsigned_types)
-   BOOST_MPL_HAS_XXX_TRAIT_DEF(float_types)
-
-   template <class T>
-   struct is_backend
-   {
-      static const bool value = has_signed_types<T>::value && has_unsigned_types<T>::value && has_float_types<T>::value;
-   };
-
-   template <class Backend>
-   struct other_backend
-   {
-      typedef typename boost::conditional<
-         boost::is_same<number<Backend>, number<Backend, et_on> >::value,
-         number<Backend, et_off>, number<Backend, et_on> >::type type;
-   };
-
-   template <class B, class V>
-   struct number_from_backend
-   {
-      typedef typename boost::conditional <
-         boost::is_convertible<V, number<B> >::value,
-         number<B>,
-         typename other_backend<B>::type > ::type type;
-   };
-
-   template <bool b, class T, class U>
-   struct is_first_backend_imp{ static const bool value = false; };
-   template <class T, class U>
-   struct is_first_backend_imp<true, T, U>{ static const bool value = is_convertible<U, number<T, et_on> >::value || is_convertible<U, number<T, et_off> >::value; };
-
-   template <class T, class U>
-   struct is_first_backend : is_first_backend_imp<is_backend<T>::value, T, U> {};
-
-   template <bool b, class T, class U>
-   struct is_second_backend_imp{ static const bool value = false; };
-   template <class T, class U>
-   struct is_second_backend_imp<true, T, U>{ static const bool value = (is_convertible<T, number<U, et_on> >::value || is_convertible<T, number<U, et_off> >::value) && !is_first_backend<T, U>::value; };
-
-   template <class T, class U>
-   struct is_second_backend : is_second_backend_imp<is_backend<U>::value, T, U> {};
+namespace boost { namespace multiprecision { namespace detail {
+
+BOOST_MPL_HAS_XXX_TRAIT_DEF(signed_types)
+BOOST_MPL_HAS_XXX_TRAIT_DEF(unsigned_types)
+BOOST_MPL_HAS_XXX_TRAIT_DEF(float_types)
+
+template <class T>
+struct is_backend
+{
+   static const bool value = has_signed_types<T>::value && has_unsigned_types<T>::value && has_float_types<T>::value;
+};
+
+template <class Backend>
+struct other_backend
+{
+   typedef typename boost::conditional<
+       boost::is_same<number<Backend>, number<Backend, et_on> >::value,
+       number<Backend, et_off>, number<Backend, et_on> >::type type;
+};
+
+template <class B, class V>
+struct number_from_backend
+{
+   typedef typename boost::conditional<
+       boost::is_convertible<V, number<B> >::value,
+       number<B>,
+       typename other_backend<B>::type>::type type;
+};
+
+template <bool b, class T, class U>
+struct is_first_backend_imp
+{
+   static const bool value = false;
+};
+template <class T, class U>
+struct is_first_backend_imp<true, T, U>
+{
+   static const bool value = is_convertible<U, number<T, et_on> >::value || is_convertible<U, number<T, et_off> >::value;
+};
+
+template <class T, class U>
+struct is_first_backend : is_first_backend_imp<is_backend<T>::value, T, U>
+{};
+
+template <bool b, class T, class U>
+struct is_second_backend_imp
+{
+   static const bool value = false;
+};
+template <class T, class U>
+struct is_second_backend_imp<true, T, U>
+{
+   static const bool value = (is_convertible<T, number<U, et_on> >::value || is_convertible<T, number<U, et_off> >::value) && !is_first_backend<T, U>::value;
+};
+
+template <class T, class U>
+struct is_second_backend : is_second_backend_imp<is_backend<U>::value, T, U>
+{};
 
 }
 }
-}
+} // namespace boost::multiprecision::detail
 
 #endif // BOOST_MP_IS_BACKEND_HPP