Make make_format_args public

This commit is contained in:
Victor Zverovich 2016-08-27 07:57:48 -07:00
parent 0028ce57b6
commit 4ece95a754
8 changed files with 31 additions and 34 deletions

1
build/test/test Normal file
View File

@ -0,0 +1 @@
there must be something here

1
build/test/test-file Normal file
View File

@ -0,0 +1 @@
Don't panic!

View File

@ -1405,14 +1405,16 @@ constexpr uint64_t make_type<void>() { return 0; }
// Maximum number of arguments with packed types. // Maximum number of arguments with packed types.
enum { MAX_PACKED_ARGS = 16 }; enum { MAX_PACKED_ARGS = 16 };
} // namespace internal
template <typename ...Args> template <typename ...Args>
class format_arg_store { class format_arg_store {
private: private:
static const size_t NUM_ARGS = sizeof...(Args); static const size_t NUM_ARGS = sizeof...(Args);
static const bool PACKED = NUM_ARGS <= MAX_PACKED_ARGS; static const bool PACKED = NUM_ARGS <= internal::MAX_PACKED_ARGS;
typedef typename std::conditional<PACKED, Value, Arg>::type value_type; typedef typename std::conditional<
PACKED, internal::Value, internal::Arg>::type value_type;
// If the arguments are not packed, add one more element to mark the end. // If the arguments are not packed, add one more element to mark the end.
std::array<value_type, NUM_ARGS + (PACKED ? 0 : 1)> data_; std::array<value_type, NUM_ARGS + (PACKED ? 0 : 1)> data_;
@ -1421,11 +1423,11 @@ class format_arg_store {
friend format_arg_store<A...> make_format_args(const A & ... args); friend format_arg_store<A...> make_format_args(const A & ... args);
public: public:
static const uint64_t TYPES = make_type<Args..., void>(); static const uint64_t TYPES = internal::make_type<Args..., void>();
template <typename Formatter> template <typename Formatter>
format_arg_store(const Args &... args, Formatter *) format_arg_store(const Args &... args, Formatter *)
: data_{{MakeValue<Formatter>(args)...}} {} : data_{{internal::MakeValue<Formatter>(args)...}} {}
const value_type *data() const { return data_.data(); } const value_type *data() const { return data_.data(); }
}; };
@ -1435,7 +1437,6 @@ inline format_arg_store<Args...> make_format_args(const Args & ... args) {
Formatter *f = nullptr; Formatter *f = nullptr;
return format_arg_store<Args...>(args..., f); return format_arg_store<Args...>(args..., f);
} }
} // namespace internal
/** Formatting arguments. */ /** Formatting arguments. */
class format_args { class format_args {
@ -1470,7 +1471,7 @@ class format_args {
format_args() : types_(0) {} format_args() : types_(0) {}
template <typename... Args> template <typename... Args>
format_args(const internal::format_arg_store<Args...> &store) format_args(const format_arg_store<Args...> &store)
: types_(store.TYPES) { : types_(store.TYPES) {
set_data(store.data()); set_data(store.data());
} }
@ -2184,7 +2185,7 @@ class BasicFormatter : private internal::FormatterBase {
# define FMT_VARIADIC_VOID(func, arg_type) \ # define FMT_VARIADIC_VOID(func, arg_type) \
template <typename... Args> \ template <typename... Args> \
void func(arg_type arg0, const Args & ... args) { \ void func(arg_type arg0, const Args & ... args) { \
auto store = fmt::internal::make_format_args< fmt::BasicFormatter<Char> >(args...); \ auto store = fmt::make_format_args< fmt::BasicFormatter<Char> >(args...); \
func(arg0, fmt::format_args(store)); \ func(arg0, fmt::format_args(store)); \
} }
@ -2192,7 +2193,7 @@ class BasicFormatter : private internal::FormatterBase {
# define FMT_VARIADIC_CTOR(ctor, func, arg0_type, arg1_type) \ # define FMT_VARIADIC_CTOR(ctor, func, arg0_type, arg1_type) \
template <typename... Args> \ template <typename... Args> \
ctor(arg0_type arg0, arg1_type arg1, const Args & ... args) { \ ctor(arg0_type arg0, arg1_type arg1, const Args & ... args) { \
auto store = internal::make_format_args< fmt::BasicFormatter<Char> >(args...); \ auto store = fmt::make_format_args< fmt::BasicFormatter<Char> >(args...); \
func(arg0, arg1, fmt::format_args(store)); \ func(arg0, arg1, fmt::format_args(store)); \
} }
@ -3128,7 +3129,7 @@ template <typename... Args>
inline void print_colored(Color c, CStringRef format_str, inline void print_colored(Color c, CStringRef format_str,
const Args & ... args) { const Args & ... args) {
vprint_colored(c, format_str, vprint_colored(c, format_str,
internal::make_format_args<BasicFormatter<char>>(args...)); make_format_args<BasicFormatter<char>>(args...));
} }
inline std::string vformat(CStringRef format_str, format_args args) { inline std::string vformat(CStringRef format_str, format_args args) {
@ -3148,8 +3149,7 @@ inline std::string vformat(CStringRef format_str, format_args args) {
*/ */
template <typename... Args> template <typename... Args>
inline std::string format(CStringRef format_str, const Args & ... args) { inline std::string format(CStringRef format_str, const Args & ... args) {
auto vargs = internal::make_format_args<BasicFormatter<char>>(args...); return vformat(format_str, make_format_args<BasicFormatter<char>>(args...));
return vformat(format_str, vargs);
} }
inline std::wstring vformat(WCStringRef format_str, format_args args) { inline std::wstring vformat(WCStringRef format_str, format_args args) {
@ -3160,7 +3160,7 @@ inline std::wstring vformat(WCStringRef format_str, format_args args) {
template <typename... Args> template <typename... Args>
inline std::wstring format(WCStringRef format_str, const Args & ... args) { inline std::wstring format(WCStringRef format_str, const Args & ... args) {
auto vargs = internal::make_format_args<BasicFormatter<wchar_t>>(args...); auto vargs = make_format_args<BasicFormatter<wchar_t>>(args...);
return vformat(format_str, vargs); return vformat(format_str, vargs);
} }
@ -3177,8 +3177,7 @@ FMT_API void vprint(std::FILE *f, CStringRef format_str, format_args args);
*/ */
template <typename... Args> template <typename... Args>
inline void print(std::FILE *f, CStringRef format_str, const Args & ... args) { inline void print(std::FILE *f, CStringRef format_str, const Args & ... args) {
vprint(f, format_str, vprint(f, format_str, make_format_args<BasicFormatter<char>>(args...));
internal::make_format_args<BasicFormatter<char>>(args...));
} }
FMT_API void vprint(CStringRef format_str, format_args args); FMT_API void vprint(CStringRef format_str, format_args args);
@ -3194,7 +3193,7 @@ FMT_API void vprint(CStringRef format_str, format_args args);
*/ */
template <typename... Args> template <typename... Args>
inline void print(CStringRef format_str, const Args & ... args) { inline void print(CStringRef format_str, const Args & ... args) {
vprint(format_str, internal::make_format_args<BasicFormatter<char>>(args...)); vprint(format_str, make_format_args<BasicFormatter<char>>(args...));
} }
/** /**

View File

@ -100,8 +100,7 @@ FMT_API void vprint(std::ostream &os, CStringRef format_str, format_args args);
template <typename... Args> template <typename... Args>
inline void print(std::ostream &os, CStringRef format_str, inline void print(std::ostream &os, CStringRef format_str,
const Args & ... args) { const Args & ... args) {
vprint(os, format_str, vprint(os, format_str, make_format_args<BasicFormatter<char>>(args...));
internal::make_format_args<BasicFormatter<char>>(args...));
} }
} // namespace fmt } // namespace fmt

View File

@ -172,8 +172,7 @@ public:
template <typename... Args> template <typename... Args>
inline void print(CStringRef format_str, const Args & ... args) { inline void print(CStringRef format_str, const Args & ... args) {
vprint(format_str, vprint(format_str, make_format_args<BasicFormatter<char>>(args...));
internal::make_format_args<BasicFormatter<char>>(args...));
} }
}; };

View File

@ -506,8 +506,7 @@ inline std::string vsprintf(CStringRef format, format_args args) {
*/ */
template <typename... Args> template <typename... Args>
inline std::string sprintf(CStringRef format_str, const Args & ... args) { inline std::string sprintf(CStringRef format_str, const Args & ... args) {
auto vargs = internal::make_format_args<BasicFormatter<char>>(args...); return vsprintf(format_str, make_format_args<BasicFormatter<char>>(args...));
return vsprintf(format_str, vargs);
} }
inline std::wstring vsprintf(WCStringRef format, format_args args) { inline std::wstring vsprintf(WCStringRef format, format_args args) {
@ -518,7 +517,7 @@ inline std::wstring vsprintf(WCStringRef format, format_args args) {
template <typename... Args> template <typename... Args>
inline std::wstring sprintf(WCStringRef format_str, const Args & ... args) { inline std::wstring sprintf(WCStringRef format_str, const Args & ... args) {
auto vargs = internal::make_format_args<BasicFormatter<wchar_t>>(args...); auto vargs = make_format_args<BasicFormatter<wchar_t>>(args...);
return vsprintf(format_str, vargs); return vsprintf(format_str, vargs);
} }
@ -535,7 +534,7 @@ FMT_API int vfprintf(std::FILE *f, CStringRef format, format_args args);
*/ */
template <typename... Args> template <typename... Args>
inline int fprintf(std::FILE *f, CStringRef format_str, const Args & ... args) { inline int fprintf(std::FILE *f, CStringRef format_str, const Args & ... args) {
auto vargs = internal::make_format_args<BasicFormatter<char>>(args...); auto vargs = make_format_args<BasicFormatter<char>>(args...);
return vfprintf(f, format_str, vargs); return vfprintf(f, format_str, vargs);
} }
@ -554,8 +553,7 @@ inline int vprintf(CStringRef format, format_args args) {
*/ */
template <typename... Args> template <typename... Args>
inline int printf(CStringRef format_str, const Args & ... args) { inline int printf(CStringRef format_str, const Args & ... args) {
auto vargs = internal::make_format_args<BasicFormatter<char>>(args...); return vprintf(format_str, make_format_args<BasicFormatter<char>>(args...));
return vprintf(format_str, vargs);
} }
inline int vfprintf(std::ostream &os, CStringRef format_str, format_args args) { inline int vfprintf(std::ostream &os, CStringRef format_str, format_args args) {
@ -577,7 +575,7 @@ inline int vfprintf(std::ostream &os, CStringRef format_str, format_args args) {
template <typename... Args> template <typename... Args>
inline int fprintf(std::ostream &os, CStringRef format_str, inline int fprintf(std::ostream &os, CStringRef format_str,
const Args & ... args) { const Args & ... args) {
auto vargs = internal::make_format_args<BasicFormatter<char>>(args...); auto vargs = make_format_args<BasicFormatter<char>>(args...);
return vfprintf(os, format_str, vargs); return vfprintf(os, format_str, vargs);
} }
} // namespace fmt } // namespace fmt

View File

@ -45,7 +45,7 @@ class CustomPrintfArgFormatter :
} }
}; };
std::string vcustom_format(const char *format_str, fmt::format_args args) { std::string custom_vformat(const char *format_str, fmt::format_args args) {
fmt::MemoryWriter writer; fmt::MemoryWriter writer;
// Pass custom argument formatter as a template arg to BasicFormatter. // Pass custom argument formatter as a template arg to BasicFormatter.
fmt::BasicFormatter<char, CustomArgFormatter> formatter(args, writer); fmt::BasicFormatter<char, CustomArgFormatter> formatter(args, writer);
@ -55,11 +55,11 @@ std::string vcustom_format(const char *format_str, fmt::format_args args) {
template <typename... Args> template <typename... Args>
std::string custom_format(const char *format_str, const Args & ... args) { std::string custom_format(const char *format_str, const Args & ... args) {
auto va = fmt::internal::make_format_args<fmt::BasicFormatter<char>>(args...); auto va = fmt::make_format_args<fmt::BasicFormatter<char>>(args...);
return vcustom_format(format_str, va); return custom_vformat(format_str, va);
} }
std::string vcustom_sprintf(const char* format_str, fmt::format_args args) { std::string custom_vsprintf(const char* format_str, fmt::format_args args) {
fmt::MemoryWriter writer; fmt::MemoryWriter writer;
fmt::PrintfFormatter<char, CustomPrintfArgFormatter> formatter(args, writer); fmt::PrintfFormatter<char, CustomPrintfArgFormatter> formatter(args, writer);
formatter.format(format_str); formatter.format(format_str);
@ -68,8 +68,8 @@ std::string vcustom_sprintf(const char* format_str, fmt::format_args args) {
template <typename... Args> template <typename... Args>
std::string custom_sprintf(const char *format_str, const Args & ... args) { std::string custom_sprintf(const char *format_str, const Args & ... args) {
auto va = fmt::internal::make_format_args<fmt::BasicFormatter<char>>(args...); auto va = fmt::make_format_args<fmt::BasicFormatter<char>>(args...);
return vcustom_sprintf(format_str, va); return custom_vsprintf(format_str, va);
} }
TEST(CustomFormatterTest, Format) { TEST(CustomFormatterTest, Format) {

View File

@ -1572,7 +1572,7 @@ std::string vformat_message(int id, const char *format, fmt::format_args args) {
template <typename... Args> template <typename... Args>
std::string format_message(int id, const char *format, const Args & ... args) { std::string format_message(int id, const char *format, const Args & ... args) {
auto va = fmt::internal::make_format_args<fmt::BasicFormatter<char>>(args...); auto va = fmt::make_format_args<fmt::BasicFormatter<char>>(args...);
return vformat_message(id, format, va); return vformat_message(id, format, va);
} }
@ -1654,7 +1654,7 @@ void vcustom_format(const char *format_str, fmt::format_args args) {
template <typename... Args> template <typename... Args>
void custom_format(const char *format_str, const Args & ... args) { void custom_format(const char *format_str, const Args & ... args) {
auto va = fmt::internal::make_format_args<fmt::BasicFormatter<char>>(args...); auto va = fmt::make_format_args<fmt::BasicFormatter<char>>(args...);
return vcustom_format(format_str, va); return vcustom_format(format_str, va);
} }