Arcane  4.1.12.0
Developer documentation
Loading...
Searching...
No Matches
ItemEnumeratorTracer.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2026 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* ItemEnumeratorTracer.h (C) 2000-2022 */
9/* */
10/* Traces calls to enumerators on entities. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_IMPL_ITEMENUMERATORTRACER_H
13#define ARCANE_IMPL_ITEMENUMERATORTRACER_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/utils/TraceAccessor.h"
18#include "arcane/utils/Ref.h"
19#include "arcane/utils/IPerformanceCounterService.h"
20
21/*---------------------------------------------------------------------------*/
22/*---------------------------------------------------------------------------*/
23
24namespace Arcane
25{
26
27/*---------------------------------------------------------------------------*/
28/*---------------------------------------------------------------------------*/
29
33class ARCANE_IMPL_EXPORT ItemEnumeratorTracer
34: public TraceAccessor
36{
37 public:
38
39 ItemEnumeratorTracer(ITraceMng* tm, Ref<IPerformanceCounterService> perf_counter);
40
41 public:
42
43 virtual ~ItemEnumeratorTracer();
44
45 public:
46
47 void enterEnumerator(const ItemEnumerator& e, EnumeratorTraceInfo& eti) override;
48 void exitEnumerator(const ItemEnumerator& e, EnumeratorTraceInfo& eti) override;
50 void exitEnumerator(const SimdItemEnumeratorBase& e, EnumeratorTraceInfo& eti) override;
51
52 public:
53
54 void dumpStats() override;
55 IPerformanceCounterService* perfCounter() override { return m_perf_counter.get(); }
56 Ref<IPerformanceCounterService> perfCounterRef() override { return m_perf_counter; }
57
58 private:
59
60 Int64 m_nb_call = 0;
61 Int64 m_nb_loop = 0;
63 bool m_is_verbose = false;
64
65 private:
66
67 void _beginLoop(EnumeratorTraceInfo& eti);
68 void _endLoop(EnumeratorTraceInfo& eti);
69};
70
71/*---------------------------------------------------------------------------*/
72/*---------------------------------------------------------------------------*/
73
74} // namespace Arcane
75
76/*---------------------------------------------------------------------------*/
77/*---------------------------------------------------------------------------*/
78
79#endif
Information for an enumerator's traces.
Interface for an enumerator tracer on entities.
Interface of a service for accessing performance counters.
void exitEnumerator(const ItemEnumerator &e, EnumeratorTraceInfo &eti) override
Method called after executing an ENUMERATE_.
void enterEnumerator(const ItemEnumerator &e, EnumeratorTraceInfo &eti) override
Method called before executing an ENUMERATE_.
Enumerator over a list of entities.
Reference to an instance.
Base class for enumerators over vectorial entities (SimdItem).
Definition SimdItem.h:433
TraceAccessor(ITraceMng *m)
Constructs an accessor via the trace manager m.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
std::int64_t Int64
Signed integer type of 64 bits.