diff --git a/include/fmt/core.h b/include/fmt/core.h index c65709aca574..c412e97d3621 100644 --- a/include/fmt/core.h +++ b/include/fmt/core.h @@ -1145,6 +1145,16 @@ class basic_format_args { set_data(store.data_); } + /** + \rst + Constructs a `basic_format_args` object from a dynamic set of arguments. + \endrst + */ + basic_format_args(const format_arg *args, size_type count) + : types_(-static_cast(count)) { + set_data(args); + } + /** Returns the argument at specified index. */ format_arg get(size_type index) const { format_arg arg = do_get(index); diff --git a/test/format-test.cc b/test/format-test.cc index 2b7208765712..9eeb7a032a34 100644 --- a/test/format-test.cc +++ b/test/format-test.cc @@ -1308,6 +1308,21 @@ TEST(FormatTest, Variadic) { EXPECT_EQ(L"abc1", format(L"{}c{}", L"ab", 1)); } +TEST(FormatTest, Dynamic) { + using ctx = fmt::format_context; + std::vector> args; + args.emplace_back(fmt::internal::make_arg(42)); + args.emplace_back(fmt::internal::make_arg("abc1")); + args.emplace_back(fmt::internal::make_arg(1.2f)); + + std::string result = fmt::vformat("{} and {} and {}", + fmt::basic_format_args( + args.data(), + static_cast(args.size()))); + + EXPECT_EQ("42 and abc1 and 1.2", result); +} + TEST(FormatTest, JoinArg) { using fmt::join; int v1[3] = { 1, 2, 3 };