我有一个日志库,它使用宏来跟踪消息。该宏使用预定义的宏,例如__func__
and __PRETTY_FUNCTION__
指示消息被记录在哪个函数/方法中。
我的日志库的宏定义在我的日志库的主头中,位于任何函数之外。
由于某种原因,预处理的代码包含__func__
(or __PRETTY_FUNCTION__
如果我正在使用这个),就像这些预定义的宏不存在一样。但我知道它们确实存在,因为如果我在不使用库的跟踪宏的情况下使用它们,它们就会起作用!
这是我的库宏:
#if _MSC_VER >= 1400 // If >= VS2005
#define _TRACE_FUNC_SIGNATURE __FUNCSIG__
#elif defined(__ANDROID__) || defined( __GNUC__ ) && defined( __cplusplus ) // If G++ and/or Android NDK
#define _TRACE_FUNC_SIGNATURE __func__
#else
#error // Unsupported compiler
#endif
// Forces the reprocessing of x to properly expand __VA_ARGS__ when using MSVC compiler
#define _TRACE_REPROCESS( x ) x
#define _TRACE_X( _methodName_, _logCatPtr_, ... ) \
do { \
::dbg::LogCategory * const _catPtrVal_ = (::dbg::LogCategory *)(_logCatPtr_); \
if( NULL != _catPtrVal_ && _catPtrVal_->IsEnabled() ) \
{ \
_TRACE_REPROCESS( _catPtrVal_->_methodName_( _TRACE_FUNC_SIGNATURE " - " __VA_ARGS__ ); ) \
} \
} while( false )
#define TRACE_E( _logCatPtr_, ... ) _TRACE_X( Error, _logCatPtr_, __VA_ARGS__ )
#define TRACE_W( _logCatPtr_, ... ) _TRACE_X( Warning, _logCatPtr_, __VA_ARGS__ )
#define TRACE_I( _logCatPtr_, ... ) _TRACE_X( Info, _logCatPtr_, __VA_ARGS__ )
我知道这些宏没有理由在函数外部定义,但由于我只在函数/方法内部使用跟踪宏,所以应该在那里定义它!
我使用的是 eclipse 提供的默认 Android NDK 编译器,据我所知,它是某种扩展的 G++。
EDIT: 如果我更换__func__
通过实际的字符串文字,它可以工作,没有语法错误。这让我觉得__func__
在我的宏中使用时绝对没有定义。