宏函数未按预期扩展

Macro function not expanding as expected

本文关键字:扩展 函数      更新时间:2023-10-16

编辑可能的重复链接无助于解决问题。

Bellow 是一个带有注释的最小可编译代码,问题是ERR_INFO宏会导致宏函数LOG_IF_FAILED扩展HRESULT参数的麻烦

我确定这个问题是微不足道的,但调试宏是一场噩梦。

#define UNICODE
#include <Windows.h>
#include <comdef.h>
#include <iostream>
#include <cwchar>

void DebugLogTrace(PCTSTR format_string, ...)
{
// implementation not important
}
// Writes a sprintf-formatted string to the logging file.
#define TRACE(...) DebugLogTrace(__VA_ARGS__)
#ifdef UNICODE
// Show only file name instead of full path wide version
#define FILENAME (std::wcsrchr(TEXT(__FILE__), L'') ? std::wcsrchr(TEXT(__FILE__), L'') + 1 : TEXT(__FILE__))
// Wide string function name
#define FUNCNAME __FUNCTIONW__
// boilerplate macro
#define ERR_INFO FILENAME, FUNCNAME, __LINE__
// Log HRESULTs if failed.
#define LOG_IF_FAILED(file_name, func_name, line, hr) if (FAILED(hr)) 
{ TRACE(TEXT("%s %s %i %s"), file_name, func_name, line, _com_error(hr).ErrorMessage()); }
#else
// ANSI versions here ...
#endif // UNICODE
int main()
{
HRESULT hr = CoInitializeEx(nullptr,
COINIT_APARTMENTTHREADED | COINIT_DISABLE_OLE1DDE);
// Here hr is not inserted into expansion
// ERR_INFO macro is causing problems somehow
LOG_IF_FAILED(ERR_INFO, hr);
// This works however
LOG_IF_FAILED(FILENAME, FUNCNAME, __LINE__, hr);
return 0;
}

>LOG_IF_FAILED(ERR_INFO, hr)应该会导致类似以下内容的内容:
error: macro "LOG_IF_FAILED" requires 4 arguments, but only 2 given.

这可以通过另一个间接级别来解决。

LOG_IF_FAILED重命名为其他名称,假设LOG_IF_FAILED_.
然后添加#define LOG_IF_FAILED(...) LOG_IF_FAILED_(__VA_ARGS__).

编辑:

由于某种原因,这不适用于 MSVC 预处理器。如果使用 MSVC,则应将LOG_IF_FAILED定义为:

#define EMPTY
#define LOG_IF_FAILED(...) LOG_IF_FAILED_ EMPTY (__VA_ARGS__)