File: timetrace.h

package info (click to toggle)
ldc 1%3A1.30.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 59,248 kB
  • sloc: cpp: 61,598; ansic: 14,545; sh: 1,014; makefile: 972; asm: 510; objc: 135; exp: 48; python: 12
file content (62 lines) | stat: -rw-r--r-- 2,332 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
//===-- driver/timetrace.h --------------------------------------*- C++ -*-===//
//
//                         LDC – the LLVM D compiler
//
// This file is distributed under the BSD-style LDC license. See the LICENSE
// file for details.
//
//===----------------------------------------------------------------------===//
//
// Compilation time tracing, --ftime-trace.
// Main implementation is in D, this C++ source is for interfacing.
//
//===----------------------------------------------------------------------===//

#pragma once

#include "dmd/globals.h"
#include <functional>

// Forward declarations to functions implemented in D
void initializeTimeTrace(unsigned timeGranularity, unsigned memoryGranularity,
                         const char *processName);
void deinitializeTimeTrace();
void writeTimeTraceProfile(const char *filename_cstr);
void timeTraceProfilerBegin(const char *name_ptr, const char *detail_ptr, Loc loc);
void timeTraceProfilerEnd();
bool timeTraceProfilerEnabled();


/// RAII helper class to call the begin and end functions of the time trace
/// profiler.  When the object is constructed, it begins the section; and when
/// it is destroyed, it stops it.
/// The strings pointed to are copied (pointers are not stored).
struct TimeTraceScope {
  TimeTraceScope() = delete;
  TimeTraceScope(const TimeTraceScope &) = delete;
  TimeTraceScope &operator=(const TimeTraceScope &) = delete;
  TimeTraceScope(TimeTraceScope &&) = delete;
  TimeTraceScope &operator=(TimeTraceScope &&) = delete;

  TimeTraceScope(const char *name, Loc loc = Loc()) {
    if (timeTraceProfilerEnabled())
      timeTraceProfilerBegin(name, "", loc);
  }
  TimeTraceScope(const char *name, const char *detail, Loc loc = Loc()) {
    if (timeTraceProfilerEnabled())
      timeTraceProfilerBegin(name, detail, loc);
  }
  TimeTraceScope(const char *name, std::function<std::string()> detail, Loc loc = Loc()) {
    if (timeTraceProfilerEnabled())
      timeTraceProfilerBegin(name, detail().c_str(), loc);
  }
  TimeTraceScope(std::function<std::string()> name, std::function<std::string()> detail, Loc loc = Loc()) {
    if (timeTraceProfilerEnabled())
      timeTraceProfilerBegin(name().c_str(), detail().c_str(), loc);
  }

  ~TimeTraceScope() {
    if (timeTraceProfilerEnabled())
      timeTraceProfilerEnd();
  }
};