1*9356374aSAndroid Build Coastguard Worker //
2*9356374aSAndroid Build Coastguard Worker // Copyright 2018 The Abseil Authors.
3*9356374aSAndroid Build Coastguard Worker //
4*9356374aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
5*9356374aSAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
6*9356374aSAndroid Build Coastguard Worker // You may obtain a copy of the License at
7*9356374aSAndroid Build Coastguard Worker //
8*9356374aSAndroid Build Coastguard Worker // https://www.apache.org/licenses/LICENSE-2.0
9*9356374aSAndroid Build Coastguard Worker //
10*9356374aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
11*9356374aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
12*9356374aSAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*9356374aSAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
14*9356374aSAndroid Build Coastguard Worker // limitations under the License.
15*9356374aSAndroid Build Coastguard Worker //
16*9356374aSAndroid Build Coastguard Worker // -----------------------------------------------------------------------------
17*9356374aSAndroid Build Coastguard Worker // File: str_format.h
18*9356374aSAndroid Build Coastguard Worker // -----------------------------------------------------------------------------
19*9356374aSAndroid Build Coastguard Worker //
20*9356374aSAndroid Build Coastguard Worker // The `str_format` library is a typesafe replacement for the family of
21*9356374aSAndroid Build Coastguard Worker // `printf()` string formatting routines within the `<cstdio>` standard library
22*9356374aSAndroid Build Coastguard Worker // header. Like the `printf` family, `str_format` uses a "format string" to
23*9356374aSAndroid Build Coastguard Worker // perform argument substitutions based on types. See the `FormatSpec` section
24*9356374aSAndroid Build Coastguard Worker // below for format string documentation.
25*9356374aSAndroid Build Coastguard Worker //
26*9356374aSAndroid Build Coastguard Worker // Example:
27*9356374aSAndroid Build Coastguard Worker //
28*9356374aSAndroid Build Coastguard Worker // std::string s = absl::StrFormat(
29*9356374aSAndroid Build Coastguard Worker // "%s %s You have $%d!", "Hello", name, dollars);
30*9356374aSAndroid Build Coastguard Worker //
31*9356374aSAndroid Build Coastguard Worker // The library consists of the following basic utilities:
32*9356374aSAndroid Build Coastguard Worker //
33*9356374aSAndroid Build Coastguard Worker // * `absl::StrFormat()`, a type-safe replacement for `std::sprintf()`, to
34*9356374aSAndroid Build Coastguard Worker // write a format string to a `string` value.
35*9356374aSAndroid Build Coastguard Worker // * `absl::StrAppendFormat()` to append a format string to a `string`
36*9356374aSAndroid Build Coastguard Worker // * `absl::StreamFormat()` to more efficiently write a format string to a
37*9356374aSAndroid Build Coastguard Worker // stream, such as`std::cout`.
38*9356374aSAndroid Build Coastguard Worker // * `absl::PrintF()`, `absl::FPrintF()` and `absl::SNPrintF()` as
39*9356374aSAndroid Build Coastguard Worker // drop-in replacements for `std::printf()`, `std::fprintf()` and
40*9356374aSAndroid Build Coastguard Worker // `std::snprintf()`.
41*9356374aSAndroid Build Coastguard Worker //
42*9356374aSAndroid Build Coastguard Worker // Note: An `absl::SPrintF()` drop-in replacement is not supported as it
43*9356374aSAndroid Build Coastguard Worker // is generally unsafe due to buffer overflows. Use `absl::StrFormat` which
44*9356374aSAndroid Build Coastguard Worker // returns the string as output instead of expecting a pre-allocated buffer.
45*9356374aSAndroid Build Coastguard Worker //
46*9356374aSAndroid Build Coastguard Worker // Additionally, you can provide a format string (and its associated arguments)
47*9356374aSAndroid Build Coastguard Worker // using one of the following abstractions:
48*9356374aSAndroid Build Coastguard Worker //
49*9356374aSAndroid Build Coastguard Worker // * A `FormatSpec` class template fully encapsulates a format string and its
50*9356374aSAndroid Build Coastguard Worker // type arguments and is usually provided to `str_format` functions as a
51*9356374aSAndroid Build Coastguard Worker // variadic argument of type `FormatSpec<Arg...>`. The `FormatSpec<Args...>`
52*9356374aSAndroid Build Coastguard Worker // template is evaluated at compile-time, providing type safety.
53*9356374aSAndroid Build Coastguard Worker // * A `ParsedFormat` instance, which encapsulates a specific, pre-compiled
54*9356374aSAndroid Build Coastguard Worker // format string for a specific set of type(s), and which can be passed
55*9356374aSAndroid Build Coastguard Worker // between API boundaries. (The `FormatSpec` type should not be used
56*9356374aSAndroid Build Coastguard Worker // directly except as an argument type for wrapper functions.)
57*9356374aSAndroid Build Coastguard Worker //
58*9356374aSAndroid Build Coastguard Worker // The `str_format` library provides the ability to output its format strings to
59*9356374aSAndroid Build Coastguard Worker // arbitrary sink types:
60*9356374aSAndroid Build Coastguard Worker //
61*9356374aSAndroid Build Coastguard Worker // * A generic `Format()` function to write outputs to arbitrary sink types,
62*9356374aSAndroid Build Coastguard Worker // which must implement a `FormatRawSink` interface.
63*9356374aSAndroid Build Coastguard Worker //
64*9356374aSAndroid Build Coastguard Worker // * A `FormatUntyped()` function that is similar to `Format()` except it is
65*9356374aSAndroid Build Coastguard Worker // loosely typed. `FormatUntyped()` is not a template and does not perform
66*9356374aSAndroid Build Coastguard Worker // any compile-time checking of the format string; instead, it returns a
67*9356374aSAndroid Build Coastguard Worker // boolean from a runtime check.
68*9356374aSAndroid Build Coastguard Worker //
69*9356374aSAndroid Build Coastguard Worker // In addition, the `str_format` library provides extension points for
70*9356374aSAndroid Build Coastguard Worker // augmenting formatting to new types. See "StrFormat Extensions" below.
71*9356374aSAndroid Build Coastguard Worker
72*9356374aSAndroid Build Coastguard Worker #ifndef ABSL_STRINGS_STR_FORMAT_H_
73*9356374aSAndroid Build Coastguard Worker #define ABSL_STRINGS_STR_FORMAT_H_
74*9356374aSAndroid Build Coastguard Worker
75*9356374aSAndroid Build Coastguard Worker #include <cstdint>
76*9356374aSAndroid Build Coastguard Worker #include <cstdio>
77*9356374aSAndroid Build Coastguard Worker #include <string>
78*9356374aSAndroid Build Coastguard Worker #include <type_traits>
79*9356374aSAndroid Build Coastguard Worker
80*9356374aSAndroid Build Coastguard Worker #include "absl/base/attributes.h"
81*9356374aSAndroid Build Coastguard Worker #include "absl/base/config.h"
82*9356374aSAndroid Build Coastguard Worker #include "absl/base/nullability.h"
83*9356374aSAndroid Build Coastguard Worker #include "absl/strings/internal/str_format/arg.h" // IWYU pragma: export
84*9356374aSAndroid Build Coastguard Worker #include "absl/strings/internal/str_format/bind.h" // IWYU pragma: export
85*9356374aSAndroid Build Coastguard Worker #include "absl/strings/internal/str_format/checker.h" // IWYU pragma: export
86*9356374aSAndroid Build Coastguard Worker #include "absl/strings/internal/str_format/extension.h" // IWYU pragma: export
87*9356374aSAndroid Build Coastguard Worker #include "absl/strings/internal/str_format/parser.h" // IWYU pragma: export
88*9356374aSAndroid Build Coastguard Worker #include "absl/strings/string_view.h"
89*9356374aSAndroid Build Coastguard Worker #include "absl/types/span.h"
90*9356374aSAndroid Build Coastguard Worker
91*9356374aSAndroid Build Coastguard Worker namespace absl {
92*9356374aSAndroid Build Coastguard Worker ABSL_NAMESPACE_BEGIN
93*9356374aSAndroid Build Coastguard Worker
94*9356374aSAndroid Build Coastguard Worker // UntypedFormatSpec
95*9356374aSAndroid Build Coastguard Worker //
96*9356374aSAndroid Build Coastguard Worker // A type-erased class that can be used directly within untyped API entry
97*9356374aSAndroid Build Coastguard Worker // points. An `UntypedFormatSpec` is specifically used as an argument to
98*9356374aSAndroid Build Coastguard Worker // `FormatUntyped()`.
99*9356374aSAndroid Build Coastguard Worker //
100*9356374aSAndroid Build Coastguard Worker // Example:
101*9356374aSAndroid Build Coastguard Worker //
102*9356374aSAndroid Build Coastguard Worker // absl::UntypedFormatSpec format("%d");
103*9356374aSAndroid Build Coastguard Worker // std::string out;
104*9356374aSAndroid Build Coastguard Worker // CHECK(absl::FormatUntyped(&out, format, {absl::FormatArg(1)}));
105*9356374aSAndroid Build Coastguard Worker class UntypedFormatSpec {
106*9356374aSAndroid Build Coastguard Worker public:
107*9356374aSAndroid Build Coastguard Worker UntypedFormatSpec() = delete;
108*9356374aSAndroid Build Coastguard Worker UntypedFormatSpec(const UntypedFormatSpec&) = delete;
109*9356374aSAndroid Build Coastguard Worker UntypedFormatSpec& operator=(const UntypedFormatSpec&) = delete;
110*9356374aSAndroid Build Coastguard Worker
UntypedFormatSpec(string_view s)111*9356374aSAndroid Build Coastguard Worker explicit UntypedFormatSpec(string_view s) : spec_(s) {}
112*9356374aSAndroid Build Coastguard Worker
113*9356374aSAndroid Build Coastguard Worker protected:
UntypedFormatSpec(absl::Nonnull<const str_format_internal::ParsedFormatBase * > pc)114*9356374aSAndroid Build Coastguard Worker explicit UntypedFormatSpec(
115*9356374aSAndroid Build Coastguard Worker absl::Nonnull<const str_format_internal::ParsedFormatBase*> pc)
116*9356374aSAndroid Build Coastguard Worker : spec_(pc) {}
117*9356374aSAndroid Build Coastguard Worker
118*9356374aSAndroid Build Coastguard Worker private:
119*9356374aSAndroid Build Coastguard Worker friend str_format_internal::UntypedFormatSpecImpl;
120*9356374aSAndroid Build Coastguard Worker str_format_internal::UntypedFormatSpecImpl spec_;
121*9356374aSAndroid Build Coastguard Worker };
122*9356374aSAndroid Build Coastguard Worker
123*9356374aSAndroid Build Coastguard Worker // FormatStreamed()
124*9356374aSAndroid Build Coastguard Worker //
125*9356374aSAndroid Build Coastguard Worker // Takes a streamable argument and returns an object that can print it
126*9356374aSAndroid Build Coastguard Worker // with '%s'. Allows printing of types that have an `operator<<` but no
127*9356374aSAndroid Build Coastguard Worker // intrinsic type support within `StrFormat()` itself.
128*9356374aSAndroid Build Coastguard Worker //
129*9356374aSAndroid Build Coastguard Worker // Example:
130*9356374aSAndroid Build Coastguard Worker //
131*9356374aSAndroid Build Coastguard Worker // absl::StrFormat("%s", absl::FormatStreamed(obj));
132*9356374aSAndroid Build Coastguard Worker template <typename T>
FormatStreamed(const T & v)133*9356374aSAndroid Build Coastguard Worker str_format_internal::StreamedWrapper<T> FormatStreamed(const T& v) {
134*9356374aSAndroid Build Coastguard Worker return str_format_internal::StreamedWrapper<T>(v);
135*9356374aSAndroid Build Coastguard Worker }
136*9356374aSAndroid Build Coastguard Worker
137*9356374aSAndroid Build Coastguard Worker // FormatCountCapture
138*9356374aSAndroid Build Coastguard Worker //
139*9356374aSAndroid Build Coastguard Worker // This class provides a way to safely wrap `StrFormat()` captures of `%n`
140*9356374aSAndroid Build Coastguard Worker // conversions, which denote the number of characters written by a formatting
141*9356374aSAndroid Build Coastguard Worker // operation to this point, into an integer value.
142*9356374aSAndroid Build Coastguard Worker //
143*9356374aSAndroid Build Coastguard Worker // This wrapper is designed to allow safe usage of `%n` within `StrFormat(); in
144*9356374aSAndroid Build Coastguard Worker // the `printf()` family of functions, `%n` is not safe to use, as the `int *`
145*9356374aSAndroid Build Coastguard Worker // buffer can be used to capture arbitrary data.
146*9356374aSAndroid Build Coastguard Worker //
147*9356374aSAndroid Build Coastguard Worker // Example:
148*9356374aSAndroid Build Coastguard Worker //
149*9356374aSAndroid Build Coastguard Worker // int n = 0;
150*9356374aSAndroid Build Coastguard Worker // std::string s = absl::StrFormat("%s%d%n", "hello", 123,
151*9356374aSAndroid Build Coastguard Worker // absl::FormatCountCapture(&n));
152*9356374aSAndroid Build Coastguard Worker // EXPECT_EQ(8, n);
153*9356374aSAndroid Build Coastguard Worker class FormatCountCapture {
154*9356374aSAndroid Build Coastguard Worker public:
FormatCountCapture(absl::Nonnull<int * > p)155*9356374aSAndroid Build Coastguard Worker explicit FormatCountCapture(absl::Nonnull<int*> p) : p_(p) {}
156*9356374aSAndroid Build Coastguard Worker
157*9356374aSAndroid Build Coastguard Worker private:
158*9356374aSAndroid Build Coastguard Worker // FormatCountCaptureHelper is used to define FormatConvertImpl() for this
159*9356374aSAndroid Build Coastguard Worker // class.
160*9356374aSAndroid Build Coastguard Worker friend struct str_format_internal::FormatCountCaptureHelper;
161*9356374aSAndroid Build Coastguard Worker // Unused() is here because of the false positive from -Wunused-private-field
162*9356374aSAndroid Build Coastguard Worker // p_ is used in the templated function of the friend FormatCountCaptureHelper
163*9356374aSAndroid Build Coastguard Worker // class.
Unused()164*9356374aSAndroid Build Coastguard Worker absl::Nonnull<int*> Unused() { return p_; }
165*9356374aSAndroid Build Coastguard Worker absl::Nonnull<int*> p_;
166*9356374aSAndroid Build Coastguard Worker };
167*9356374aSAndroid Build Coastguard Worker
168*9356374aSAndroid Build Coastguard Worker // FormatSpec
169*9356374aSAndroid Build Coastguard Worker //
170*9356374aSAndroid Build Coastguard Worker // The `FormatSpec` type defines the makeup of a format string within the
171*9356374aSAndroid Build Coastguard Worker // `str_format` library. It is a variadic class template that is evaluated at
172*9356374aSAndroid Build Coastguard Worker // compile-time, according to the format string and arguments that are passed to
173*9356374aSAndroid Build Coastguard Worker // it.
174*9356374aSAndroid Build Coastguard Worker //
175*9356374aSAndroid Build Coastguard Worker // You should not need to manipulate this type directly. You should only name it
176*9356374aSAndroid Build Coastguard Worker // if you are writing wrapper functions which accept format arguments that will
177*9356374aSAndroid Build Coastguard Worker // be provided unmodified to functions in this library. Such a wrapper function
178*9356374aSAndroid Build Coastguard Worker // might be a class method that provides format arguments and/or internally uses
179*9356374aSAndroid Build Coastguard Worker // the result of formatting.
180*9356374aSAndroid Build Coastguard Worker //
181*9356374aSAndroid Build Coastguard Worker // For a `FormatSpec` to be valid at compile-time, it must be provided as
182*9356374aSAndroid Build Coastguard Worker // either:
183*9356374aSAndroid Build Coastguard Worker //
184*9356374aSAndroid Build Coastguard Worker // * A `constexpr` literal or `absl::string_view`, which is how it is most often
185*9356374aSAndroid Build Coastguard Worker // used.
186*9356374aSAndroid Build Coastguard Worker // * A `ParsedFormat` instantiation, which ensures the format string is
187*9356374aSAndroid Build Coastguard Worker // valid before use. (See below.)
188*9356374aSAndroid Build Coastguard Worker //
189*9356374aSAndroid Build Coastguard Worker // Example:
190*9356374aSAndroid Build Coastguard Worker //
191*9356374aSAndroid Build Coastguard Worker // // Provided as a string literal.
192*9356374aSAndroid Build Coastguard Worker // absl::StrFormat("Welcome to %s, Number %d!", "The Village", 6);
193*9356374aSAndroid Build Coastguard Worker //
194*9356374aSAndroid Build Coastguard Worker // // Provided as a constexpr absl::string_view.
195*9356374aSAndroid Build Coastguard Worker // constexpr absl::string_view formatString = "Welcome to %s, Number %d!";
196*9356374aSAndroid Build Coastguard Worker // absl::StrFormat(formatString, "The Village", 6);
197*9356374aSAndroid Build Coastguard Worker //
198*9356374aSAndroid Build Coastguard Worker // // Provided as a pre-compiled ParsedFormat object.
199*9356374aSAndroid Build Coastguard Worker // // Note that this example is useful only for illustration purposes.
200*9356374aSAndroid Build Coastguard Worker // absl::ParsedFormat<'s', 'd'> formatString("Welcome to %s, Number %d!");
201*9356374aSAndroid Build Coastguard Worker // absl::StrFormat(formatString, "TheVillage", 6);
202*9356374aSAndroid Build Coastguard Worker //
203*9356374aSAndroid Build Coastguard Worker // A format string generally follows the POSIX syntax as used within the POSIX
204*9356374aSAndroid Build Coastguard Worker // `printf` specification. (Exceptions are noted below.)
205*9356374aSAndroid Build Coastguard Worker //
206*9356374aSAndroid Build Coastguard Worker // (See http://pubs.opengroup.org/onlinepubs/9699919799/functions/fprintf.html)
207*9356374aSAndroid Build Coastguard Worker //
208*9356374aSAndroid Build Coastguard Worker // In specific, the `FormatSpec` supports the following type specifiers:
209*9356374aSAndroid Build Coastguard Worker // * `c` for characters
210*9356374aSAndroid Build Coastguard Worker // * `s` for strings
211*9356374aSAndroid Build Coastguard Worker // * `d` or `i` for integers
212*9356374aSAndroid Build Coastguard Worker // * `o` for unsigned integer conversions into octal
213*9356374aSAndroid Build Coastguard Worker // * `x` or `X` for unsigned integer conversions into hex
214*9356374aSAndroid Build Coastguard Worker // * `u` for unsigned integers
215*9356374aSAndroid Build Coastguard Worker // * `f` or `F` for floating point values into decimal notation
216*9356374aSAndroid Build Coastguard Worker // * `e` or `E` for floating point values into exponential notation
217*9356374aSAndroid Build Coastguard Worker // * `a` or `A` for floating point values into hex exponential notation
218*9356374aSAndroid Build Coastguard Worker // * `g` or `G` for floating point values into decimal or exponential
219*9356374aSAndroid Build Coastguard Worker // notation based on their precision
220*9356374aSAndroid Build Coastguard Worker // * `p` for pointer address values
221*9356374aSAndroid Build Coastguard Worker // * `n` for the special case of writing out the number of characters
222*9356374aSAndroid Build Coastguard Worker // written to this point. The resulting value must be captured within an
223*9356374aSAndroid Build Coastguard Worker // `absl::FormatCountCapture` type.
224*9356374aSAndroid Build Coastguard Worker // * `v` for values using the default format for a deduced type. These deduced
225*9356374aSAndroid Build Coastguard Worker // types include many of the primitive types denoted here as well as
226*9356374aSAndroid Build Coastguard Worker // user-defined types containing the proper extensions. (See below for more
227*9356374aSAndroid Build Coastguard Worker // information.)
228*9356374aSAndroid Build Coastguard Worker //
229*9356374aSAndroid Build Coastguard Worker // Implementation-defined behavior:
230*9356374aSAndroid Build Coastguard Worker // * A null pointer provided to "%s" or "%p" is output as "(nil)".
231*9356374aSAndroid Build Coastguard Worker // * A non-null pointer provided to "%p" is output in hex as if by %#x or
232*9356374aSAndroid Build Coastguard Worker // %#lx.
233*9356374aSAndroid Build Coastguard Worker //
234*9356374aSAndroid Build Coastguard Worker // NOTE: `o`, `x\X` and `u` will convert signed values to their unsigned
235*9356374aSAndroid Build Coastguard Worker // counterpart before formatting.
236*9356374aSAndroid Build Coastguard Worker //
237*9356374aSAndroid Build Coastguard Worker // Examples:
238*9356374aSAndroid Build Coastguard Worker // "%c", 'a' -> "a"
239*9356374aSAndroid Build Coastguard Worker // "%c", 32 -> " "
240*9356374aSAndroid Build Coastguard Worker // "%s", "C" -> "C"
241*9356374aSAndroid Build Coastguard Worker // "%s", std::string("C++") -> "C++"
242*9356374aSAndroid Build Coastguard Worker // "%d", -10 -> "-10"
243*9356374aSAndroid Build Coastguard Worker // "%o", 10 -> "12"
244*9356374aSAndroid Build Coastguard Worker // "%x", 16 -> "10"
245*9356374aSAndroid Build Coastguard Worker // "%f", 123456789 -> "123456789.000000"
246*9356374aSAndroid Build Coastguard Worker // "%e", .01 -> "1.00000e-2"
247*9356374aSAndroid Build Coastguard Worker // "%a", -3.0 -> "-0x1.8p+1"
248*9356374aSAndroid Build Coastguard Worker // "%g", .01 -> "1e-2"
249*9356374aSAndroid Build Coastguard Worker // "%p", (void*)&value -> "0x7ffdeb6ad2a4"
250*9356374aSAndroid Build Coastguard Worker //
251*9356374aSAndroid Build Coastguard Worker // int n = 0;
252*9356374aSAndroid Build Coastguard Worker // std::string s = absl::StrFormat(
253*9356374aSAndroid Build Coastguard Worker // "%s%d%n", "hello", 123, absl::FormatCountCapture(&n));
254*9356374aSAndroid Build Coastguard Worker // EXPECT_EQ(8, n);
255*9356374aSAndroid Build Coastguard Worker //
256*9356374aSAndroid Build Coastguard Worker // NOTE: the `v` specifier (for "value") is a type specifier not present in the
257*9356374aSAndroid Build Coastguard Worker // POSIX specification. %v will format values according to their deduced type.
258*9356374aSAndroid Build Coastguard Worker // `v` uses `d` for signed integer values, `u` for unsigned integer values, `g`
259*9356374aSAndroid Build Coastguard Worker // for floating point values, and formats boolean values as "true"/"false"
260*9356374aSAndroid Build Coastguard Worker // (instead of 1 or 0 for booleans formatted using d). `const char*` is not
261*9356374aSAndroid Build Coastguard Worker // supported; please use `std::string` and `string_view`. `char` is also not
262*9356374aSAndroid Build Coastguard Worker // supported due to ambiguity of the type. This specifier does not support
263*9356374aSAndroid Build Coastguard Worker // modifiers.
264*9356374aSAndroid Build Coastguard Worker //
265*9356374aSAndroid Build Coastguard Worker // The `FormatSpec` intrinsically supports all of these fundamental C++ types:
266*9356374aSAndroid Build Coastguard Worker //
267*9356374aSAndroid Build Coastguard Worker // * Characters: `char`, `signed char`, `unsigned char`, `wchar_t`
268*9356374aSAndroid Build Coastguard Worker // * Integers: `int`, `short`, `unsigned short`, `unsigned`, `long`,
269*9356374aSAndroid Build Coastguard Worker // `unsigned long`, `long long`, `unsigned long long`
270*9356374aSAndroid Build Coastguard Worker // * Enums: printed as their underlying integral value
271*9356374aSAndroid Build Coastguard Worker // * Floating-point: `float`, `double`, `long double`
272*9356374aSAndroid Build Coastguard Worker //
273*9356374aSAndroid Build Coastguard Worker // However, in the `str_format` library, a format conversion specifies a broader
274*9356374aSAndroid Build Coastguard Worker // C++ conceptual category instead of an exact type. For example, `%s` binds to
275*9356374aSAndroid Build Coastguard Worker // any string-like argument, so `std::string`, `std::wstring`,
276*9356374aSAndroid Build Coastguard Worker // `absl::string_view`, `const char*`, and `const wchar_t*` are all accepted.
277*9356374aSAndroid Build Coastguard Worker // Likewise, `%d` accepts any integer-like argument, etc.
278*9356374aSAndroid Build Coastguard Worker
279*9356374aSAndroid Build Coastguard Worker template <typename... Args>
280*9356374aSAndroid Build Coastguard Worker using FormatSpec = str_format_internal::FormatSpecTemplate<
281*9356374aSAndroid Build Coastguard Worker str_format_internal::ArgumentToConv<Args>()...>;
282*9356374aSAndroid Build Coastguard Worker
283*9356374aSAndroid Build Coastguard Worker // ParsedFormat
284*9356374aSAndroid Build Coastguard Worker //
285*9356374aSAndroid Build Coastguard Worker // A `ParsedFormat` is a class template representing a preparsed `FormatSpec`,
286*9356374aSAndroid Build Coastguard Worker // with template arguments specifying the conversion characters used within the
287*9356374aSAndroid Build Coastguard Worker // format string. Such characters must be valid format type specifiers, and
288*9356374aSAndroid Build Coastguard Worker // these type specifiers are checked at compile-time.
289*9356374aSAndroid Build Coastguard Worker //
290*9356374aSAndroid Build Coastguard Worker // Instances of `ParsedFormat` can be created, copied, and reused to speed up
291*9356374aSAndroid Build Coastguard Worker // formatting loops. A `ParsedFormat` may either be constructed statically, or
292*9356374aSAndroid Build Coastguard Worker // dynamically through its `New()` factory function, which only constructs a
293*9356374aSAndroid Build Coastguard Worker // runtime object if the format is valid at that time.
294*9356374aSAndroid Build Coastguard Worker //
295*9356374aSAndroid Build Coastguard Worker // Example:
296*9356374aSAndroid Build Coastguard Worker //
297*9356374aSAndroid Build Coastguard Worker // // Verified at compile time.
298*9356374aSAndroid Build Coastguard Worker // absl::ParsedFormat<'s', 'd'> format_string("Welcome to %s, Number %d!");
299*9356374aSAndroid Build Coastguard Worker // absl::StrFormat(format_string, "TheVillage", 6);
300*9356374aSAndroid Build Coastguard Worker //
301*9356374aSAndroid Build Coastguard Worker // // Verified at runtime.
302*9356374aSAndroid Build Coastguard Worker // auto format_runtime = absl::ParsedFormat<'d'>::New(format_string);
303*9356374aSAndroid Build Coastguard Worker // if (format_runtime) {
304*9356374aSAndroid Build Coastguard Worker // value = absl::StrFormat(*format_runtime, i);
305*9356374aSAndroid Build Coastguard Worker // } else {
306*9356374aSAndroid Build Coastguard Worker // ... error case ...
307*9356374aSAndroid Build Coastguard Worker // }
308*9356374aSAndroid Build Coastguard Worker
309*9356374aSAndroid Build Coastguard Worker #if defined(__cpp_nontype_template_parameter_auto)
310*9356374aSAndroid Build Coastguard Worker // If C++17 is available, an 'extended' format is also allowed that can specify
311*9356374aSAndroid Build Coastguard Worker // multiple conversion characters per format argument, using a combination of
312*9356374aSAndroid Build Coastguard Worker // `absl::FormatConversionCharSet` enum values (logically a set union)
313*9356374aSAndroid Build Coastguard Worker // via the `|` operator. (Single character-based arguments are still accepted,
314*9356374aSAndroid Build Coastguard Worker // but cannot be combined). Some common conversions also have predefined enum
315*9356374aSAndroid Build Coastguard Worker // values, such as `absl::FormatConversionCharSet::kIntegral`.
316*9356374aSAndroid Build Coastguard Worker //
317*9356374aSAndroid Build Coastguard Worker // Example:
318*9356374aSAndroid Build Coastguard Worker // // Extended format supports multiple conversion characters per argument,
319*9356374aSAndroid Build Coastguard Worker // // specified via a combination of `FormatConversionCharSet` enums.
320*9356374aSAndroid Build Coastguard Worker // using MyFormat = absl::ParsedFormat<absl::FormatConversionCharSet::d |
321*9356374aSAndroid Build Coastguard Worker // absl::FormatConversionCharSet::x>;
322*9356374aSAndroid Build Coastguard Worker // MyFormat GetFormat(bool use_hex) {
323*9356374aSAndroid Build Coastguard Worker // if (use_hex) return MyFormat("foo %x bar");
324*9356374aSAndroid Build Coastguard Worker // return MyFormat("foo %d bar");
325*9356374aSAndroid Build Coastguard Worker // }
326*9356374aSAndroid Build Coastguard Worker // // `format` can be used with any value that supports 'd' and 'x',
327*9356374aSAndroid Build Coastguard Worker // // like `int`.
328*9356374aSAndroid Build Coastguard Worker // auto format = GetFormat(use_hex);
329*9356374aSAndroid Build Coastguard Worker // value = StringF(format, i);
330*9356374aSAndroid Build Coastguard Worker template <auto... Conv>
331*9356374aSAndroid Build Coastguard Worker using ParsedFormat = absl::str_format_internal::ExtendedParsedFormat<
332*9356374aSAndroid Build Coastguard Worker absl::str_format_internal::ToFormatConversionCharSet(Conv)...>;
333*9356374aSAndroid Build Coastguard Worker #else
334*9356374aSAndroid Build Coastguard Worker template <char... Conv>
335*9356374aSAndroid Build Coastguard Worker using ParsedFormat = str_format_internal::ExtendedParsedFormat<
336*9356374aSAndroid Build Coastguard Worker absl::str_format_internal::ToFormatConversionCharSet(Conv)...>;
337*9356374aSAndroid Build Coastguard Worker #endif // defined(__cpp_nontype_template_parameter_auto)
338*9356374aSAndroid Build Coastguard Worker
339*9356374aSAndroid Build Coastguard Worker // StrFormat()
340*9356374aSAndroid Build Coastguard Worker //
341*9356374aSAndroid Build Coastguard Worker // Returns a `string` given a `printf()`-style format string and zero or more
342*9356374aSAndroid Build Coastguard Worker // additional arguments. Use it as you would `sprintf()`. `StrFormat()` is the
343*9356374aSAndroid Build Coastguard Worker // primary formatting function within the `str_format` library, and should be
344*9356374aSAndroid Build Coastguard Worker // used in most cases where you need type-safe conversion of types into
345*9356374aSAndroid Build Coastguard Worker // formatted strings.
346*9356374aSAndroid Build Coastguard Worker //
347*9356374aSAndroid Build Coastguard Worker // The format string generally consists of ordinary character data along with
348*9356374aSAndroid Build Coastguard Worker // one or more format conversion specifiers (denoted by the `%` character).
349*9356374aSAndroid Build Coastguard Worker // Ordinary character data is returned unchanged into the result string, while
350*9356374aSAndroid Build Coastguard Worker // each conversion specification performs a type substitution from
351*9356374aSAndroid Build Coastguard Worker // `StrFormat()`'s other arguments. See the comments for `FormatSpec` for full
352*9356374aSAndroid Build Coastguard Worker // information on the makeup of this format string.
353*9356374aSAndroid Build Coastguard Worker //
354*9356374aSAndroid Build Coastguard Worker // Example:
355*9356374aSAndroid Build Coastguard Worker //
356*9356374aSAndroid Build Coastguard Worker // std::string s = absl::StrFormat(
357*9356374aSAndroid Build Coastguard Worker // "Welcome to %s, Number %d!", "The Village", 6);
358*9356374aSAndroid Build Coastguard Worker // EXPECT_EQ("Welcome to The Village, Number 6!", s);
359*9356374aSAndroid Build Coastguard Worker //
360*9356374aSAndroid Build Coastguard Worker // Returns an empty string in case of error.
361*9356374aSAndroid Build Coastguard Worker template <typename... Args>
StrFormat(const FormatSpec<Args...> & format,const Args &...args)362*9356374aSAndroid Build Coastguard Worker ABSL_MUST_USE_RESULT std::string StrFormat(const FormatSpec<Args...>& format,
363*9356374aSAndroid Build Coastguard Worker const Args&... args) {
364*9356374aSAndroid Build Coastguard Worker return str_format_internal::FormatPack(
365*9356374aSAndroid Build Coastguard Worker str_format_internal::UntypedFormatSpecImpl::Extract(format),
366*9356374aSAndroid Build Coastguard Worker {str_format_internal::FormatArgImpl(args)...});
367*9356374aSAndroid Build Coastguard Worker }
368*9356374aSAndroid Build Coastguard Worker
369*9356374aSAndroid Build Coastguard Worker // StrAppendFormat()
370*9356374aSAndroid Build Coastguard Worker //
371*9356374aSAndroid Build Coastguard Worker // Appends to a `dst` string given a format string, and zero or more additional
372*9356374aSAndroid Build Coastguard Worker // arguments, returning `*dst` as a convenience for chaining purposes. Appends
373*9356374aSAndroid Build Coastguard Worker // nothing in case of error (but possibly alters its capacity).
374*9356374aSAndroid Build Coastguard Worker //
375*9356374aSAndroid Build Coastguard Worker // Example:
376*9356374aSAndroid Build Coastguard Worker //
377*9356374aSAndroid Build Coastguard Worker // std::string orig("For example PI is approximately ");
378*9356374aSAndroid Build Coastguard Worker // std::cout << StrAppendFormat(&orig, "%12.6f", 3.14);
379*9356374aSAndroid Build Coastguard Worker template <typename... Args>
StrAppendFormat(absl::Nonnull<std::string * > dst,const FormatSpec<Args...> & format,const Args &...args)380*9356374aSAndroid Build Coastguard Worker std::string& StrAppendFormat(absl::Nonnull<std::string*> dst,
381*9356374aSAndroid Build Coastguard Worker const FormatSpec<Args...>& format,
382*9356374aSAndroid Build Coastguard Worker const Args&... args) {
383*9356374aSAndroid Build Coastguard Worker return str_format_internal::AppendPack(
384*9356374aSAndroid Build Coastguard Worker dst, str_format_internal::UntypedFormatSpecImpl::Extract(format),
385*9356374aSAndroid Build Coastguard Worker {str_format_internal::FormatArgImpl(args)...});
386*9356374aSAndroid Build Coastguard Worker }
387*9356374aSAndroid Build Coastguard Worker
388*9356374aSAndroid Build Coastguard Worker // StreamFormat()
389*9356374aSAndroid Build Coastguard Worker //
390*9356374aSAndroid Build Coastguard Worker // Writes to an output stream given a format string and zero or more arguments,
391*9356374aSAndroid Build Coastguard Worker // generally in a manner that is more efficient than streaming the result of
392*9356374aSAndroid Build Coastguard Worker // `absl::StrFormat()`. The returned object must be streamed before the full
393*9356374aSAndroid Build Coastguard Worker // expression ends.
394*9356374aSAndroid Build Coastguard Worker //
395*9356374aSAndroid Build Coastguard Worker // Example:
396*9356374aSAndroid Build Coastguard Worker //
397*9356374aSAndroid Build Coastguard Worker // std::cout << StreamFormat("%12.6f", 3.14);
398*9356374aSAndroid Build Coastguard Worker template <typename... Args>
StreamFormat(const FormatSpec<Args...> & format,const Args &...args)399*9356374aSAndroid Build Coastguard Worker ABSL_MUST_USE_RESULT str_format_internal::Streamable StreamFormat(
400*9356374aSAndroid Build Coastguard Worker const FormatSpec<Args...>& format, const Args&... args) {
401*9356374aSAndroid Build Coastguard Worker return str_format_internal::Streamable(
402*9356374aSAndroid Build Coastguard Worker str_format_internal::UntypedFormatSpecImpl::Extract(format),
403*9356374aSAndroid Build Coastguard Worker {str_format_internal::FormatArgImpl(args)...});
404*9356374aSAndroid Build Coastguard Worker }
405*9356374aSAndroid Build Coastguard Worker
406*9356374aSAndroid Build Coastguard Worker // PrintF()
407*9356374aSAndroid Build Coastguard Worker //
408*9356374aSAndroid Build Coastguard Worker // Writes to stdout given a format string and zero or more arguments. This
409*9356374aSAndroid Build Coastguard Worker // function is functionally equivalent to `std::printf()` (and type-safe);
410*9356374aSAndroid Build Coastguard Worker // prefer `absl::PrintF()` over `std::printf()`.
411*9356374aSAndroid Build Coastguard Worker //
412*9356374aSAndroid Build Coastguard Worker // Example:
413*9356374aSAndroid Build Coastguard Worker //
414*9356374aSAndroid Build Coastguard Worker // std::string_view s = "Ulaanbaatar";
415*9356374aSAndroid Build Coastguard Worker // absl::PrintF("The capital of Mongolia is %s", s);
416*9356374aSAndroid Build Coastguard Worker //
417*9356374aSAndroid Build Coastguard Worker // Outputs: "The capital of Mongolia is Ulaanbaatar"
418*9356374aSAndroid Build Coastguard Worker //
419*9356374aSAndroid Build Coastguard Worker template <typename... Args>
PrintF(const FormatSpec<Args...> & format,const Args &...args)420*9356374aSAndroid Build Coastguard Worker int PrintF(const FormatSpec<Args...>& format, const Args&... args) {
421*9356374aSAndroid Build Coastguard Worker return str_format_internal::FprintF(
422*9356374aSAndroid Build Coastguard Worker stdout, str_format_internal::UntypedFormatSpecImpl::Extract(format),
423*9356374aSAndroid Build Coastguard Worker {str_format_internal::FormatArgImpl(args)...});
424*9356374aSAndroid Build Coastguard Worker }
425*9356374aSAndroid Build Coastguard Worker
426*9356374aSAndroid Build Coastguard Worker // FPrintF()
427*9356374aSAndroid Build Coastguard Worker //
428*9356374aSAndroid Build Coastguard Worker // Writes to a file given a format string and zero or more arguments. This
429*9356374aSAndroid Build Coastguard Worker // function is functionally equivalent to `std::fprintf()` (and type-safe);
430*9356374aSAndroid Build Coastguard Worker // prefer `absl::FPrintF()` over `std::fprintf()`.
431*9356374aSAndroid Build Coastguard Worker //
432*9356374aSAndroid Build Coastguard Worker // Example:
433*9356374aSAndroid Build Coastguard Worker //
434*9356374aSAndroid Build Coastguard Worker // std::string_view s = "Ulaanbaatar";
435*9356374aSAndroid Build Coastguard Worker // absl::FPrintF(stdout, "The capital of Mongolia is %s", s);
436*9356374aSAndroid Build Coastguard Worker //
437*9356374aSAndroid Build Coastguard Worker // Outputs: "The capital of Mongolia is Ulaanbaatar"
438*9356374aSAndroid Build Coastguard Worker //
439*9356374aSAndroid Build Coastguard Worker template <typename... Args>
FPrintF(absl::Nonnull<std::FILE * > output,const FormatSpec<Args...> & format,const Args &...args)440*9356374aSAndroid Build Coastguard Worker int FPrintF(absl::Nonnull<std::FILE*> output, const FormatSpec<Args...>& format,
441*9356374aSAndroid Build Coastguard Worker const Args&... args) {
442*9356374aSAndroid Build Coastguard Worker return str_format_internal::FprintF(
443*9356374aSAndroid Build Coastguard Worker output, str_format_internal::UntypedFormatSpecImpl::Extract(format),
444*9356374aSAndroid Build Coastguard Worker {str_format_internal::FormatArgImpl(args)...});
445*9356374aSAndroid Build Coastguard Worker }
446*9356374aSAndroid Build Coastguard Worker
447*9356374aSAndroid Build Coastguard Worker // SNPrintF()
448*9356374aSAndroid Build Coastguard Worker //
449*9356374aSAndroid Build Coastguard Worker // Writes to a sized buffer given a format string and zero or more arguments.
450*9356374aSAndroid Build Coastguard Worker // This function is functionally equivalent to `std::snprintf()` (and
451*9356374aSAndroid Build Coastguard Worker // type-safe); prefer `absl::SNPrintF()` over `std::snprintf()`.
452*9356374aSAndroid Build Coastguard Worker //
453*9356374aSAndroid Build Coastguard Worker // In particular, a successful call to `absl::SNPrintF()` writes at most `size`
454*9356374aSAndroid Build Coastguard Worker // bytes of the formatted output to `output`, including a NUL-terminator, and
455*9356374aSAndroid Build Coastguard Worker // returns the number of bytes that would have been written if truncation did
456*9356374aSAndroid Build Coastguard Worker // not occur. In the event of an error, a negative value is returned and `errno`
457*9356374aSAndroid Build Coastguard Worker // is set.
458*9356374aSAndroid Build Coastguard Worker //
459*9356374aSAndroid Build Coastguard Worker // Example:
460*9356374aSAndroid Build Coastguard Worker //
461*9356374aSAndroid Build Coastguard Worker // std::string_view s = "Ulaanbaatar";
462*9356374aSAndroid Build Coastguard Worker // char output[128];
463*9356374aSAndroid Build Coastguard Worker // absl::SNPrintF(output, sizeof(output),
464*9356374aSAndroid Build Coastguard Worker // "The capital of Mongolia is %s", s);
465*9356374aSAndroid Build Coastguard Worker //
466*9356374aSAndroid Build Coastguard Worker // Post-condition: output == "The capital of Mongolia is Ulaanbaatar"
467*9356374aSAndroid Build Coastguard Worker //
468*9356374aSAndroid Build Coastguard Worker template <typename... Args>
SNPrintF(absl::Nonnull<char * > output,std::size_t size,const FormatSpec<Args...> & format,const Args &...args)469*9356374aSAndroid Build Coastguard Worker int SNPrintF(absl::Nonnull<char*> output, std::size_t size,
470*9356374aSAndroid Build Coastguard Worker const FormatSpec<Args...>& format, const Args&... args) {
471*9356374aSAndroid Build Coastguard Worker return str_format_internal::SnprintF(
472*9356374aSAndroid Build Coastguard Worker output, size, str_format_internal::UntypedFormatSpecImpl::Extract(format),
473*9356374aSAndroid Build Coastguard Worker {str_format_internal::FormatArgImpl(args)...});
474*9356374aSAndroid Build Coastguard Worker }
475*9356374aSAndroid Build Coastguard Worker
476*9356374aSAndroid Build Coastguard Worker // -----------------------------------------------------------------------------
477*9356374aSAndroid Build Coastguard Worker // Custom Output Formatting Functions
478*9356374aSAndroid Build Coastguard Worker // -----------------------------------------------------------------------------
479*9356374aSAndroid Build Coastguard Worker
480*9356374aSAndroid Build Coastguard Worker // FormatRawSink
481*9356374aSAndroid Build Coastguard Worker //
482*9356374aSAndroid Build Coastguard Worker // FormatRawSink is a type erased wrapper around arbitrary sink objects
483*9356374aSAndroid Build Coastguard Worker // specifically used as an argument to `Format()`.
484*9356374aSAndroid Build Coastguard Worker //
485*9356374aSAndroid Build Coastguard Worker // All the object has to do define an overload of `AbslFormatFlush()` for the
486*9356374aSAndroid Build Coastguard Worker // sink, usually by adding a ADL-based free function in the same namespace as
487*9356374aSAndroid Build Coastguard Worker // the sink:
488*9356374aSAndroid Build Coastguard Worker //
489*9356374aSAndroid Build Coastguard Worker // void AbslFormatFlush(MySink* dest, absl::string_view part);
490*9356374aSAndroid Build Coastguard Worker //
491*9356374aSAndroid Build Coastguard Worker // where `dest` is the pointer passed to `absl::Format()`. The function should
492*9356374aSAndroid Build Coastguard Worker // append `part` to `dest`.
493*9356374aSAndroid Build Coastguard Worker //
494*9356374aSAndroid Build Coastguard Worker // FormatRawSink does not own the passed sink object. The passed object must
495*9356374aSAndroid Build Coastguard Worker // outlive the FormatRawSink.
496*9356374aSAndroid Build Coastguard Worker class FormatRawSink {
497*9356374aSAndroid Build Coastguard Worker public:
498*9356374aSAndroid Build Coastguard Worker // Implicitly convert from any type that provides the hook function as
499*9356374aSAndroid Build Coastguard Worker // described above.
500*9356374aSAndroid Build Coastguard Worker template <typename T,
501*9356374aSAndroid Build Coastguard Worker typename = typename std::enable_if<std::is_constructible<
502*9356374aSAndroid Build Coastguard Worker str_format_internal::FormatRawSinkImpl, T*>::value>::type>
FormatRawSink(absl::Nonnull<T * > raw)503*9356374aSAndroid Build Coastguard Worker FormatRawSink(absl::Nonnull<T*> raw) // NOLINT
504*9356374aSAndroid Build Coastguard Worker : sink_(raw) {}
505*9356374aSAndroid Build Coastguard Worker
506*9356374aSAndroid Build Coastguard Worker private:
507*9356374aSAndroid Build Coastguard Worker friend str_format_internal::FormatRawSinkImpl;
508*9356374aSAndroid Build Coastguard Worker str_format_internal::FormatRawSinkImpl sink_;
509*9356374aSAndroid Build Coastguard Worker };
510*9356374aSAndroid Build Coastguard Worker
511*9356374aSAndroid Build Coastguard Worker // Format()
512*9356374aSAndroid Build Coastguard Worker //
513*9356374aSAndroid Build Coastguard Worker // Writes a formatted string to an arbitrary sink object (implementing the
514*9356374aSAndroid Build Coastguard Worker // `absl::FormatRawSink` interface), using a format string and zero or more
515*9356374aSAndroid Build Coastguard Worker // additional arguments.
516*9356374aSAndroid Build Coastguard Worker //
517*9356374aSAndroid Build Coastguard Worker // By default, `std::string`, `std::ostream`, and `absl::Cord` are supported as
518*9356374aSAndroid Build Coastguard Worker // destination objects. If a `std::string` is used the formatted string is
519*9356374aSAndroid Build Coastguard Worker // appended to it.
520*9356374aSAndroid Build Coastguard Worker //
521*9356374aSAndroid Build Coastguard Worker // `absl::Format()` is a generic version of `absl::StrAppendFormat()`, for
522*9356374aSAndroid Build Coastguard Worker // custom sinks. The format string, like format strings for `StrFormat()`, is
523*9356374aSAndroid Build Coastguard Worker // checked at compile-time.
524*9356374aSAndroid Build Coastguard Worker //
525*9356374aSAndroid Build Coastguard Worker // On failure, this function returns `false` and the state of the sink is
526*9356374aSAndroid Build Coastguard Worker // unspecified.
527*9356374aSAndroid Build Coastguard Worker template <typename... Args>
Format(FormatRawSink raw_sink,const FormatSpec<Args...> & format,const Args &...args)528*9356374aSAndroid Build Coastguard Worker bool Format(FormatRawSink raw_sink, const FormatSpec<Args...>& format,
529*9356374aSAndroid Build Coastguard Worker const Args&... args) {
530*9356374aSAndroid Build Coastguard Worker return str_format_internal::FormatUntyped(
531*9356374aSAndroid Build Coastguard Worker str_format_internal::FormatRawSinkImpl::Extract(raw_sink),
532*9356374aSAndroid Build Coastguard Worker str_format_internal::UntypedFormatSpecImpl::Extract(format),
533*9356374aSAndroid Build Coastguard Worker {str_format_internal::FormatArgImpl(args)...});
534*9356374aSAndroid Build Coastguard Worker }
535*9356374aSAndroid Build Coastguard Worker
536*9356374aSAndroid Build Coastguard Worker // FormatArg
537*9356374aSAndroid Build Coastguard Worker //
538*9356374aSAndroid Build Coastguard Worker // A type-erased handle to a format argument specifically used as an argument to
539*9356374aSAndroid Build Coastguard Worker // `FormatUntyped()`. You may construct `FormatArg` by passing
540*9356374aSAndroid Build Coastguard Worker // reference-to-const of any printable type. `FormatArg` is both copyable and
541*9356374aSAndroid Build Coastguard Worker // assignable. The source data must outlive the `FormatArg` instance. See
542*9356374aSAndroid Build Coastguard Worker // example below.
543*9356374aSAndroid Build Coastguard Worker //
544*9356374aSAndroid Build Coastguard Worker using FormatArg = str_format_internal::FormatArgImpl;
545*9356374aSAndroid Build Coastguard Worker
546*9356374aSAndroid Build Coastguard Worker // FormatUntyped()
547*9356374aSAndroid Build Coastguard Worker //
548*9356374aSAndroid Build Coastguard Worker // Writes a formatted string to an arbitrary sink object (implementing the
549*9356374aSAndroid Build Coastguard Worker // `absl::FormatRawSink` interface), using an `UntypedFormatSpec` and zero or
550*9356374aSAndroid Build Coastguard Worker // more additional arguments.
551*9356374aSAndroid Build Coastguard Worker //
552*9356374aSAndroid Build Coastguard Worker // This function acts as the most generic formatting function in the
553*9356374aSAndroid Build Coastguard Worker // `str_format` library. The caller provides a raw sink, an unchecked format
554*9356374aSAndroid Build Coastguard Worker // string, and (usually) a runtime specified list of arguments; no compile-time
555*9356374aSAndroid Build Coastguard Worker // checking of formatting is performed within this function. As a result, a
556*9356374aSAndroid Build Coastguard Worker // caller should check the return value to verify that no error occurred.
557*9356374aSAndroid Build Coastguard Worker // On failure, this function returns `false` and the state of the sink is
558*9356374aSAndroid Build Coastguard Worker // unspecified.
559*9356374aSAndroid Build Coastguard Worker //
560*9356374aSAndroid Build Coastguard Worker // The arguments are provided in an `absl::Span<const absl::FormatArg>`.
561*9356374aSAndroid Build Coastguard Worker // Each `absl::FormatArg` object binds to a single argument and keeps a
562*9356374aSAndroid Build Coastguard Worker // reference to it. The values used to create the `FormatArg` objects must
563*9356374aSAndroid Build Coastguard Worker // outlive this function call.
564*9356374aSAndroid Build Coastguard Worker //
565*9356374aSAndroid Build Coastguard Worker // Example:
566*9356374aSAndroid Build Coastguard Worker //
567*9356374aSAndroid Build Coastguard Worker // std::optional<std::string> FormatDynamic(
568*9356374aSAndroid Build Coastguard Worker // const std::string& in_format,
569*9356374aSAndroid Build Coastguard Worker // const vector<std::string>& in_args) {
570*9356374aSAndroid Build Coastguard Worker // std::string out;
571*9356374aSAndroid Build Coastguard Worker // std::vector<absl::FormatArg> args;
572*9356374aSAndroid Build Coastguard Worker // for (const auto& v : in_args) {
573*9356374aSAndroid Build Coastguard Worker // // It is important that 'v' is a reference to the objects in in_args.
574*9356374aSAndroid Build Coastguard Worker // // The values we pass to FormatArg must outlive the call to
575*9356374aSAndroid Build Coastguard Worker // // FormatUntyped.
576*9356374aSAndroid Build Coastguard Worker // args.emplace_back(v);
577*9356374aSAndroid Build Coastguard Worker // }
578*9356374aSAndroid Build Coastguard Worker // absl::UntypedFormatSpec format(in_format);
579*9356374aSAndroid Build Coastguard Worker // if (!absl::FormatUntyped(&out, format, args)) {
580*9356374aSAndroid Build Coastguard Worker // return std::nullopt;
581*9356374aSAndroid Build Coastguard Worker // }
582*9356374aSAndroid Build Coastguard Worker // return std::move(out);
583*9356374aSAndroid Build Coastguard Worker // }
584*9356374aSAndroid Build Coastguard Worker //
FormatUntyped(FormatRawSink raw_sink,const UntypedFormatSpec & format,absl::Span<const FormatArg> args)585*9356374aSAndroid Build Coastguard Worker ABSL_MUST_USE_RESULT inline bool FormatUntyped(
586*9356374aSAndroid Build Coastguard Worker FormatRawSink raw_sink, const UntypedFormatSpec& format,
587*9356374aSAndroid Build Coastguard Worker absl::Span<const FormatArg> args) {
588*9356374aSAndroid Build Coastguard Worker return str_format_internal::FormatUntyped(
589*9356374aSAndroid Build Coastguard Worker str_format_internal::FormatRawSinkImpl::Extract(raw_sink),
590*9356374aSAndroid Build Coastguard Worker str_format_internal::UntypedFormatSpecImpl::Extract(format), args);
591*9356374aSAndroid Build Coastguard Worker }
592*9356374aSAndroid Build Coastguard Worker
593*9356374aSAndroid Build Coastguard Worker //------------------------------------------------------------------------------
594*9356374aSAndroid Build Coastguard Worker // StrFormat Extensions
595*9356374aSAndroid Build Coastguard Worker //------------------------------------------------------------------------------
596*9356374aSAndroid Build Coastguard Worker //
597*9356374aSAndroid Build Coastguard Worker // AbslStringify()
598*9356374aSAndroid Build Coastguard Worker //
599*9356374aSAndroid Build Coastguard Worker // A simpler customization API for formatting user-defined types using
600*9356374aSAndroid Build Coastguard Worker // absl::StrFormat(). The API relies on detecting an overload in the
601*9356374aSAndroid Build Coastguard Worker // user-defined type's namespace of a free (non-member) `AbslStringify()`
602*9356374aSAndroid Build Coastguard Worker // function as a friend definition with the following signature:
603*9356374aSAndroid Build Coastguard Worker //
604*9356374aSAndroid Build Coastguard Worker // template <typename Sink>
605*9356374aSAndroid Build Coastguard Worker // void AbslStringify(Sink& sink, const X& value);
606*9356374aSAndroid Build Coastguard Worker //
607*9356374aSAndroid Build Coastguard Worker // An `AbslStringify()` overload for a type should only be declared in the same
608*9356374aSAndroid Build Coastguard Worker // file and namespace as said type.
609*9356374aSAndroid Build Coastguard Worker //
610*9356374aSAndroid Build Coastguard Worker // Note that unlike with AbslFormatConvert(), AbslStringify() does not allow
611*9356374aSAndroid Build Coastguard Worker // customization of allowed conversion characters. AbslStringify() uses `%v` as
612*9356374aSAndroid Build Coastguard Worker // the underlying conversion specififer. Additionally, AbslStringify() supports
613*9356374aSAndroid Build Coastguard Worker // use with absl::StrCat while AbslFormatConvert() does not.
614*9356374aSAndroid Build Coastguard Worker //
615*9356374aSAndroid Build Coastguard Worker // Example:
616*9356374aSAndroid Build Coastguard Worker //
617*9356374aSAndroid Build Coastguard Worker // struct Point {
618*9356374aSAndroid Build Coastguard Worker // // To add formatting support to `Point`, we simply need to add a free
619*9356374aSAndroid Build Coastguard Worker // // (non-member) function `AbslStringify()`. This method prints in the
620*9356374aSAndroid Build Coastguard Worker // // request format using the underlying `%v` specifier. You can add such a
621*9356374aSAndroid Build Coastguard Worker // // free function using a friend declaration within the body of the class.
622*9356374aSAndroid Build Coastguard Worker // // The sink parameter is a templated type to avoid requiring dependencies.
623*9356374aSAndroid Build Coastguard Worker // template <typename Sink>
624*9356374aSAndroid Build Coastguard Worker // friend void AbslStringify(Sink& sink, const Point& p) {
625*9356374aSAndroid Build Coastguard Worker // absl::Format(&sink, "(%v, %v)", p.x, p.y);
626*9356374aSAndroid Build Coastguard Worker // }
627*9356374aSAndroid Build Coastguard Worker //
628*9356374aSAndroid Build Coastguard Worker // int x;
629*9356374aSAndroid Build Coastguard Worker // int y;
630*9356374aSAndroid Build Coastguard Worker // };
631*9356374aSAndroid Build Coastguard Worker //
632*9356374aSAndroid Build Coastguard Worker // AbslFormatConvert()
633*9356374aSAndroid Build Coastguard Worker //
634*9356374aSAndroid Build Coastguard Worker // The StrFormat library provides a customization API for formatting
635*9356374aSAndroid Build Coastguard Worker // user-defined types using absl::StrFormat(). The API relies on detecting an
636*9356374aSAndroid Build Coastguard Worker // overload in the user-defined type's namespace of a free (non-member)
637*9356374aSAndroid Build Coastguard Worker // `AbslFormatConvert()` function, usually as a friend definition with the
638*9356374aSAndroid Build Coastguard Worker // following signature:
639*9356374aSAndroid Build Coastguard Worker //
640*9356374aSAndroid Build Coastguard Worker // absl::FormatConvertResult<...> AbslFormatConvert(
641*9356374aSAndroid Build Coastguard Worker // const X& value,
642*9356374aSAndroid Build Coastguard Worker // const absl::FormatConversionSpec& spec,
643*9356374aSAndroid Build Coastguard Worker // absl::FormatSink *sink);
644*9356374aSAndroid Build Coastguard Worker //
645*9356374aSAndroid Build Coastguard Worker // An `AbslFormatConvert()` overload for a type should only be declared in the
646*9356374aSAndroid Build Coastguard Worker // same file and namespace as said type.
647*9356374aSAndroid Build Coastguard Worker //
648*9356374aSAndroid Build Coastguard Worker // The abstractions within this definition include:
649*9356374aSAndroid Build Coastguard Worker //
650*9356374aSAndroid Build Coastguard Worker // * An `absl::FormatConversionSpec` to specify the fields to pull from a
651*9356374aSAndroid Build Coastguard Worker // user-defined type's format string
652*9356374aSAndroid Build Coastguard Worker // * An `absl::FormatSink` to hold the converted string data during the
653*9356374aSAndroid Build Coastguard Worker // conversion process.
654*9356374aSAndroid Build Coastguard Worker // * An `absl::FormatConvertResult` to hold the status of the returned
655*9356374aSAndroid Build Coastguard Worker // formatting operation
656*9356374aSAndroid Build Coastguard Worker //
657*9356374aSAndroid Build Coastguard Worker // The return type encodes all the conversion characters that your
658*9356374aSAndroid Build Coastguard Worker // AbslFormatConvert() routine accepts. The return value should be {true}.
659*9356374aSAndroid Build Coastguard Worker // A return value of {false} will result in `StrFormat()` returning
660*9356374aSAndroid Build Coastguard Worker // an empty string. This result will be propagated to the result of
661*9356374aSAndroid Build Coastguard Worker // `FormatUntyped`.
662*9356374aSAndroid Build Coastguard Worker //
663*9356374aSAndroid Build Coastguard Worker // Example:
664*9356374aSAndroid Build Coastguard Worker //
665*9356374aSAndroid Build Coastguard Worker // struct Point {
666*9356374aSAndroid Build Coastguard Worker // // To add formatting support to `Point`, we simply need to add a free
667*9356374aSAndroid Build Coastguard Worker // // (non-member) function `AbslFormatConvert()`. This method interprets
668*9356374aSAndroid Build Coastguard Worker // // `spec` to print in the request format. The allowed conversion characters
669*9356374aSAndroid Build Coastguard Worker // // can be restricted via the type of the result, in this example
670*9356374aSAndroid Build Coastguard Worker // // string and integral formatting are allowed (but not, for instance
671*9356374aSAndroid Build Coastguard Worker // // floating point characters like "%f"). You can add such a free function
672*9356374aSAndroid Build Coastguard Worker // // using a friend declaration within the body of the class:
673*9356374aSAndroid Build Coastguard Worker // friend absl::FormatConvertResult<absl::FormatConversionCharSet::kString |
674*9356374aSAndroid Build Coastguard Worker // absl::FormatConversionCharSet::kIntegral>
675*9356374aSAndroid Build Coastguard Worker // AbslFormatConvert(const Point& p, const absl::FormatConversionSpec& spec,
676*9356374aSAndroid Build Coastguard Worker // absl::FormatSink* s) {
677*9356374aSAndroid Build Coastguard Worker // if (spec.conversion_char() == absl::FormatConversionChar::s) {
678*9356374aSAndroid Build Coastguard Worker // absl::Format(s, "x=%vy=%v", p.x, p.y);
679*9356374aSAndroid Build Coastguard Worker // } else {
680*9356374aSAndroid Build Coastguard Worker // absl::Format(s, "%v,%v", p.x, p.y);
681*9356374aSAndroid Build Coastguard Worker // }
682*9356374aSAndroid Build Coastguard Worker // return {true};
683*9356374aSAndroid Build Coastguard Worker // }
684*9356374aSAndroid Build Coastguard Worker //
685*9356374aSAndroid Build Coastguard Worker // int x;
686*9356374aSAndroid Build Coastguard Worker // int y;
687*9356374aSAndroid Build Coastguard Worker // };
688*9356374aSAndroid Build Coastguard Worker
689*9356374aSAndroid Build Coastguard Worker // clang-format off
690*9356374aSAndroid Build Coastguard Worker
691*9356374aSAndroid Build Coastguard Worker // FormatConversionChar
692*9356374aSAndroid Build Coastguard Worker //
693*9356374aSAndroid Build Coastguard Worker // Specifies the formatting character provided in the format string
694*9356374aSAndroid Build Coastguard Worker // passed to `StrFormat()`.
695*9356374aSAndroid Build Coastguard Worker enum class FormatConversionChar : uint8_t {
696*9356374aSAndroid Build Coastguard Worker c, s, // text
697*9356374aSAndroid Build Coastguard Worker d, i, o, u, x, X, // int
698*9356374aSAndroid Build Coastguard Worker f, F, e, E, g, G, a, A, // float
699*9356374aSAndroid Build Coastguard Worker n, p, v // misc
700*9356374aSAndroid Build Coastguard Worker };
701*9356374aSAndroid Build Coastguard Worker // clang-format on
702*9356374aSAndroid Build Coastguard Worker
703*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec
704*9356374aSAndroid Build Coastguard Worker //
705*9356374aSAndroid Build Coastguard Worker // Specifies modifications to the conversion of the format string, through use
706*9356374aSAndroid Build Coastguard Worker // of one or more format flags in the source format string.
707*9356374aSAndroid Build Coastguard Worker class FormatConversionSpec {
708*9356374aSAndroid Build Coastguard Worker public:
709*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::is_basic()
710*9356374aSAndroid Build Coastguard Worker //
711*9356374aSAndroid Build Coastguard Worker // Indicates that width and precision are not specified, and no additional
712*9356374aSAndroid Build Coastguard Worker // flags are set for this conversion character in the format string.
is_basic()713*9356374aSAndroid Build Coastguard Worker bool is_basic() const { return impl_.is_basic(); }
714*9356374aSAndroid Build Coastguard Worker
715*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::has_left_flag()
716*9356374aSAndroid Build Coastguard Worker //
717*9356374aSAndroid Build Coastguard Worker // Indicates whether the result should be left justified for this conversion
718*9356374aSAndroid Build Coastguard Worker // character in the format string. This flag is set through use of a '-'
719*9356374aSAndroid Build Coastguard Worker // character in the format string. E.g. "%-s"
has_left_flag()720*9356374aSAndroid Build Coastguard Worker bool has_left_flag() const { return impl_.has_left_flag(); }
721*9356374aSAndroid Build Coastguard Worker
722*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::has_show_pos_flag()
723*9356374aSAndroid Build Coastguard Worker //
724*9356374aSAndroid Build Coastguard Worker // Indicates whether a sign column is prepended to the result for this
725*9356374aSAndroid Build Coastguard Worker // conversion character in the format string, even if the result is positive.
726*9356374aSAndroid Build Coastguard Worker // This flag is set through use of a '+' character in the format string.
727*9356374aSAndroid Build Coastguard Worker // E.g. "%+d"
has_show_pos_flag()728*9356374aSAndroid Build Coastguard Worker bool has_show_pos_flag() const { return impl_.has_show_pos_flag(); }
729*9356374aSAndroid Build Coastguard Worker
730*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::has_sign_col_flag()
731*9356374aSAndroid Build Coastguard Worker //
732*9356374aSAndroid Build Coastguard Worker // Indicates whether a mandatory sign column is added to the result for this
733*9356374aSAndroid Build Coastguard Worker // conversion character. This flag is set through use of a space character
734*9356374aSAndroid Build Coastguard Worker // (' ') in the format string. E.g. "% i"
has_sign_col_flag()735*9356374aSAndroid Build Coastguard Worker bool has_sign_col_flag() const { return impl_.has_sign_col_flag(); }
736*9356374aSAndroid Build Coastguard Worker
737*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::has_alt_flag()
738*9356374aSAndroid Build Coastguard Worker //
739*9356374aSAndroid Build Coastguard Worker // Indicates whether an "alternate" format is applied to the result for this
740*9356374aSAndroid Build Coastguard Worker // conversion character. Alternative forms depend on the type of conversion
741*9356374aSAndroid Build Coastguard Worker // character, and unallowed alternatives are undefined. This flag is set
742*9356374aSAndroid Build Coastguard Worker // through use of a '#' character in the format string. E.g. "%#h"
has_alt_flag()743*9356374aSAndroid Build Coastguard Worker bool has_alt_flag() const { return impl_.has_alt_flag(); }
744*9356374aSAndroid Build Coastguard Worker
745*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::has_zero_flag()
746*9356374aSAndroid Build Coastguard Worker //
747*9356374aSAndroid Build Coastguard Worker // Indicates whether zeroes should be prepended to the result for this
748*9356374aSAndroid Build Coastguard Worker // conversion character instead of spaces. This flag is set through use of the
749*9356374aSAndroid Build Coastguard Worker // '0' character in the format string. E.g. "%0f"
has_zero_flag()750*9356374aSAndroid Build Coastguard Worker bool has_zero_flag() const { return impl_.has_zero_flag(); }
751*9356374aSAndroid Build Coastguard Worker
752*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::conversion_char()
753*9356374aSAndroid Build Coastguard Worker //
754*9356374aSAndroid Build Coastguard Worker // Returns the underlying conversion character.
conversion_char()755*9356374aSAndroid Build Coastguard Worker FormatConversionChar conversion_char() const {
756*9356374aSAndroid Build Coastguard Worker return impl_.conversion_char();
757*9356374aSAndroid Build Coastguard Worker }
758*9356374aSAndroid Build Coastguard Worker
759*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::width()
760*9356374aSAndroid Build Coastguard Worker //
761*9356374aSAndroid Build Coastguard Worker // Returns the specified width (indicated through use of a non-zero integer
762*9356374aSAndroid Build Coastguard Worker // value or '*' character) of the conversion character. If width is
763*9356374aSAndroid Build Coastguard Worker // unspecified, it returns a negative value.
width()764*9356374aSAndroid Build Coastguard Worker int width() const { return impl_.width(); }
765*9356374aSAndroid Build Coastguard Worker
766*9356374aSAndroid Build Coastguard Worker // FormatConversionSpec::precision()
767*9356374aSAndroid Build Coastguard Worker //
768*9356374aSAndroid Build Coastguard Worker // Returns the specified precision (through use of the '.' character followed
769*9356374aSAndroid Build Coastguard Worker // by a non-zero integer value or '*' character) of the conversion character.
770*9356374aSAndroid Build Coastguard Worker // If precision is unspecified, it returns a negative value.
precision()771*9356374aSAndroid Build Coastguard Worker int precision() const { return impl_.precision(); }
772*9356374aSAndroid Build Coastguard Worker
773*9356374aSAndroid Build Coastguard Worker private:
FormatConversionSpec(str_format_internal::FormatConversionSpecImpl impl)774*9356374aSAndroid Build Coastguard Worker explicit FormatConversionSpec(
775*9356374aSAndroid Build Coastguard Worker str_format_internal::FormatConversionSpecImpl impl)
776*9356374aSAndroid Build Coastguard Worker : impl_(impl) {}
777*9356374aSAndroid Build Coastguard Worker
778*9356374aSAndroid Build Coastguard Worker friend str_format_internal::FormatConversionSpecImpl;
779*9356374aSAndroid Build Coastguard Worker
780*9356374aSAndroid Build Coastguard Worker absl::str_format_internal::FormatConversionSpecImpl impl_;
781*9356374aSAndroid Build Coastguard Worker };
782*9356374aSAndroid Build Coastguard Worker
783*9356374aSAndroid Build Coastguard Worker // Type safe OR operator for FormatConversionCharSet to allow accepting multiple
784*9356374aSAndroid Build Coastguard Worker // conversion chars in custom format converters.
785*9356374aSAndroid Build Coastguard Worker constexpr FormatConversionCharSet operator|(FormatConversionCharSet a,
786*9356374aSAndroid Build Coastguard Worker FormatConversionCharSet b) {
787*9356374aSAndroid Build Coastguard Worker return static_cast<FormatConversionCharSet>(static_cast<uint64_t>(a) |
788*9356374aSAndroid Build Coastguard Worker static_cast<uint64_t>(b));
789*9356374aSAndroid Build Coastguard Worker }
790*9356374aSAndroid Build Coastguard Worker
791*9356374aSAndroid Build Coastguard Worker // FormatConversionCharSet
792*9356374aSAndroid Build Coastguard Worker //
793*9356374aSAndroid Build Coastguard Worker // Specifies the _accepted_ conversion types as a template parameter to
794*9356374aSAndroid Build Coastguard Worker // FormatConvertResult for custom implementations of `AbslFormatConvert`.
795*9356374aSAndroid Build Coastguard Worker // Note the helper predefined alias definitions (kIntegral, etc.) below.
796*9356374aSAndroid Build Coastguard Worker enum class FormatConversionCharSet : uint64_t {
797*9356374aSAndroid Build Coastguard Worker // text
798*9356374aSAndroid Build Coastguard Worker c = str_format_internal::FormatConversionCharToConvInt('c'),
799*9356374aSAndroid Build Coastguard Worker s = str_format_internal::FormatConversionCharToConvInt('s'),
800*9356374aSAndroid Build Coastguard Worker // integer
801*9356374aSAndroid Build Coastguard Worker d = str_format_internal::FormatConversionCharToConvInt('d'),
802*9356374aSAndroid Build Coastguard Worker i = str_format_internal::FormatConversionCharToConvInt('i'),
803*9356374aSAndroid Build Coastguard Worker o = str_format_internal::FormatConversionCharToConvInt('o'),
804*9356374aSAndroid Build Coastguard Worker u = str_format_internal::FormatConversionCharToConvInt('u'),
805*9356374aSAndroid Build Coastguard Worker x = str_format_internal::FormatConversionCharToConvInt('x'),
806*9356374aSAndroid Build Coastguard Worker X = str_format_internal::FormatConversionCharToConvInt('X'),
807*9356374aSAndroid Build Coastguard Worker // Float
808*9356374aSAndroid Build Coastguard Worker f = str_format_internal::FormatConversionCharToConvInt('f'),
809*9356374aSAndroid Build Coastguard Worker F = str_format_internal::FormatConversionCharToConvInt('F'),
810*9356374aSAndroid Build Coastguard Worker e = str_format_internal::FormatConversionCharToConvInt('e'),
811*9356374aSAndroid Build Coastguard Worker E = str_format_internal::FormatConversionCharToConvInt('E'),
812*9356374aSAndroid Build Coastguard Worker g = str_format_internal::FormatConversionCharToConvInt('g'),
813*9356374aSAndroid Build Coastguard Worker G = str_format_internal::FormatConversionCharToConvInt('G'),
814*9356374aSAndroid Build Coastguard Worker a = str_format_internal::FormatConversionCharToConvInt('a'),
815*9356374aSAndroid Build Coastguard Worker A = str_format_internal::FormatConversionCharToConvInt('A'),
816*9356374aSAndroid Build Coastguard Worker // misc
817*9356374aSAndroid Build Coastguard Worker n = str_format_internal::FormatConversionCharToConvInt('n'),
818*9356374aSAndroid Build Coastguard Worker p = str_format_internal::FormatConversionCharToConvInt('p'),
819*9356374aSAndroid Build Coastguard Worker v = str_format_internal::FormatConversionCharToConvInt('v'),
820*9356374aSAndroid Build Coastguard Worker
821*9356374aSAndroid Build Coastguard Worker // Used for width/precision '*' specification.
822*9356374aSAndroid Build Coastguard Worker kStar = static_cast<uint64_t>(
823*9356374aSAndroid Build Coastguard Worker absl::str_format_internal::FormatConversionCharSetInternal::kStar),
824*9356374aSAndroid Build Coastguard Worker // Some predefined values:
825*9356374aSAndroid Build Coastguard Worker kIntegral = d | i | u | o | x | X,
826*9356374aSAndroid Build Coastguard Worker kFloating = a | e | f | g | A | E | F | G,
827*9356374aSAndroid Build Coastguard Worker kNumeric = kIntegral | kFloating,
828*9356374aSAndroid Build Coastguard Worker kString = s,
829*9356374aSAndroid Build Coastguard Worker kPointer = p,
830*9356374aSAndroid Build Coastguard Worker };
831*9356374aSAndroid Build Coastguard Worker
832*9356374aSAndroid Build Coastguard Worker // FormatSink
833*9356374aSAndroid Build Coastguard Worker //
834*9356374aSAndroid Build Coastguard Worker // A format sink is a generic abstraction to which conversions may write their
835*9356374aSAndroid Build Coastguard Worker // formatted string data. `absl::FormatConvert()` uses this sink to write its
836*9356374aSAndroid Build Coastguard Worker // formatted string.
837*9356374aSAndroid Build Coastguard Worker //
838*9356374aSAndroid Build Coastguard Worker class FormatSink {
839*9356374aSAndroid Build Coastguard Worker public:
840*9356374aSAndroid Build Coastguard Worker // FormatSink::Append()
841*9356374aSAndroid Build Coastguard Worker //
842*9356374aSAndroid Build Coastguard Worker // Appends `count` copies of `ch` to the format sink.
Append(size_t count,char ch)843*9356374aSAndroid Build Coastguard Worker void Append(size_t count, char ch) { sink_->Append(count, ch); }
844*9356374aSAndroid Build Coastguard Worker
845*9356374aSAndroid Build Coastguard Worker // Overload of FormatSink::Append() for appending the characters of a string
846*9356374aSAndroid Build Coastguard Worker // view to a format sink.
Append(string_view v)847*9356374aSAndroid Build Coastguard Worker void Append(string_view v) { sink_->Append(v); }
848*9356374aSAndroid Build Coastguard Worker
849*9356374aSAndroid Build Coastguard Worker // FormatSink::PutPaddedString()
850*9356374aSAndroid Build Coastguard Worker //
851*9356374aSAndroid Build Coastguard Worker // Appends `precision` number of bytes of `v` to the format sink. If this is
852*9356374aSAndroid Build Coastguard Worker // less than `width`, spaces will be appended first (if `left` is false), or
853*9356374aSAndroid Build Coastguard Worker // after (if `left` is true) to ensure the total amount appended is
854*9356374aSAndroid Build Coastguard Worker // at least `width`.
PutPaddedString(string_view v,int width,int precision,bool left)855*9356374aSAndroid Build Coastguard Worker bool PutPaddedString(string_view v, int width, int precision, bool left) {
856*9356374aSAndroid Build Coastguard Worker return sink_->PutPaddedString(v, width, precision, left);
857*9356374aSAndroid Build Coastguard Worker }
858*9356374aSAndroid Build Coastguard Worker
859*9356374aSAndroid Build Coastguard Worker // Support `absl::Format(&sink, format, args...)`.
AbslFormatFlush(absl::Nonnull<FormatSink * > sink,absl::string_view v)860*9356374aSAndroid Build Coastguard Worker friend void AbslFormatFlush(absl::Nonnull<FormatSink*> sink,
861*9356374aSAndroid Build Coastguard Worker absl::string_view v) {
862*9356374aSAndroid Build Coastguard Worker sink->Append(v);
863*9356374aSAndroid Build Coastguard Worker }
864*9356374aSAndroid Build Coastguard Worker
865*9356374aSAndroid Build Coastguard Worker private:
866*9356374aSAndroid Build Coastguard Worker friend str_format_internal::FormatSinkImpl;
FormatSink(absl::Nonnull<str_format_internal::FormatSinkImpl * > s)867*9356374aSAndroid Build Coastguard Worker explicit FormatSink(absl::Nonnull<str_format_internal::FormatSinkImpl*> s)
868*9356374aSAndroid Build Coastguard Worker : sink_(s) {}
869*9356374aSAndroid Build Coastguard Worker absl::Nonnull<str_format_internal::FormatSinkImpl*> sink_;
870*9356374aSAndroid Build Coastguard Worker };
871*9356374aSAndroid Build Coastguard Worker
872*9356374aSAndroid Build Coastguard Worker // FormatConvertResult
873*9356374aSAndroid Build Coastguard Worker //
874*9356374aSAndroid Build Coastguard Worker // Indicates whether a call to AbslFormatConvert() was successful.
875*9356374aSAndroid Build Coastguard Worker // This return type informs the StrFormat extension framework (through
876*9356374aSAndroid Build Coastguard Worker // ADL but using the return type) of what conversion characters are supported.
877*9356374aSAndroid Build Coastguard Worker // It is strongly discouraged to return {false}, as this will result in an
878*9356374aSAndroid Build Coastguard Worker // empty string in StrFormat.
879*9356374aSAndroid Build Coastguard Worker template <FormatConversionCharSet C>
880*9356374aSAndroid Build Coastguard Worker struct FormatConvertResult {
881*9356374aSAndroid Build Coastguard Worker bool value;
882*9356374aSAndroid Build Coastguard Worker };
883*9356374aSAndroid Build Coastguard Worker
884*9356374aSAndroid Build Coastguard Worker ABSL_NAMESPACE_END
885*9356374aSAndroid Build Coastguard Worker } // namespace absl
886*9356374aSAndroid Build Coastguard Worker
887*9356374aSAndroid Build Coastguard Worker #endif // ABSL_STRINGS_STR_FORMAT_H_
888