Я использую boost_logging для моего проекта.
В одном из моих файлов я просто использую средство ведения журнала: LDBG_ << "something"
, но он не сшивается для компиляции, у меня есть следующая ошибка:
1>c:\boost\boost_logging\boost\logging\detail\ts\ts_win32.hpp(57) : error C2872: 'CRITICAL_SECTION' : ambiguous symbol
1> could be 'c:\program files\microsoft sdks\windows\v6.0a\include\winbase.h(314) : RTL_CRITICAL_SECTION CRITICAL_SECTION'
1> or 'c:\boost\boost135\boost\detail\lwm_win32_cs.hpp(33) : boost::detail::CRITICAL_SECTION'
Странная часть заключается в том, что этоотлично работает на одном из моих компьютеров, но не на другом, так что это может быть другой файл winbase.h.
РЕДАКТИРОВАТЬ:
Воткак определяется журнал LDBG_:
#include <boost/logging/format_fwd.hpp>
#include <boost/logging/format_ts.hpp>
typedef boost::logging::scenario::usage::use<
// the filter is always accurate (but slow)
//boost::logging::scenario::usage::filter_::change::always_accurate,
boost::logging::scenario::usage::filter_::change::often< 10 >,
// filter does not use levels
boost::logging::scenario::usage::filter_::level::no_levels,
// the logger is initialized once, when only one thread is running
boost::logging::scenario::usage::logger_::change::set_once_when_one_thread,
// the logger favors speed (on a dedicated thread)
boost::logging::scenario::usage::logger_::favor::speed> finder;
BOOST_DECLARE_LOG_FILTER(g_log_filter, finder::filter )
BOOST_DECLARE_LOG(g_log_dbg, finder::logger)
#define LDBG_ BOOST_LOG_USE_LOG_IF_FILTER(g_log_dbg(), g_log_filter()->is_enabled() )