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.
print_storage.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/print_storage.hpp
27 * \brief Definition for various functions for print_storage in operations
28 */
29
30#pragma once
31
35
36namespace tim
37{
38namespace operation
39{
40//
41//--------------------------------------------------------------------------------------//
42//
43///
44/// \struct tim::operation::print_storage
45/// \brief Print the storage for a component
46//
47//--------------------------------------------------------------------------------------//
48//
49template <typename Tp>
51{
52 using type = Tp;
53
54 TIMEMORY_COLD print_storage() { (*this)(); }
55
56 TIMEMORY_COLD void operator()() const { this->sfinae<type>(0); }
57
58private:
59 //----------------------------------------------------------------------------------//
60 // only if component is available
61 //
62 template <typename Up, typename Vp = typename Up::value_type,
64 TIMEMORY_COLD void sfinae(int) const
65 {
67 return;
68
69 auto _storage = storage<Tp, Vp>::noninit_instance();
70 if(_storage)
71 {
72 _storage->stack_clear();
73 _storage->print();
74 }
75 }
76
77 //----------------------------------------------------------------------------------//
78 // print nothing if component is not available
79 //
80 template <typename Up>
81 void sfinae(long) const
82 {}
83};
84//
85//--------------------------------------------------------------------------------------//
86//
87template <typename Tp>
89{
91 : print_storage<Tp>()
92 {}
93};
94//
95//--------------------------------------------------------------------------------------//
96//
97} // namespace operation
98} // namespace tim
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.
Include the macros for operations.
Declare the operations types.
Print the storage for a component.
trait that signifies that an implementation is enabled at runtime. The value returned from get() is f...