mirror of
https://github.com/gabime/spdlog.git
synced 2025-09-28 17:19:34 +08:00
Removed lazy argument evaluation from macros
This commit is contained in:
@@ -40,20 +40,20 @@ TEST_CASE("disable param evaluation", "[macros]")
|
||||
SPDLOG_TRACE("Test message {}", throw std::runtime_error("Should not be evaluated"));
|
||||
}
|
||||
|
||||
TEST_CASE("compile with reference to logger", "[macros]")
|
||||
TEST_CASE("pass logger pointer", "[macros]")
|
||||
{
|
||||
auto logger = spdlog::create<spdlog::sinks::null_sink_mt>("refmacro");
|
||||
auto& ref = *logger;
|
||||
auto &ref = *logger;
|
||||
SPDLOG_LOGGER_TRACE(&ref, "Test message 1");
|
||||
SPDLOG_LOGGER_DEBUG(&ref, "Test message 2");
|
||||
}
|
||||
|
||||
// ensure that even if right macro level is on- don't evaluate if the logger's level is not high enough
|
||||
TEST_CASE("disable param evaluation2", "[macros]")
|
||||
{
|
||||
auto logger = std::make_shared<spdlog::logger>("test-macro");
|
||||
logger->set_level(spdlog::level::off);
|
||||
int x = 0;
|
||||
SPDLOG_LOGGER_DEBUG(logger, "Test message {}", ++x);
|
||||
REQUIRE(x == 0);
|
||||
}
|
||||
//TEST_CASE("disable param evaluation2", "[macros]")
|
||||
//{
|
||||
// auto logger = std::make_shared<spdlog::logger>("test-macro");
|
||||
// logger->set_level(spdlog::level::off);
|
||||
// int x = 0;
|
||||
// SPDLOG_LOGGER_DEBUG(logger, "Test message {}", ++x);
|
||||
// REQUIRE(x == 0);
|
||||
//}
|
||||
|
Reference in New Issue
Block a user