Line data Source code
1 : //* This file is part of the MOOSE framework 2 : //* https://mooseframework.inl.gov 3 : //* 4 : //* All rights reserved, see COPYRIGHT for full restrictions 5 : //* https://github.com/idaholab/moose/blob/master/COPYRIGHT 6 : //* 7 : //* Licensed under LGPL 2.1, please see LICENSE for details 8 : //* https://www.gnu.org/licenses/lgpl-2.1.html 9 : 10 : #include "PerfGraphInterface.h" 11 : #include "PerfGraphRegistry.h" 12 : 13 : #include "MooseApp.h" 14 : 15 : InputParameters 16 439496 : PerfGraphInterface::validParams() 17 : { 18 439496 : InputParameters params = emptyInputParameters(); 19 439496 : return params; 20 : } 21 : 22 871615 : PerfGraphInterface::PerfGraphInterface(const MooseObject * moose_object) 23 871615 : : _pg_moose_app(*moose_object->parameters().getCheckedPointerParam<MooseApp *>( 24 : "_moose_app", "PerfGraphInterface is unable to retrieve the MooseApp pointer!")), 25 1743230 : _prefix(moose_object->type()) 26 : { 27 871615 : } 28 : 29 23357 : PerfGraphInterface::PerfGraphInterface(const MooseObject * moose_object, const std::string prefix) 30 23357 : : _pg_moose_app(*moose_object->parameters().getCheckedPointerParam<MooseApp *>( 31 : "_moose_app", "PerfGraphInterface is unable to retrieve the MooseApp pointer!")), 32 46714 : _prefix(prefix) 33 : { 34 23357 : } 35 : 36 135220 : PerfGraphInterface::PerfGraphInterface(MooseApp & moose_app, const std::string prefix) 37 135220 : : _pg_moose_app(moose_app), _prefix(prefix) 38 : { 39 135220 : } 40 : 41 3701806 : PerfGraphInterface::PerfGraphInterface(PerfGraph & perf_graph, const std::string prefix) 42 3701806 : : _pg_moose_app(perf_graph.mooseApp()), _prefix(prefix) 43 : { 44 3701806 : } 45 : 46 : std::string 47 101427103 : PerfGraphInterface::timedSectionName(const std::string & section_name) const 48 : { 49 202854206 : return _prefix.empty() ? "" : (_prefix + "::") + section_name; 50 : } 51 : 52 : PerfID 53 61419577 : PerfGraphInterface::registerTimedSection(const std::string & section_name, 54 : const unsigned int level) const 55 : { 56 61419577 : const auto timed_section_name = timedSectionName(section_name); 57 61419577 : if (!moose::internal::getPerfGraphRegistry().sectionExists(timed_section_name)) 58 3981031 : return moose::internal::getPerfGraphRegistry().registerSection(timed_section_name, level); 59 : else 60 57438546 : return moose::internal::getPerfGraphRegistry().sectionID(timed_section_name); 61 61419577 : } 62 : 63 : PerfID 64 37024054 : PerfGraphInterface::registerTimedSection(const std::string & section_name, 65 : const unsigned int level, 66 : const std::string & live_message, 67 : const bool print_dots) const 68 : { 69 37024054 : const auto timed_section_name = timedSectionName(section_name); 70 37024054 : if (!moose::internal::getPerfGraphRegistry().sectionExists(timed_section_name)) 71 5966944 : return moose::internal::getPerfGraphRegistry().registerSection( 72 5966944 : timedSectionName(section_name), level, live_message, print_dots); 73 : else 74 34040582 : return moose::internal::getPerfGraphRegistry().sectionID(timed_section_name); 75 37024054 : } 76 : 77 : PerfGraph & 78 186522 : PerfGraphInterface::perfGraph() 79 : { 80 186522 : return _pg_moose_app.perfGraph(); 81 : }