Dont format logging calls with only the format string

This commit is contained in:
Exzap 2023-04-20 13:14:11 +02:00
parent c209feeaaa
commit f48ad6a1ca
1 changed files with 13 additions and 6 deletions

View File

@ -76,21 +76,28 @@ auto ForwardEnum(std::tuple<TArgs...> t)
} }
template<typename T, typename ... TArgs> template<typename T, typename ... TArgs>
bool cemuLog_log(LogType type, std::basic_string<T> format, TArgs&&... args) bool cemuLog_log(LogType type, std::basic_string<T> formatStr, TArgs&&... args)
{ {
if (!cemuLog_isLoggingEnabled(type)) if (!cemuLog_isLoggingEnabled(type))
return false; return false;
if constexpr (sizeof...(TArgs) == 0)
const auto format_view = fmt::basic_string_view<T>(format); {
cemuLog_log(type, std::basic_string_view<T>(formatStr.data(), formatStr.size()));
return true;
}
else
{
const auto format_view = fmt::basic_string_view<T>(formatStr);
const auto text = fmt::vformat(format_view, fmt::make_format_args<fmt::buffer_context<T>>(ForwardEnum(args)...)); const auto text = fmt::vformat(format_view, fmt::make_format_args<fmt::buffer_context<T>>(ForwardEnum(args)...));
cemuLog_log(type, std::basic_string_view(text.data(), text.size())); cemuLog_log(type, std::basic_string_view(text.data(), text.size()));
}
return true; return true;
} }
template<typename T, typename ... TArgs> template<typename T, typename ... TArgs>
bool cemuLog_log(LogType type, const T* format, TArgs&&... args) bool cemuLog_log(LogType type, const T* format, TArgs&&... args)
{ {
auto format_str=std::basic_string<T>(format); auto format_str = std::basic_string<T>(format);
return cemuLog_log(type, format_str, std::forward<TArgs>(args)...); return cemuLog_log(type, format_str, std::forward<TArgs>(args)...);
} }