当其中一个是函数参数时,在编译时连接 const char

Concatenate const char at compile time when one of them is a function parameter

我正在尝试为 spdlog 中的每个日志字符串添加文件名前缀。 Spdlog 格式化字符串如下所示:

Test log {}

日志是这样写的: spdlog::error("Test log {}", value)

我试图包装这个调用并在格式化字符串之前连接额外的 {},这样我就可以在那里传递文件的前缀。

static constexpr char * prefixHolder("{} ");

template<typename... Args>
void critical(const char fmt[], Args&&... args) const
{
    constexpr auto fullFmt = prefixHolder + fmt; //I can't find any solution for this

    spdlog::critical(fullFmt, m_prefix, std::forward<Args>(args)...);
}


Log log("MyClassOrLogger");

log.critical("My format {}", value);

是否可以在编译时解决这个问题?我已经尝试了一些方法,但我还没有找到任何方法来为编译器创建输入 fmt 参数 constexpr。

C++ 17

有什么建议或解决方案吗?

谢谢

参数值不能用于 constexpr。

你可能会转:

template<typename... Args>
constexpr void critical(const char fmt[], Args&&... args)

进入

template <char... cs, typename... Args>
void critical(std::integer_sequence<char, cs...>, Args&&... args)
{
    constexpr char fullFmt[] = {'{', '}', ' ', cs... , '[=11=]'};

    spdlog::critical(fullFmt, m_prefix, std::forward<Args>(args)...);
}

允许有 constexpr 字符数组。

显示了从文字字符串创建相似序列的方法。 在您的情况下,它将是:

template <typename Char, Char... Cs>
constexpr auto operator"" _cs() -> std::integer_sequence<Char, Cs...> {
    return {};
}

用法是这样的:

log.critical("My format {}"_cs, value); // gcc extension
log.critical(MAKE_SEQUENCE("My format {}"), value);

Demo 带有 gcc 扩展。
Demo 与宏。