timemory 3.3.0
Modular C++ Toolkit for Performance Analysis and Logging. Profiling API and Tools for C, C++, CUDA, Fortran, and Python. The C++ template API is essentially a framework to creating tools: it is designed to provide a unifying interface for recording various performance measurements alongside data logging and interfaces to other tools.
record.hpp
Go to the documentation of this file.
1// MIT License
2//
3// Copyright (c) 2020, The Regents of the University of California,
4// through Lawrence Berkeley National Laboratory (subject to receipt of any
5// required approvals from the U.S. Dept. of Energy). All rights reserved.
6//
7// Permission is hereby granted, free of charge, to any person obtaining a copy
8// of this software and associated documentation files (the "Software"), to deal
9// in the Software without restriction, including without limitation the rights
10// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11// copies of the Software, and to permit persons to whom the Software is
12// furnished to do so, subject to the following conditions:
13//
14// The above copyright notice and this permission notice shall be included in all
15// copies or substantial portions of the Software.
16//
17// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23// SOFTWARE.
24
25/**
26 * \file timemory/operations/types/record.hpp
27 * \brief Definition for various functions for record in operations
28 */
29
30#pragma once
31
35
36namespace tim
37{
38namespace operation
39{
40//
41//--------------------------------------------------------------------------------------//
42//
43//
44//
45//--------------------------------------------------------------------------------------//
46//
47template <typename Tp>
48struct record
49{
50 using type = Tp;
51
53
54 record(type& obj, const type& rhs);
55
56 template <typename T = type, typename... Args,
57 enable_if_t<check_record_type<T>::value, char> = 0>
58 explicit record(T& obj, Args&&... args);
59
60 template <typename T = type, typename... Args,
61 enable_if_t<!check_record_type<T>::value, char> = 0>
62 explicit record(T&, Args&&...);
63
64private:
65 // satisfies mpl condition and accepts arguments
66 template <typename Up, typename T, typename... Args,
67 typename Vp = typename Up::value_type,
68 enable_if_t<check_record_type<Up, Vp>::value, int> = 0>
69 auto sfinae(T& obj, int, int, Args&&... args)
70 -> decltype((std::declval<T&>().value = obj.record(std::forward<Args>(args)...)),
71 void())
72 {
73 obj.value = obj.record(std::forward<Args>(args)...);
74 }
75
76 // satisfies mpl condition but does not accept arguments
77 template <typename Up, typename T, typename... Args,
78 typename Vp = typename Up::value_type,
80 auto sfinae(T& obj, int, long, Args&&...)
81 -> decltype((std::declval<T&>().value = obj.record()), void())
82 {
83 obj.value = obj.record();
84 }
85
86 // satisfies mpl condition but does not accept arguments
87 template <typename Up, typename T, typename... Args,
88 typename Vp = typename Up::value_type,
90 auto sfinae(T&, long, long, Args&&...) -> decltype(void(), void())
91 {}
92
93 // no member function or does not satisfy mpl condition
94 template <typename Up, typename T, typename... Args>
95 void sfinae(T&, long, long, Args&&...)
96 {
98 }
99
100 // satisfies mpl condition but does not accept arguments
101 template <typename T>
102 auto sfinae(T& obj, const T& rhs, int, long) -> decltype(obj += rhs)
103 {
104 return obj += rhs;
105 }
106
107 // no member function or does not satisfy mpl condition
108 template <typename T>
109 void sfinae(T&, const T&, long, long)
110 {
112 }
113};
114//
115//--------------------------------------------------------------------------------------//
116//
117template <typename Tp>
118record<Tp>::record(type& obj, const type& rhs)
119{
120 sfinae(obj, rhs, 0, 0);
121}
122//
123//--------------------------------------------------------------------------------------//
124//
125template <typename Tp>
126template <typename T, typename... Args, enable_if_t<check_record_type<T>::value, char>>
127record<Tp>::record(T& obj, Args&&... args)
128{
129 sfinae<type>(obj, 0, 0, std::forward<Args>(args)...);
130}
131//
132//--------------------------------------------------------------------------------------//
133//
134template <typename Tp>
135template <typename T, typename... Args, enable_if_t<!check_record_type<T>::value, char>>
136record<Tp>::record(T&, Args&&...)
137{}
138//
139//--------------------------------------------------------------------------------------//
140//
141} // namespace operation
142} // namespace tim
STL namespace.
Definition: kokkosp.cpp:39
typename std::enable_if< B, T >::type enable_if_t
Alias template for enable_if.
Definition: types.hpp:190
The declaration for the types for operations without definitions.
#define SFINAE_WARNING(...)
Definition: declaration.hpp:70
Include the macros for operations.
Declare the operations types.
static constexpr bool value
Definition: types.hpp:199
record(T &obj, Args &&... args)
Definition: record.hpp:127
TIMEMORY_DELETED_OBJECT(record) record(type &obj
const type & rhs
Definition: record.hpp:54
typename typename typename
Definition: types.hpp:226