1*5c90c05cSAndroid Build Coastguard Worker // Formatting library for C++ - module tests
2*5c90c05cSAndroid Build Coastguard Worker //
3*5c90c05cSAndroid Build Coastguard Worker // Copyright (c) 2012 - present, Victor Zverovich
4*5c90c05cSAndroid Build Coastguard Worker // All rights reserved.
5*5c90c05cSAndroid Build Coastguard Worker //
6*5c90c05cSAndroid Build Coastguard Worker // For the license information refer to format.h.
7*5c90c05cSAndroid Build Coastguard Worker //
8*5c90c05cSAndroid Build Coastguard Worker // Copyright (c) 2021 - present, Daniela Engert
9*5c90c05cSAndroid Build Coastguard Worker // All Rights Reserved
10*5c90c05cSAndroid Build Coastguard Worker // {fmt} module.
11*5c90c05cSAndroid Build Coastguard Worker
12*5c90c05cSAndroid Build Coastguard Worker #ifdef _MSC_FULL_VER
13*5c90c05cSAndroid Build Coastguard Worker // hide some implementation bugs in msvc
14*5c90c05cSAndroid Build Coastguard Worker // that are not essential to users of the module.
15*5c90c05cSAndroid Build Coastguard Worker # define FMT_HIDE_MODULE_BUGS
16*5c90c05cSAndroid Build Coastguard Worker #endif
17*5c90c05cSAndroid Build Coastguard Worker
18*5c90c05cSAndroid Build Coastguard Worker #include <bit>
19*5c90c05cSAndroid Build Coastguard Worker #include <chrono>
20*5c90c05cSAndroid Build Coastguard Worker #include <exception>
21*5c90c05cSAndroid Build Coastguard Worker #include <iterator>
22*5c90c05cSAndroid Build Coastguard Worker #include <locale>
23*5c90c05cSAndroid Build Coastguard Worker #include <memory>
24*5c90c05cSAndroid Build Coastguard Worker #include <ostream>
25*5c90c05cSAndroid Build Coastguard Worker #include <string>
26*5c90c05cSAndroid Build Coastguard Worker #include <string_view>
27*5c90c05cSAndroid Build Coastguard Worker #include <system_error>
28*5c90c05cSAndroid Build Coastguard Worker
29*5c90c05cSAndroid Build Coastguard Worker #if (__has_include(<fcntl.h>) || defined(__APPLE__) || \
30*5c90c05cSAndroid Build Coastguard Worker defined(__linux__)) && \
31*5c90c05cSAndroid Build Coastguard Worker (!defined(WINAPI_FAMILY) || (WINAPI_FAMILY == WINAPI_FAMILY_DESKTOP_APP))
32*5c90c05cSAndroid Build Coastguard Worker # include <fcntl.h>
33*5c90c05cSAndroid Build Coastguard Worker # define FMT_USE_FCNTL 1
34*5c90c05cSAndroid Build Coastguard Worker #else
35*5c90c05cSAndroid Build Coastguard Worker # define FMT_USE_FCNTL 0
36*5c90c05cSAndroid Build Coastguard Worker #endif
37*5c90c05cSAndroid Build Coastguard Worker #if defined(_WIN32) && !defined(__MINGW32__)
38*5c90c05cSAndroid Build Coastguard Worker # define FMT_POSIX(call) _##call
39*5c90c05cSAndroid Build Coastguard Worker #else
40*5c90c05cSAndroid Build Coastguard Worker # define FMT_POSIX(call) call
41*5c90c05cSAndroid Build Coastguard Worker #endif
42*5c90c05cSAndroid Build Coastguard Worker
43*5c90c05cSAndroid Build Coastguard Worker import fmt;
44*5c90c05cSAndroid Build Coastguard Worker
45*5c90c05cSAndroid Build Coastguard Worker // check for macros leaking from BMI
46*5c90c05cSAndroid Build Coastguard Worker static bool macro_leaked =
47*5c90c05cSAndroid Build Coastguard Worker #if defined(FMT_CORE_H_) || defined(FMT_FORMAT_H_)
48*5c90c05cSAndroid Build Coastguard Worker true;
49*5c90c05cSAndroid Build Coastguard Worker #else
50*5c90c05cSAndroid Build Coastguard Worker false;
51*5c90c05cSAndroid Build Coastguard Worker #endif
52*5c90c05cSAndroid Build Coastguard Worker
53*5c90c05cSAndroid Build Coastguard Worker #define FMT_OS_H_ // don't pull in os.h, neither directly nor indirectly
54*5c90c05cSAndroid Build Coastguard Worker #include "gtest-extra.h"
55*5c90c05cSAndroid Build Coastguard Worker
56*5c90c05cSAndroid Build Coastguard Worker // an implicitly exported namespace must be visible [module.interface]/2.2
TEST(module_test,namespace)57*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, namespace) {
58*5c90c05cSAndroid Build Coastguard Worker using namespace fmt;
59*5c90c05cSAndroid Build Coastguard Worker using namespace fmt::literals;
60*5c90c05cSAndroid Build Coastguard Worker ASSERT_TRUE(true);
61*5c90c05cSAndroid Build Coastguard Worker }
62*5c90c05cSAndroid Build Coastguard Worker
63*5c90c05cSAndroid Build Coastguard Worker namespace detail {
64*5c90c05cSAndroid Build Coastguard Worker bool oops_detail_namespace_is_visible;
65*5c90c05cSAndroid Build Coastguard Worker }
66*5c90c05cSAndroid Build Coastguard Worker
67*5c90c05cSAndroid Build Coastguard Worker namespace fmt {
namespace_detail_invisible()68*5c90c05cSAndroid Build Coastguard Worker bool namespace_detail_invisible() {
69*5c90c05cSAndroid Build Coastguard Worker #if defined(FMT_HIDE_MODULE_BUGS) && defined(_MSC_FULL_VER) && \
70*5c90c05cSAndroid Build Coastguard Worker _MSC_FULL_VER <= 193700000
71*5c90c05cSAndroid Build Coastguard Worker // bug in msvc up to at least 17.7:
72*5c90c05cSAndroid Build Coastguard Worker
73*5c90c05cSAndroid Build Coastguard Worker // the namespace is visible even when it is neither
74*5c90c05cSAndroid Build Coastguard Worker // implicitly nor explicitly exported
75*5c90c05cSAndroid Build Coastguard Worker return true;
76*5c90c05cSAndroid Build Coastguard Worker #else
77*5c90c05cSAndroid Build Coastguard Worker using namespace detail;
78*5c90c05cSAndroid Build Coastguard Worker // this fails to compile if fmt::detail is visible
79*5c90c05cSAndroid Build Coastguard Worker return !oops_detail_namespace_is_visible;
80*5c90c05cSAndroid Build Coastguard Worker #endif
81*5c90c05cSAndroid Build Coastguard Worker }
82*5c90c05cSAndroid Build Coastguard Worker } // namespace fmt
83*5c90c05cSAndroid Build Coastguard Worker
84*5c90c05cSAndroid Build Coastguard Worker // the non-exported namespace 'detail' must be invisible [module.interface]/2
TEST(module_test,detail_namespace)85*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, detail_namespace) {
86*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::namespace_detail_invisible());
87*5c90c05cSAndroid Build Coastguard Worker }
88*5c90c05cSAndroid Build Coastguard Worker
89*5c90c05cSAndroid Build Coastguard Worker // macros must not be imported from a *named* module [cpp.import]/5.1
TEST(module_test,macros)90*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, macros) {
91*5c90c05cSAndroid Build Coastguard Worker #if defined(FMT_HIDE_MODULE_BUGS) && defined(_MSC_FULL_VER) && \
92*5c90c05cSAndroid Build Coastguard Worker _MSC_FULL_VER <= 192930130
93*5c90c05cSAndroid Build Coastguard Worker // bug in msvc up to 16.11-pre2:
94*5c90c05cSAndroid Build Coastguard Worker // include-guard macros leak from BMI
95*5c90c05cSAndroid Build Coastguard Worker // and even worse: they cannot be #undef-ined
96*5c90c05cSAndroid Build Coastguard Worker macro_leaked = false;
97*5c90c05cSAndroid Build Coastguard Worker #endif
98*5c90c05cSAndroid Build Coastguard Worker EXPECT_FALSE(macro_leaked);
99*5c90c05cSAndroid Build Coastguard Worker }
100*5c90c05cSAndroid Build Coastguard Worker
101*5c90c05cSAndroid Build Coastguard Worker // The following is less about functional testing (that's done elsewhere)
102*5c90c05cSAndroid Build Coastguard Worker // but rather visibility of all client-facing overloads, reachability of
103*5c90c05cSAndroid Build Coastguard Worker // non-exported entities, name lookup and overload resolution within
104*5c90c05cSAndroid Build Coastguard Worker // template instantitions.
105*5c90c05cSAndroid Build Coastguard Worker // Exercise all exported entities of the API at least once.
106*5c90c05cSAndroid Build Coastguard Worker // Instantiate as many code paths as possible.
107*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,to_string)108*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, to_string) {
109*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::to_string(42));
110*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::to_string(42.0));
111*5c90c05cSAndroid Build Coastguard Worker
112*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::to_wstring(42));
113*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::to_wstring(42.0));
114*5c90c05cSAndroid Build Coastguard Worker }
115*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,format)116*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, format) {
117*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::format("{:}", 42));
118*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("-42", fmt::format("{0}", -42.0));
119*5c90c05cSAndroid Build Coastguard Worker
120*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::format(L"{:}", 42));
121*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"-42", fmt::format(L"{0}", -42.0));
122*5c90c05cSAndroid Build Coastguard Worker }
123*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,format_to)124*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, format_to) {
125*5c90c05cSAndroid Build Coastguard Worker std::string s;
126*5c90c05cSAndroid Build Coastguard Worker fmt::format_to(std::back_inserter(s), "{}", 42);
127*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", s);
128*5c90c05cSAndroid Build Coastguard Worker
129*5c90c05cSAndroid Build Coastguard Worker char buffer[4] = {0};
130*5c90c05cSAndroid Build Coastguard Worker fmt::format_to(buffer, "{}", 42);
131*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", std::string_view(buffer));
132*5c90c05cSAndroid Build Coastguard Worker
133*5c90c05cSAndroid Build Coastguard Worker fmt::memory_buffer mb;
134*5c90c05cSAndroid Build Coastguard Worker fmt::format_to(std::back_inserter(mb), "{}", 42);
135*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", std::string_view(buffer));
136*5c90c05cSAndroid Build Coastguard Worker
137*5c90c05cSAndroid Build Coastguard Worker std::wstring w;
138*5c90c05cSAndroid Build Coastguard Worker fmt::format_to(std::back_inserter(w), L"{}", 42);
139*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", w);
140*5c90c05cSAndroid Build Coastguard Worker
141*5c90c05cSAndroid Build Coastguard Worker wchar_t wbuffer[4] = {0};
142*5c90c05cSAndroid Build Coastguard Worker fmt::format_to(wbuffer, L"{}", 42);
143*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", std::wstring_view(wbuffer));
144*5c90c05cSAndroid Build Coastguard Worker
145*5c90c05cSAndroid Build Coastguard Worker fmt::wmemory_buffer wb;
146*5c90c05cSAndroid Build Coastguard Worker fmt::format_to(std::back_inserter(wb), L"{}", 42);
147*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", std::wstring_view(wbuffer));
148*5c90c05cSAndroid Build Coastguard Worker }
149*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,formatted_size)150*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, formatted_size) {
151*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(2u, fmt::formatted_size("{}", 42));
152*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(2u, fmt::formatted_size(L"{}", 42));
153*5c90c05cSAndroid Build Coastguard Worker }
154*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,format_to_n)155*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, format_to_n) {
156*5c90c05cSAndroid Build Coastguard Worker std::string s;
157*5c90c05cSAndroid Build Coastguard Worker auto result = fmt::format_to_n(std::back_inserter(s), 1, "{}", 42);
158*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(2u, result.size);
159*5c90c05cSAndroid Build Coastguard Worker char buffer[4] = {0};
160*5c90c05cSAndroid Build Coastguard Worker fmt::format_to_n(buffer, 3, "{}", 12345);
161*5c90c05cSAndroid Build Coastguard Worker
162*5c90c05cSAndroid Build Coastguard Worker std::wstring w;
163*5c90c05cSAndroid Build Coastguard Worker auto wresult = fmt::format_to_n(std::back_inserter(w), 1, L"{}", 42);
164*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(2u, wresult.size);
165*5c90c05cSAndroid Build Coastguard Worker wchar_t wbuffer[4] = {0};
166*5c90c05cSAndroid Build Coastguard Worker fmt::format_to_n(wbuffer, 3, L"{}", 12345);
167*5c90c05cSAndroid Build Coastguard Worker }
168*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,format_args)169*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, format_args) {
170*5c90c05cSAndroid Build Coastguard Worker auto no_args = fmt::format_args();
171*5c90c05cSAndroid Build Coastguard Worker EXPECT_FALSE(no_args.get(1));
172*5c90c05cSAndroid Build Coastguard Worker
173*5c90c05cSAndroid Build Coastguard Worker fmt::basic_format_args args = fmt::make_format_args(42);
174*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(args.max_size() > 0);
175*5c90c05cSAndroid Build Coastguard Worker auto arg0 = args.get(0);
176*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(arg0);
177*5c90c05cSAndroid Build Coastguard Worker decltype(arg0) arg_none;
178*5c90c05cSAndroid Build Coastguard Worker EXPECT_FALSE(arg_none);
179*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(arg0.type() != arg_none.type());
180*5c90c05cSAndroid Build Coastguard Worker }
181*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,wformat_args)182*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, wformat_args) {
183*5c90c05cSAndroid Build Coastguard Worker auto no_args = fmt::wformat_args();
184*5c90c05cSAndroid Build Coastguard Worker EXPECT_FALSE(no_args.get(1));
185*5c90c05cSAndroid Build Coastguard Worker fmt::basic_format_args args = fmt::make_wformat_args(42);
186*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(args.get(0));
187*5c90c05cSAndroid Build Coastguard Worker }
188*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,dynamic_format_args)189*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, dynamic_format_args) {
190*5c90c05cSAndroid Build Coastguard Worker fmt::dynamic_format_arg_store<fmt::format_context> dyn_store;
191*5c90c05cSAndroid Build Coastguard Worker dyn_store.push_back(fmt::arg("a42", 42));
192*5c90c05cSAndroid Build Coastguard Worker fmt::basic_format_args args = dyn_store;
193*5c90c05cSAndroid Build Coastguard Worker EXPECT_FALSE(args.get(3));
194*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(args.get(fmt::string_view("a42")));
195*5c90c05cSAndroid Build Coastguard Worker
196*5c90c05cSAndroid Build Coastguard Worker fmt::dynamic_format_arg_store<fmt::wformat_context> wdyn_store;
197*5c90c05cSAndroid Build Coastguard Worker wdyn_store.push_back(fmt::arg(L"a42", 42));
198*5c90c05cSAndroid Build Coastguard Worker fmt::basic_format_args wargs = wdyn_store;
199*5c90c05cSAndroid Build Coastguard Worker EXPECT_FALSE(wargs.get(3));
200*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(wargs.get(fmt::wstring_view(L"a42")));
201*5c90c05cSAndroid Build Coastguard Worker }
202*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,vformat)203*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, vformat) {
204*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::vformat("{}", fmt::make_format_args(42)));
205*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42",
206*5c90c05cSAndroid Build Coastguard Worker fmt::vformat(fmt::wstring_view(L"{}"), fmt::make_wformat_args(42)));
207*5c90c05cSAndroid Build Coastguard Worker }
208*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,vformat_to)209*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, vformat_to) {
210*5c90c05cSAndroid Build Coastguard Worker auto store = fmt::make_format_args(42);
211*5c90c05cSAndroid Build Coastguard Worker std::string s;
212*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to(std::back_inserter(s), "{}", store);
213*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", s);
214*5c90c05cSAndroid Build Coastguard Worker
215*5c90c05cSAndroid Build Coastguard Worker char buffer[4] = {0};
216*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to(buffer, "{:}", store);
217*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", std::string_view(buffer));
218*5c90c05cSAndroid Build Coastguard Worker
219*5c90c05cSAndroid Build Coastguard Worker auto wstore = fmt::make_wformat_args(42);
220*5c90c05cSAndroid Build Coastguard Worker std::wstring w;
221*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to(std::back_inserter(w), L"{}", wstore);
222*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", w);
223*5c90c05cSAndroid Build Coastguard Worker
224*5c90c05cSAndroid Build Coastguard Worker wchar_t wbuffer[4] = {0};
225*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to(wbuffer, L"{:}", wstore);
226*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", std::wstring_view(wbuffer));
227*5c90c05cSAndroid Build Coastguard Worker }
228*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,vformat_to_n)229*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, vformat_to_n) {
230*5c90c05cSAndroid Build Coastguard Worker auto store = fmt::make_format_args(12345);
231*5c90c05cSAndroid Build Coastguard Worker std::string s;
232*5c90c05cSAndroid Build Coastguard Worker auto result = fmt::vformat_to_n(std::back_inserter(s), 1, "{}", store);
233*5c90c05cSAndroid Build Coastguard Worker char buffer[4] = {0};
234*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to_n(buffer, 3, "{:}", store);
235*5c90c05cSAndroid Build Coastguard Worker
236*5c90c05cSAndroid Build Coastguard Worker auto wstore = fmt::make_wformat_args(12345);
237*5c90c05cSAndroid Build Coastguard Worker std::wstring w;
238*5c90c05cSAndroid Build Coastguard Worker auto wresult = fmt::vformat_to_n(std::back_inserter(w), 1,
239*5c90c05cSAndroid Build Coastguard Worker fmt::wstring_view(L"{}"), wstore);
240*5c90c05cSAndroid Build Coastguard Worker wchar_t wbuffer[4] = {0};
241*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to_n(wbuffer, 3, fmt::wstring_view(L"{:}"), wstore);
242*5c90c05cSAndroid Build Coastguard Worker }
243*5c90c05cSAndroid Build Coastguard Worker
as_string(std::wstring_view text)244*5c90c05cSAndroid Build Coastguard Worker std::string as_string(std::wstring_view text) {
245*5c90c05cSAndroid Build Coastguard Worker return {reinterpret_cast<const char*>(text.data()),
246*5c90c05cSAndroid Build Coastguard Worker text.size() * sizeof(text[0])};
247*5c90c05cSAndroid Build Coastguard Worker }
248*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,print)249*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, print) {
250*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::print("{}µ", 42), "42µ");
251*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::print(stderr, "{}µ", 4.2), "4.2µ");
252*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::print(L"{}µ", 42), as_string(L"42µ"));
253*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::print(stderr, L"{}µ", 4.2), as_string(L"4.2µ"));
254*5c90c05cSAndroid Build Coastguard Worker }
255*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,vprint)256*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, vprint) {
257*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::vprint("{:}µ", fmt::make_format_args(42)), "42µ");
258*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::vprint(stderr, "{}", fmt::make_format_args(4.2)),
259*5c90c05cSAndroid Build Coastguard Worker "4.2");
260*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::vprint(L"{:}µ", fmt::make_wformat_args(42)),
261*5c90c05cSAndroid Build Coastguard Worker as_string(L"42µ"));
262*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::vprint(stderr, L"{}", fmt::make_wformat_args(42)),
263*5c90c05cSAndroid Build Coastguard Worker as_string(L"42"));
264*5c90c05cSAndroid Build Coastguard Worker }
265*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,named_args)266*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, named_args) {
267*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::format("{answer}", fmt::arg("answer", 42)));
268*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::format(L"{answer}", fmt::arg(L"answer", 42)));
269*5c90c05cSAndroid Build Coastguard Worker }
270*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,literals)271*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, literals) {
272*5c90c05cSAndroid Build Coastguard Worker using namespace fmt::literals;
273*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::format("{answer}", "answer"_a = 42));
274*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::format(L"{answer}", L"answer"_a = 42));
275*5c90c05cSAndroid Build Coastguard Worker }
276*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,locale)277*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, locale) {
278*5c90c05cSAndroid Build Coastguard Worker auto store = fmt::make_format_args(4.2);
279*5c90c05cSAndroid Build Coastguard Worker const auto classic = std::locale::classic();
280*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("4.2", fmt::format(classic, "{:L}", 4.2));
281*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("4.2", fmt::vformat(classic, "{:L}", store));
282*5c90c05cSAndroid Build Coastguard Worker std::string s;
283*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to(std::back_inserter(s), classic, "{:L}", store);
284*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("4.2", s);
285*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("4.2", fmt::format("{:L}", 4.2));
286*5c90c05cSAndroid Build Coastguard Worker
287*5c90c05cSAndroid Build Coastguard Worker auto wstore = fmt::make_wformat_args(4.2);
288*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"4.2", fmt::format(classic, L"{:L}", 4.2));
289*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"4.2", fmt::vformat(classic, L"{:L}", wstore));
290*5c90c05cSAndroid Build Coastguard Worker std::wstring w;
291*5c90c05cSAndroid Build Coastguard Worker fmt::vformat_to(std::back_inserter(w), classic, L"{:L}", wstore);
292*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"4.2", w);
293*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"4.2", fmt::format(L"{:L}", 4.2));
294*5c90c05cSAndroid Build Coastguard Worker }
295*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,string_view)296*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, string_view) {
297*5c90c05cSAndroid Build Coastguard Worker fmt::string_view nsv("fmt");
298*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("fmt", nsv);
299*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::string_view("fmt") == nsv);
300*5c90c05cSAndroid Build Coastguard Worker
301*5c90c05cSAndroid Build Coastguard Worker fmt::wstring_view wsv(L"fmt");
302*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"fmt", wsv);
303*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::wstring_view(L"fmt") == wsv);
304*5c90c05cSAndroid Build Coastguard Worker }
305*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,memory_buffer)306*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, memory_buffer) {
307*5c90c05cSAndroid Build Coastguard Worker fmt::basic_memory_buffer<char, fmt::inline_buffer_size> buffer;
308*5c90c05cSAndroid Build Coastguard Worker fmt::format_to(std::back_inserter(buffer), "{}", "42");
309*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", to_string(buffer));
310*5c90c05cSAndroid Build Coastguard Worker fmt::memory_buffer nbuffer(std::move(buffer));
311*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", to_string(nbuffer));
312*5c90c05cSAndroid Build Coastguard Worker buffer = std::move(nbuffer);
313*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", to_string(buffer));
314*5c90c05cSAndroid Build Coastguard Worker nbuffer.clear();
315*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(0u, to_string(nbuffer).size());
316*5c90c05cSAndroid Build Coastguard Worker
317*5c90c05cSAndroid Build Coastguard Worker fmt::wmemory_buffer wbuffer;
318*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(0u, to_string(wbuffer).size());
319*5c90c05cSAndroid Build Coastguard Worker }
320*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,is_char)321*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, is_char) {
322*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::is_char<char>());
323*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::is_char<wchar_t>());
324*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::is_char<char8_t>());
325*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::is_char<char16_t>());
326*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::is_char<char32_t>());
327*5c90c05cSAndroid Build Coastguard Worker EXPECT_FALSE(fmt::is_char<signed char>());
328*5c90c05cSAndroid Build Coastguard Worker }
329*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,ptr)330*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, ptr) {
331*5c90c05cSAndroid Build Coastguard Worker uintptr_t answer = 42;
332*5c90c05cSAndroid Build Coastguard Worker auto p = std::bit_cast<int*>(answer);
333*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("0x2a", fmt::to_string(fmt::ptr(p)));
334*5c90c05cSAndroid Build Coastguard Worker std::unique_ptr<int> up(p);
335*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("0x2a", fmt::to_string(fmt::ptr(up)));
336*5c90c05cSAndroid Build Coastguard Worker up.release();
337*5c90c05cSAndroid Build Coastguard Worker auto sp = std::make_shared<int>(0);
338*5c90c05cSAndroid Build Coastguard Worker p = sp.get();
339*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(fmt::to_string(fmt::ptr(p)), fmt::to_string(fmt::ptr(sp)));
340*5c90c05cSAndroid Build Coastguard Worker }
341*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,errors)342*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, errors) {
343*5c90c05cSAndroid Build Coastguard Worker auto store = fmt::make_format_args(42);
344*5c90c05cSAndroid Build Coastguard Worker EXPECT_THROW(throw fmt::format_error("oops"), std::exception);
345*5c90c05cSAndroid Build Coastguard Worker EXPECT_THROW(throw fmt::vsystem_error(0, "{}", store), std::system_error);
346*5c90c05cSAndroid Build Coastguard Worker EXPECT_THROW(throw fmt::system_error(0, "{}", 42), std::system_error);
347*5c90c05cSAndroid Build Coastguard Worker
348*5c90c05cSAndroid Build Coastguard Worker fmt::memory_buffer buffer;
349*5c90c05cSAndroid Build Coastguard Worker fmt::format_system_error(buffer, 0, "oops");
350*5c90c05cSAndroid Build Coastguard Worker auto oops = to_string(buffer);
351*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(oops.size() > 0);
352*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::report_system_error(0, "oops"), oops + '\n');
353*5c90c05cSAndroid Build Coastguard Worker
354*5c90c05cSAndroid Build Coastguard Worker #ifdef _WIN32
355*5c90c05cSAndroid Build Coastguard Worker EXPECT_THROW(throw fmt::vwindows_error(0, "{}", store), std::system_error);
356*5c90c05cSAndroid Build Coastguard Worker EXPECT_THROW(throw fmt::windows_error(0, "{}", 42), std::system_error);
357*5c90c05cSAndroid Build Coastguard Worker output_redirect redirect(stderr);
358*5c90c05cSAndroid Build Coastguard Worker fmt::report_windows_error(0, "oops");
359*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(redirect.restore_and_read().size() > 0);
360*5c90c05cSAndroid Build Coastguard Worker #endif
361*5c90c05cSAndroid Build Coastguard Worker }
362*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,error_code)363*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, error_code) {
364*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("generic:42",
365*5c90c05cSAndroid Build Coastguard Worker fmt::format("{0}", std::error_code(42, std::generic_category())));
366*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("system:42",
367*5c90c05cSAndroid Build Coastguard Worker fmt::format("{0}", std::error_code(42, fmt::system_category())));
368*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"generic:42",
369*5c90c05cSAndroid Build Coastguard Worker fmt::format(L"{0}", std::error_code(42, std::generic_category())));
370*5c90c05cSAndroid Build Coastguard Worker }
371*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,format_int)372*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, format_int) {
373*5c90c05cSAndroid Build Coastguard Worker fmt::format_int sanswer(42);
374*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::string_view(sanswer.data(), sanswer.size()));
375*5c90c05cSAndroid Build Coastguard Worker fmt::format_int uanswer(42u);
376*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::string_view(uanswer.data(), uanswer.size()));
377*5c90c05cSAndroid Build Coastguard Worker }
378*5c90c05cSAndroid Build Coastguard Worker
379*5c90c05cSAndroid Build Coastguard Worker struct test_formatter : fmt::formatter<char> {
checktest_formatter380*5c90c05cSAndroid Build Coastguard Worker bool check() { return true; }
381*5c90c05cSAndroid Build Coastguard Worker };
382*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,formatter)383*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, formatter) { EXPECT_TRUE(test_formatter{}.check()); }
384*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,join)385*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, join) {
386*5c90c05cSAndroid Build Coastguard Worker int arr[3] = {1, 2, 3};
387*5c90c05cSAndroid Build Coastguard Worker std::vector<double> vec{1.0, 2.0, 3.0};
388*5c90c05cSAndroid Build Coastguard Worker std::initializer_list<int> il{1, 2, 3};
389*5c90c05cSAndroid Build Coastguard Worker auto sep = fmt::string_view(", ");
390*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("1, 2, 3", to_string(fmt::join(arr + 0, arr + 3, sep)));
391*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("1, 2, 3", to_string(fmt::join(arr, sep)));
392*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("1, 2, 3", to_string(fmt::join(vec.begin(), vec.end(), sep)));
393*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("1, 2, 3", to_string(fmt::join(vec, sep)));
394*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("1, 2, 3", to_string(fmt::join(il, sep)));
395*5c90c05cSAndroid Build Coastguard Worker
396*5c90c05cSAndroid Build Coastguard Worker auto wsep = fmt::wstring_view(L", ");
397*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"1, 2, 3", fmt::format(L"{}", fmt::join(arr + 0, arr + 3, wsep)));
398*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"1, 2, 3", fmt::format(L"{}", fmt::join(arr, wsep)));
399*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"1, 2, 3", fmt::format(L"{}", fmt::join(il, wsep)));
400*5c90c05cSAndroid Build Coastguard Worker }
401*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,time)402*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, time) {
403*5c90c05cSAndroid Build Coastguard Worker auto time_now = std::time(nullptr);
404*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::localtime(time_now).tm_year > 120);
405*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::gmtime(time_now).tm_year > 120);
406*5c90c05cSAndroid Build Coastguard Worker auto chrono_now = std::chrono::system_clock::now();
407*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::gmtime(chrono_now).tm_year > 120);
408*5c90c05cSAndroid Build Coastguard Worker }
409*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,time_point)410*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, time_point) {
411*5c90c05cSAndroid Build Coastguard Worker auto now = std::chrono::system_clock::now();
412*5c90c05cSAndroid Build Coastguard Worker std::string_view past("2021-05-20 10:30:15");
413*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(past < fmt::format("{:%Y-%m-%d %H:%M:%S}", now));
414*5c90c05cSAndroid Build Coastguard Worker std::wstring_view wpast(L"2021-05-20 10:30:15");
415*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(wpast < fmt::format(L"{:%Y-%m-%d %H:%M:%S}", now));
416*5c90c05cSAndroid Build Coastguard Worker }
417*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,time_duration)418*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, time_duration) {
419*5c90c05cSAndroid Build Coastguard Worker using us = std::chrono::duration<double, std::micro>;
420*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42s", fmt::format("{}", std::chrono::seconds{42}));
421*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("4.2µs", fmt::format("{:3.1}", us{4.234}));
422*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("4.2µs", fmt::format(std::locale::classic(), "{:L}", us{4.2}));
423*5c90c05cSAndroid Build Coastguard Worker
424*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42s", fmt::format(L"{}", std::chrono::seconds{42}));
425*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"4.2µs", fmt::format(L"{:3.1}", us{4.234}));
426*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"4.2µs", fmt::format(std::locale::classic(), L"{:L}", us{4.2}));
427*5c90c05cSAndroid Build Coastguard Worker }
428*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,weekday)429*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, weekday) {
430*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("Mon", fmt::format(std::locale::classic(), "{}", fmt::weekday(1)));
431*5c90c05cSAndroid Build Coastguard Worker }
432*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,printf)433*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, printf) {
434*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::printf("%f", 42.123456), "42.123456");
435*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::printf("%d", 42), "42");
436*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::printf(L"%f", 42.123456), as_string(L"42.123456"));
437*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::printf(L"%d", 42), as_string(L"42"));
438*5c90c05cSAndroid Build Coastguard Worker }
439*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,fprintf)440*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, fprintf) {
441*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::fprintf(stderr, "%d", 42), "42");
442*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::fprintf(stderr, L"%d", 42), as_string(L"42"));
443*5c90c05cSAndroid Build Coastguard Worker }
444*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,sprintf)445*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, sprintf) {
446*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::sprintf("%d", 42));
447*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::sprintf(L"%d", 42));
448*5c90c05cSAndroid Build Coastguard Worker }
449*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,vprintf)450*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, vprintf) {
451*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::vprintf("%d", fmt::make_printf_args(42)), "42");
452*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stdout, fmt::vprintf(L"%d", fmt::make_wprintf_args(42)),
453*5c90c05cSAndroid Build Coastguard Worker as_string(L"42"));
454*5c90c05cSAndroid Build Coastguard Worker }
455*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,vfprintf)456*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, vfprintf) {
457*5c90c05cSAndroid Build Coastguard Worker auto args = fmt::make_printf_args(42);
458*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::vfprintf(stderr, "%d", args), "42");
459*5c90c05cSAndroid Build Coastguard Worker auto wargs = fmt::make_wprintf_args(42);
460*5c90c05cSAndroid Build Coastguard Worker EXPECT_WRITE(stderr, fmt::vfprintf(stderr, L"%d", wargs), as_string(L"42"));
461*5c90c05cSAndroid Build Coastguard Worker }
462*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,vsprintf)463*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, vsprintf) {
464*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::vsprintf("%d", fmt::make_printf_args(42)));
465*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::vsprintf(L"%d", fmt::make_wprintf_args(42)));
466*5c90c05cSAndroid Build Coastguard Worker }
467*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,color)468*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, color) {
469*5c90c05cSAndroid Build Coastguard Worker auto fg_check = fg(fmt::rgb(255, 200, 30));
470*5c90c05cSAndroid Build Coastguard Worker auto bg_check = bg(fmt::color::dark_slate_gray) | fmt::emphasis::italic;
471*5c90c05cSAndroid Build Coastguard Worker auto emphasis_check = fmt::emphasis::underline | fmt::emphasis::bold;
472*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("\x1B[30m42\x1B[0m",
473*5c90c05cSAndroid Build Coastguard Worker fmt::format(fg(fmt::terminal_color::black), "{}", 42));
474*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"\x1B[30m42\x1B[0m",
475*5c90c05cSAndroid Build Coastguard Worker fmt::format(fg(fmt::terminal_color::black), L"{}", 42));
476*5c90c05cSAndroid Build Coastguard Worker }
477*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,cstring_view)478*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, cstring_view) {
479*5c90c05cSAndroid Build Coastguard Worker auto s = "fmt";
480*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(s, fmt::cstring_view(s).c_str());
481*5c90c05cSAndroid Build Coastguard Worker auto w = L"fmt";
482*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(w, fmt::wcstring_view(w).c_str());
483*5c90c05cSAndroid Build Coastguard Worker }
484*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,buffered_file)485*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, buffered_file) {
486*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(fmt::buffered_file{}.get() == nullptr);
487*5c90c05cSAndroid Build Coastguard Worker }
488*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,output_file)489*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, output_file) {
490*5c90c05cSAndroid Build Coastguard Worker #ifdef __clang__
491*5c90c05cSAndroid Build Coastguard Worker fmt::println("\033[0;33m[=disabled=] {}\033[0;0m",
492*5c90c05cSAndroid Build Coastguard Worker "Clang 16.0 emits multiple copies of vtables");
493*5c90c05cSAndroid Build Coastguard Worker #else
494*5c90c05cSAndroid Build Coastguard Worker fmt::ostream out = fmt::output_file("module-test", fmt::buffer_size = 1);
495*5c90c05cSAndroid Build Coastguard Worker out.close();
496*5c90c05cSAndroid Build Coastguard Worker #endif
497*5c90c05cSAndroid Build Coastguard Worker }
498*5c90c05cSAndroid Build Coastguard Worker
499*5c90c05cSAndroid Build Coastguard Worker struct custom_context {
500*5c90c05cSAndroid Build Coastguard Worker using char_type = char;
501*5c90c05cSAndroid Build Coastguard Worker using parse_context_type = fmt::format_parse_context;
502*5c90c05cSAndroid Build Coastguard Worker };
503*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,custom_context)504*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, custom_context) {
505*5c90c05cSAndroid Build Coastguard Worker fmt::basic_format_arg<custom_context> custom_arg;
506*5c90c05cSAndroid Build Coastguard Worker EXPECT_TRUE(!custom_arg);
507*5c90c05cSAndroid Build Coastguard Worker }
508*5c90c05cSAndroid Build Coastguard Worker
TEST(module_test,compile_format_string)509*5c90c05cSAndroid Build Coastguard Worker TEST(module_test, compile_format_string) {
510*5c90c05cSAndroid Build Coastguard Worker using namespace fmt::literals;
511*5c90c05cSAndroid Build Coastguard Worker #ifdef __clang__
512*5c90c05cSAndroid Build Coastguard Worker fmt::println("\033[0;33m[=disabled=] {}\033[0;0m",
513*5c90c05cSAndroid Build Coastguard Worker "Clang 16.0 fails to import user-defined literals");
514*5c90c05cSAndroid Build Coastguard Worker #else
515*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("42", fmt::format("{0:x}"_cf, 0x42));
516*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L"42", fmt::format(L"{:}"_cf, 42));
517*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ("4.2", fmt::format("{arg:3.1f}"_cf, "arg"_a = 4.2));
518*5c90c05cSAndroid Build Coastguard Worker EXPECT_EQ(L" 42", fmt::format(L"{arg:>3}"_cf, L"arg"_a = L"42"));
519*5c90c05cSAndroid Build Coastguard Worker #endif
520*5c90c05cSAndroid Build Coastguard Worker }
521