不完全是你问的,因为你必须把你的函数称为
myFunction(myString, "name", "World", "number", 42);
代替
myFunction(myString, {"name", "World"}, {"number", 42});
但以下应该是一个例子(对不起,但baz()
未经测试)
#include <tuple>
#include <string>
#include <utility>
#include <iostream>
// fmt headers
template <typename ... Ps>
std::string baz (char const * frmt,
std::pair<char const *, Ps> const & ... ps)
{ return fmt::format(frmt, fmt::arg(ps.first, ps.second)...); }
template <typename ... Ts, std::size_t ... Is>
std::string bar (char const * frmt, std::tuple<Ts...> const & t,
std::index_sequence<Is...> const &)
{ return baz(frmt, std::get<Is>(t)...); }
template <typename ... Ts>
std::string foo (char const * frmt, std::tuple<Ts...> const & t)
{ return bar(frmt, t, std::make_index_sequence<sizeof...(Ts)>{}); }
template <typename ... Ts, typename P1, typename P2, typename ... Args>
std::string foo (char const * frmt, std::tuple<Ts...> const & t,
P1 const & p1, P2 const & p2, Args const & ... args)
{ return foo(frmt,
std::tuple_cat(t, std::make_tuple(std::make_pair(p1, p2))), args...); }
template <typename ... Args>
std::string myFunction (char const * frmt, Args const & ... args)
{ return foo(frmt, std::tuple<>{}, args...); }
int main()
{
myFunction("format", "name", "World", "number", 42);
}
观察这个例子使用std::index_sequence
and std::make_index_sequence()
,所以从 C++14 开始编译;但是很容易为这个类创建一个替代品,这个函数也可以与 C++11 一起使用。