trace.cpp
 1  #include "pch.h"
 2  #include "trace.h"
 3  
 4  #include <common/Telemetry/TraceBase.h>
 5  
 6  TRACELOGGING_DEFINE_PROVIDER(
 7      g_hProvider,
 8      "Microsoft.PowerToys",
 9      // {38e8889b-9731-53f5-e901-e8a7c1753074}
10      (0x38e8889b, 0x9731, 0x53f5, 0xe9, 0x01, 0xe8, 0xa7, 0xc1, 0x75, 0x30, 0x74),
11      TraceLoggingOptionProjectTelemetry());
12  
13  void Trace::SendGuideSession(const __int64 duration_ms, const wchar_t* close_type) noexcept
14  {
15      TraceLoggingWriteWrapper(
16          g_hProvider,
17          "ShortcutGuide_GuideSession",
18          TraceLoggingInt64(duration_ms, "DurationInMs"),
19          TraceLoggingWideString(close_type, "CloseType"),
20          ProjectTelemetryPrivacyDataTag(ProjectTelemetryTag_ProductAndServicePerformance),
21          TraceLoggingBoolean(TRUE, "UTCReplace_AppSessionGuid"),
22          TraceLoggingKeyword(PROJECT_KEYWORD_MEASURE));
23  }
24  
25  void Trace::SendSettings(ShortcutGuideSettings settings) noexcept
26  {
27      TraceLoggingWriteWrapper(
28          g_hProvider,
29          "ShortcutGuide_Settings",
30          TraceLoggingWideString(settings.hotkey.c_str(), "Hotkey"),
31          TraceLoggingInt32(settings.overlayOpacity, "OverlayOpacity"),
32          TraceLoggingWideString(settings.theme.c_str(), "Theme"),
33          TraceLoggingWideString(settings.disabledApps.c_str(), "DisabledApps"),
34          TraceLoggingBoolean(settings.shouldReactToPressedWinKey, "ShouldReactToPressedWinKey"),
35          TraceLoggingInt32(settings.windowsKeyPressTimeForGlobalWindowsShortcuts, "WindowsKeyPressTimeForGlobalWindowsShortcuts"),
36          TraceLoggingInt32(settings.windowsKeyPressTimeForTaskbarIconShortcuts, "WindowsKeyPressTimeForTaskbarIconShortcuts"),
37          ProjectTelemetryPrivacyDataTag(ProjectTelemetryTag_ProductAndServicePerformance),
38          TraceLoggingBoolean(TRUE, "UTCReplace_AppSessionGuid"),
39          TraceLoggingKeyword(PROJECT_KEYWORD_MEASURE));
40  }