//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11, c++14, c++17, c++20 // UNSUPPORTED: no-threads // UNSUPPORTED: GCC-ALWAYS_INLINE-FIXME // // template // struct formatter; // template // constexpr typename ParseContext::iterator // parse(ParseContext& ctx); // Note this tests the basics of this function. It's tested in more detail in // the format functions test. #include #include #include #include #include #include "test_macros.h" #include "make_string.h" #define SV(S) MAKE_STRING_VIEW(CharT, S) template constexpr void test_parse(StringViewT fmt, std::size_t offset) { using CharT = typename StringViewT::value_type; auto parse_ctx = std::basic_format_parse_context(fmt); std::formatter formatter; static_assert(std::semiregular); std::same_as auto it = formatter.parse(parse_ctx); // std::to_address works around LWG3989 and MSVC STL's iterator debugging mechanism. assert(std::to_address(it) == std::to_address(fmt.end()) - offset); } template constexpr void test_fmt() { test_parse(SV(""), 0); test_parse(SV("1"), 0); test_parse(SV("}"), 1); test_parse(SV("1}"), 1); } constexpr bool test() { test_fmt(); #ifndef TEST_HAS_NO_WIDE_CHARACTERS test_fmt(); #endif return true; } int main(int, char**) { test(); static_assert(test()); return 0; }