ttg 1.0.0
Template Task Graph (TTG): flowgraph-based programming model for high-performance distributed-memory algorithms
Loading...
Searching...
No Matches
add_transaction_safe.hpp
Go to the documentation of this file.
1/*
2@file add_transaction_safe
3
4@Copyright Barrett Adair 2015-2017
5Distributed under the Boost Software License, Version 1.0.
6(See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt)
7
8*/
9
10#ifndef BOOST_CLBL_TRTS_ADD_TRANSACTION_SAFE_HPP
11#define BOOST_CLBL_TRTS_ADD_TRANSACTION_SAFE_HPP
12
14
15namespace boost { namespace callable_traits {
16
18BOOST_CLBL_TRTS_SFINAE_MSG(add_transaction_safe, cannot_add_transaction_safe_to_this_type)
19
20#ifndef BOOST_CLBL_TRTS_ENABLE_TRANSACTION_SAFE
21template<typename T>
23 static_assert(std::is_same<T, detail::dummy>::value,
24 "transaction_safe not supported by this configuration.");
25};
26
27template<typename T>
29 static_assert(std::is_same<T, detail::dummy>::value,
30 "transaction_safe not supported by this configuration.");
31};
32
33#else
34
35//[ add_transaction_safe_hpp
36/*`
37[section:ref_add_transaction_safe add_transaction_safe]
38[heading Header]
39``#include <boost/callable_traits/add_transaction_safe.hpp>``
40[heading Definition]
41*/
42
43
44template<typename T>
45using add_transaction_safe_t = //see below
46//<-
49 cannot_add_transaction_safe_to_this_type>;
50
51namespace detail {
52
53 template<typename T, typename = std::false_type>
54 struct add_transaction_safe_impl {};
55
56 template<typename T>
57 struct add_transaction_safe_impl <T, typename std::is_same<
58 add_transaction_safe_t<T>, detail::dummy>::type>
59 {
60 using type = add_transaction_safe_t<T>;
61 };
62}
63//->
64
65template<typename T>
66struct add_transaction_safe
67 : detail::add_transaction_safe_impl<T> {};
68
69//<-
70#endif // #ifndef BOOST_CLBL_TRTS_ENABLE_TRANSACTION_SAFE
71}} // namespace boost::callable_traits
72//->
73
74/*`
75[heading Constraints]
76* `T` must be one of the following:
77 * function type
78 * function pointer type
79 * function reference type
80 * member function pointer type
81* If `T` is a pointer, it may not be cv/ref qualified
82
83[heading Behavior]
84* A substitution failure occurs if the constraints are violated.
85* Adds the `transaction_safe` specifier to `T`, if not already present.
86
87[heading Input/Output Examples]
88[table
89 [[`T`] [`add_transaction_safe_t<T>`]]
90 [[`int()`] [`int() transaction_safe`]]
91 [[`int (&)()`] [`int(&)() transaction_safe`]]
92 [[`int (*)()`] [`int(*)() transaction_safe`]]
93 [[`int(foo::*)()`] [`int(foo::*)() transaction_safe`]]
94 [[`int(foo::*)() &`] [`int(foo::*)() & transaction_safe`]]
95 [[`int(foo::*)() &&`] [`int(foo::*)() && transaction_safe`]]
96 [[`int(foo::*)() const`] [`int(foo::*)() const transaction_safe`]]
97 [[`int(foo::*)() transaction_safe`] [`int(foo::*)() transaction_safe`]]
98 [[`int`] [(substitution failure)]]
99 [[`int foo::*`] [(substitution failure)]]
100 [[`int (*&)()`] [(substitution failure)]]
101]
102
103[heading Example Program]
104[import ../example/add_transaction_safe.cpp]
105[add_transaction_safe]
106[endsect]
107*/
108//]
109
110#endif // #ifndef BOOST_CLBL_TRTS_ADD_TRANSACTION_SAFE_HPP
sfinae_try< T, fail_when_same< U, invalid_type, ErrorType >, fail_when_same< U, reference_error, reference_type_not_supported_by_this_metafunction > > try_but_fail_if_invalid
Definition utility.hpp:58
typename BOOST_CLBL_TRTS_DISJUNCTION(function_object< unwrap_reference< T > >, function< T >, pmf< T >, pmd< T >, default_callable_traits< T >)::traits traits
Definition traits.hpp:25
STL namespace.
#define BOOST_CLBL_TRTS_SFINAE_MSG(origin, name)
#define BOOST_CLBL_TRTS_DEFINE_SFINAE_ERROR_ORIGIN(origin)