从用户模式应用程序使用 WPP

Ghi*_*ita 2 c++ logging etw visual-studio

我尝试在用户模式下使用 WPP,在 VS10 中成功使用它,通过添加到 proj 文件来发布目标:

    <PropertyGroup><WdkDir>c:\work\Proj\wppTest\DDK\</WdkDir><MyTargetsDir>c:\work\Proj\wppTest</MyTargetsDir>  </PropertyGroup>

...

  <ImportGroup Label="ExtensionTargets">
    <Import Project="$(MyTargetsDir)\Wpp.targets" />
  </ImportGroup>
Run Code Online (Sandbox Code Playgroud)

然后 Wpp.targets 定义如下:

<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <PropertyGroup>
      <ExtensionsToDeleteOnClean>$(ExtensionsToDeleteOnClean);*.tmh</ExtensionsToDeleteOnClean>
  </PropertyGroup>
  <ItemGroup>
      <CoreCppClean Include="@(CoreCppClean);$(ProjectDir)">
          <FilePatternsToDelete>*.tmh</FilePatternsToDelete>
     </CoreCppClean>
  </ItemGroup>
  <ItemGroup>
    <TraceWppSources Include="@(ClCompile)" Exclude="stdafx.cpp" />
  </ItemGroup>
  <Target Name="TraceWpp" BeforeTargets="ClCompile" Inputs="@(TraceWppSources)" Outputs="@(TraceWppSources -> '%(Filename).tmh')">
    <Exec Command="cd $(ProjectDir)" />
    <Message Importance="high" Text="Creating tmh"/>
    <Exec Command="$(WdkDir)\bin\x86\tracewpp.EXE -cfgdir:$(WdkDir)\bin\wppconfig\rev1 -odir:. @(TraceWppSources, ' ')" />
    <Message Importance="high" Text="tmh created"/>
  </Target>
</Project>
Run Code Online (Sandbox Code Playgroud)

此步骤取自文章:http : //www.devproconnections.com/article/visual-studio-2010/wpp-tracing-in-visual-c-2010-projects

当尝试在 VS10->Debug 下编译它时,我可以看到正在生成“tmh”文件,但实际上我想记录一些东西时却出现错误:

DoTraceMessage(TRACE_ERROR, L"啊哈"); // 错误 C2065:'TRACE_ERROR':未声明的标识符错误 C3861:'WPP_CALL_Application_Test_cpp':未找到标识符

正如我所说,我对 VS10->Release 目标上的相同代码没有任何问题。这是我的定义供参考:

#pragma once

#define WPP_CONTROL_GUIDS \
    WPP_DEFINE_CONTROL_GUID(CtlGuid,(28EE579B, CF67, 43b6, 9D19, 8930E7AAA131),  \
                                                                            \
        WPP_DEFINE_BIT(TRACE_ERROR)                                   \
        WPP_DEFINE_BIT(TRACE_WARNING)                                   \
        WPP_DEFINE_BIT(TRACE_INFO1)                                   \
        WPP_DEFINE_BIT(TRACE_INFO2)                                   \
        )
Run Code Online (Sandbox Code Playgroud)

有谁知道为什么这可能会在使用发布模式下工作但在调试模式下不起作用?

Uri*_*hen 5

是的,问题是当您使用“支持编辑和继续支持的 PDB 中的调试符号”进行编译时,编译器无法解析 __LINE__ 宏。

如果您从 Application_Test.cpp 第 51 行进行跟踪,WPP 编译器会定义一个函数 WPP_CALL_Application_Test_cpp51,并使用 __FILE__ 和 __LINE__ 来执行此操作。