Moved range_length_limit to formatting_range.
Added add_delimiter_spaces and add_prepostfix_space.
This commit is contained in:
parent
a7041e9652
commit
a70b48023f
@ -32,18 +32,22 @@ struct formatting_base {
|
|||||||
|
|
||||||
template <typename Char, typename Enable = void>
|
template <typename Char, typename Enable = void>
|
||||||
struct formatting_range : formatting_base<Char> {
|
struct formatting_range : formatting_base<Char> {
|
||||||
|
static FMT_CONSTEXPR_DECL const std::size_t range_length_limit =
|
||||||
|
FMT_RANGE_OUTPUT_LENGTH_LIMIT; // output only up to N items from the range.
|
||||||
Char prefix = '{';
|
Char prefix = '{';
|
||||||
Char delimiter = ',';
|
Char delimiter = ',';
|
||||||
Char postfix = '}';
|
Char postfix = '}';
|
||||||
static FMT_CONSTEXPR_DECL const bool add_spaces = false;
|
static FMT_CONSTEXPR_DECL const bool add_delimiter_spaces = true;
|
||||||
|
static FMT_CONSTEXPR_DECL const bool add_prepostfix_space = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename Char, typename Enable = void>
|
template <typename Char, typename Enable = void>
|
||||||
struct formatting_tuple : formatting_base<Char> {
|
struct formatting_tuple : formatting_base<Char> {
|
||||||
Char prefix = '[';
|
Char prefix = '(';
|
||||||
Char delimiter = ',';
|
Char delimiter = ',';
|
||||||
Char postfix = ']';
|
Char postfix = ')';
|
||||||
static FMT_CONSTEXPR_DECL const bool add_spaces = false;
|
static FMT_CONSTEXPR_DECL const bool add_delimiter_spaces = true;
|
||||||
|
static FMT_CONSTEXPR_DECL const bool add_prepostfix_space = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace internal {
|
namespace internal {
|
||||||
@ -92,10 +96,11 @@ template <typename T, typename _ = void>
|
|||||||
struct is_range_ : std::false_type {};
|
struct is_range_ : std::false_type {};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct is_range_<T, std::conditional_t<false,
|
struct is_range_<T,typename std::conditional<
|
||||||
conditional_helper<decltype(std::declval<T>().begin()),
|
false,
|
||||||
decltype(std::declval<T>().end())>,
|
conditional_helper<decltype(std::declval<T>().begin()),
|
||||||
void>> : std::true_type {};
|
decltype(std::declval<T>().end())>,
|
||||||
|
void>::type> : std::true_type {};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct is_range {
|
struct is_range {
|
||||||
@ -162,16 +167,20 @@ struct formatter<TupleT, Char,
|
|||||||
std::size_t i = 0;
|
std::size_t i = 0;
|
||||||
internal::copy(formatting.prefix, out);
|
internal::copy(formatting.prefix, out);
|
||||||
internal::for_each(values, [&](const auto &v) {
|
internal::for_each(values, [&](const auto &v) {
|
||||||
if (i++ > 0) {
|
if (i > 0) {
|
||||||
|
if (formatting.add_prepostfix_space) {
|
||||||
|
*out++ = ' ';
|
||||||
|
}
|
||||||
internal::copy(formatting.delimiter, out);
|
internal::copy(formatting.delimiter, out);
|
||||||
}
|
}
|
||||||
if (formatting.add_spaces) {
|
if (formatting.add_delimiter_spaces && i > 0) {
|
||||||
format_to(out, " {}", v);
|
format_to(out, " {}", v);
|
||||||
} else {
|
} else {
|
||||||
format_to(out, "{}", v);
|
format_to(out, "{}", v);
|
||||||
}
|
}
|
||||||
|
++i;
|
||||||
});
|
});
|
||||||
if (formatting.add_spaces) {
|
if (formatting.add_prepostfix_space) {
|
||||||
*out++ = ' ';
|
*out++ = ' ';
|
||||||
}
|
}
|
||||||
internal::copy(formatting.postfix, out);
|
internal::copy(formatting.postfix, out);
|
||||||
@ -184,8 +193,6 @@ template <typename RangeT, typename Char>
|
|||||||
struct formatter< RangeT, Char,
|
struct formatter< RangeT, Char,
|
||||||
typename std::enable_if<fmt::internal::is_range<RangeT>::value>::type> {
|
typename std::enable_if<fmt::internal::is_range<RangeT>::value>::type> {
|
||||||
|
|
||||||
static FMT_CONSTEXPR_DECL const std::size_t range_length_limit =
|
|
||||||
FMT_RANGE_OUTPUT_LENGTH_LIMIT; // output only up to N items from the range.
|
|
||||||
|
|
||||||
fmt::formatting_range<Char> formatting;
|
fmt::formatting_range<Char> formatting;
|
||||||
|
|
||||||
@ -201,19 +208,22 @@ struct formatter< RangeT, Char,
|
|||||||
std::size_t i = 0;
|
std::size_t i = 0;
|
||||||
for (const auto &it : values) {
|
for (const auto &it : values) {
|
||||||
if (i > 0) {
|
if (i > 0) {
|
||||||
|
if (formatting.add_prepostfix_space) {
|
||||||
|
*out++ = ' ';
|
||||||
|
}
|
||||||
internal::copy(formatting.delimiter, out);
|
internal::copy(formatting.delimiter, out);
|
||||||
}
|
}
|
||||||
if (formatting.add_spaces) {
|
if (formatting.add_delimiter_spaces && i > 0) {
|
||||||
format_to(out, " {}", it);
|
format_to(out, " {}", it);
|
||||||
} else {
|
} else {
|
||||||
format_to(out, "{}", it);
|
format_to(out, "{}", it);
|
||||||
}
|
}
|
||||||
if (++i > range_length_limit) {
|
if (++i > formatting.range_length_limit) {
|
||||||
format_to(out, " ... <other elements>");
|
format_to(out, " ... <other elements>");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (formatting.add_spaces) {
|
if (formatting.add_prepostfix_space) {
|
||||||
*out++ = ' ';
|
*out++ = ' ';
|
||||||
}
|
}
|
||||||
internal::copy(formatting.postfix, out);
|
internal::copy(formatting.postfix, out);
|
||||||
|
|||||||
@ -9,10 +9,6 @@
|
|||||||
// All Rights Reserved
|
// All Rights Reserved
|
||||||
// {fmt} support for ranges, containers and types tuple interface.
|
// {fmt} support for ranges, containers and types tuple interface.
|
||||||
|
|
||||||
#ifdef WIN32
|
|
||||||
#define _CRT_SECURE_NO_WARNINGS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "fmt/ranges.h"
|
#include "fmt/ranges.h"
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
#include "gtest/gtest.h"
|
||||||
@ -36,20 +32,21 @@ TEST(RangesTest, FormatVector2) {
|
|||||||
|
|
||||||
TEST(RangesTest, FormatMap) {
|
TEST(RangesTest, FormatMap) {
|
||||||
std::map<std::string, int32_t> simap{{"one", 1}, {"two", 2}};
|
std::map<std::string, int32_t> simap{{"one", 1}, {"two", 2}};
|
||||||
EXPECT_EQ("{[one,1],[two,2]}", fmt::format("{}", simap));
|
EXPECT_EQ("{(one,1),(two,2)}", fmt::format("{}", simap));
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(RangesTest, FormatPair) {
|
TEST(RangesTest, FormatPair) {
|
||||||
std::pair<int64_t, float> pa1{42, 3.14159265358979f};
|
std::pair<int64_t, float> pa1{42, 3.14159265358979f};
|
||||||
EXPECT_EQ("[42,3.14159]", fmt::format("{}", pa1));
|
EXPECT_EQ("(42,3.14159)", fmt::format("{}", pa1));
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(RangesTest, FormatTuple) {
|
TEST(RangesTest, FormatTuple) {
|
||||||
std::tuple<int64_t, float, std::string> tu1{42, 3.14159265358979f,
|
std::tuple<int64_t, float, std::string> tu1{42, 3.14159265358979f,
|
||||||
"this is tuple"};
|
"this is tuple"};
|
||||||
EXPECT_EQ("[42,3.14159,this is tuple]", fmt::format("{}", tu1));
|
EXPECT_EQ("(42,3.14159,this is tuple)", fmt::format("{}", tu1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// check if 'if constexpr' is supported.
|
||||||
#if (__cplusplus > 201402L) || \
|
#if (__cplusplus > 201402L) || \
|
||||||
(defined(_MSVC_LANG) && _MSVC_LANG > 201402L && _MSC_VER >= 1910)
|
(defined(_MSVC_LANG) && _MSVC_LANG > 201402L && _MSC_VER >= 1910)
|
||||||
|
|
||||||
@ -84,7 +81,8 @@ struct tuple_element<N, my_struct> {
|
|||||||
|
|
||||||
TEST(RangesTest, FormatStruct) {
|
TEST(RangesTest, FormatStruct) {
|
||||||
my_struct mst{13, "my struct"};
|
my_struct mst{13, "my struct"};
|
||||||
EXPECT_EQ("[13,my struct]", fmt::format("{}", mst));
|
EXPECT_EQ("(13, my struct)", fmt::format("{}", mst));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // (__cplusplus > 201402L) || (defined(_MSVC_LANG) && _MSVC_LANG > 201402L && _MSC_VER >= 1910)
|
#endif // (__cplusplus > 201402L) || (defined(_MSVC_LANG) && _MSVC_LANG >
|
||||||
|
// 201402L && _MSC_VER >= 1910)
|
||||||
Loading…
Reference in New Issue
Block a user