summaryrefslogtreecommitdiffhomepage
path: root/vendor/toml++/impl/toml_formatter.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/toml++/impl/toml_formatter.hpp')
-rw-r--r--vendor/toml++/impl/toml_formatter.hpp266
1 files changed, 131 insertions, 135 deletions
diff --git a/vendor/toml++/impl/toml_formatter.hpp b/vendor/toml++/impl/toml_formatter.hpp
index ffd6325..d307277 100644
--- a/vendor/toml++/impl/toml_formatter.hpp
+++ b/vendor/toml++/impl/toml_formatter.hpp
@@ -1,153 +1,149 @@
-//# This file is a part of toml++ and is subject to the the terms of the MIT license.
-//# Copyright (c) Mark Gillard <mark.gillard@outlook.com.au>
-//# See https://github.com/marzer/tomlplusplus/blob/master/LICENSE for the full license text.
-// SPDX-License-Identifier: MIT
+// # This file is a part of toml++ and is subject to the the terms of the MIT license.
+// # Copyright (c) Mark Gillard <mark.gillard@outlook.com.au>
+// # See https://github.com/marzer/tomlplusplus/blob/master/LICENSE for the full license text.
+// SPDX-License-Identifier: MIT
#pragma once
#include "preprocessor.hpp"
#if TOML_ENABLE_FORMATTERS
-#include "std_vector.hpp"
#include "formatter.hpp"
#include "header_start.hpp"
+#include "std_vector.hpp"
-TOML_NAMESPACE_START
-{
- /// \brief A wrapper for printing TOML objects out to a stream as formatted TOML.
- ///
- /// \availability This class is only available when #TOML_ENABLE_FORMATTERS is enabled.
- ///
- /// \remarks You generally don't need to create an instance of this class explicitly; the stream
- /// operators of the TOML node types already print themselves out using this formatter.
- ///
- /// \detail \cpp
- /// auto tbl = toml::table{
- /// { "description", "This is some TOML, yo." },
- /// { "fruit", toml::array{ "apple", "orange", "pear" } },
- /// { "numbers", toml::array{ 1, 2, 3, 4, 5 } },
- /// { "table", toml::table{ { "foo", "bar" } } }
- /// };
- ///
- /// // these two lines are equivalent:
- /// std::cout << toml::toml_formatter{ tbl } << "\n";
- /// std::cout << tbl << "\n";
- /// \ecpp
- ///
- /// \out
- /// description = "This is some TOML, yo."
- /// fruit = ["apple", "orange", "pear"]
- /// numbers = [1, 2, 3, 4, 5]
- ///
- /// [table]
- /// foo = "bar"
- /// \eout
- class TOML_EXPORTED_CLASS toml_formatter : impl::formatter
- {
- private:
- /// \cond
-
- using base = impl::formatter;
- std::vector<const key*> key_path_;
- bool pending_table_separator_ = false;
-
- TOML_EXPORTED_MEMBER_FUNCTION
- void print_pending_table_separator();
-
- TOML_EXPORTED_MEMBER_FUNCTION
- void print(const key&);
-
- TOML_EXPORTED_MEMBER_FUNCTION
- void print_inline(const toml::table&);
-
- TOML_EXPORTED_MEMBER_FUNCTION
- void print(const toml::array&);
-
- TOML_EXPORTED_MEMBER_FUNCTION
- void print(const toml::table&);
-
- TOML_EXPORTED_MEMBER_FUNCTION
- void print();
-
- static constexpr impl::formatter_constants constants = { format_flags::none, // mandatory
- format_flags::none, // ignored
- "inf"sv,
- "-inf"sv,
- "nan"sv,
- "true"sv,
- "false"sv };
-
- /// \endcond
-
- public:
- /// \brief The default flags for a toml_formatter.
- static constexpr format_flags default_flags = constants.mandatory_flags //
- | format_flags::allow_literal_strings //
- | format_flags::allow_multi_line_strings //
- | format_flags::allow_unicode_strings //
- | format_flags::allow_real_tabs_in_strings //
- | format_flags::allow_binary_integers //
- | format_flags::allow_octal_integers //
- | format_flags::allow_hexadecimal_integers //
- | format_flags::indentation;
-
- /// \brief Constructs a TOML formatter and binds it to a TOML object.
- ///
- /// \param source The source TOML object.
- /// \param flags Format option flags.
- TOML_NODISCARD_CTOR
- explicit toml_formatter(const toml::node& source, format_flags flags = default_flags) noexcept
- : base{ &source, nullptr, constants, { flags, " "sv } }
- {}
+TOML_NAMESPACE_START {
+ /// \brief A wrapper for printing TOML objects out to a stream as formatted TOML.
+ ///
+ /// \availability This class is only available when #TOML_ENABLE_FORMATTERS is enabled.
+ ///
+ /// \remarks You generally don't need to create an instance of this class explicitly; the stream
+ /// operators of the TOML node types already print themselves out using this formatter.
+ ///
+ /// \detail \cpp
+ /// auto tbl = toml::table{
+ /// { "description", "This is some TOML, yo." },
+ /// { "fruit", toml::array{ "apple", "orange", "pear" } },
+ /// { "numbers", toml::array{ 1, 2, 3, 4, 5 } },
+ /// { "table", toml::table{ { "foo", "bar" } } }
+ /// };
+ ///
+ /// // these two lines are equivalent:
+ /// std::cout << toml::toml_formatter{ tbl } << "\n";
+ /// std::cout << tbl << "\n";
+ /// \ecpp
+ ///
+ /// \out
+ /// description = "This is some TOML, yo."
+ /// fruit = ["apple", "orange", "pear"]
+ /// numbers = [1, 2, 3, 4, 5]
+ ///
+ /// [table]
+ /// foo = "bar"
+ /// \eout
+ class TOML_EXPORTED_CLASS toml_formatter : impl::formatter {
+ private:
+ /// \cond
+
+ using base = impl::formatter;
+ std::vector<const key*> key_path_;
+ bool pending_table_separator_ = false;
+
+ TOML_EXPORTED_MEMBER_FUNCTION
+ void print_pending_table_separator();
+
+ TOML_EXPORTED_MEMBER_FUNCTION
+ void print(const key&);
+
+ TOML_EXPORTED_MEMBER_FUNCTION
+ void print_inline(const toml::table&);
+
+ TOML_EXPORTED_MEMBER_FUNCTION
+ void print(const toml::array&);
+
+ TOML_EXPORTED_MEMBER_FUNCTION
+ void print(const toml::table&);
+
+ TOML_EXPORTED_MEMBER_FUNCTION
+ void print();
+
+ static constexpr impl::formatter_constants constants = {format_flags::none, // mandatory
+ format_flags::none, // ignored
+ "inf"sv,
+ "-inf"sv,
+ "nan"sv,
+ "true"sv,
+ "false"sv};
+
+ /// \endcond
+
+ public:
+ /// \brief The default flags for a toml_formatter.
+ static constexpr format_flags default_flags = constants.mandatory_flags //
+ | format_flags::allow_literal_strings //
+ | format_flags::allow_multi_line_strings //
+ | format_flags::allow_unicode_strings //
+ | format_flags::allow_real_tabs_in_strings //
+ | format_flags::allow_binary_integers //
+ | format_flags::allow_octal_integers //
+ | format_flags::allow_hexadecimal_integers //
+ | format_flags::indentation;
+
+ /// \brief Constructs a TOML formatter and binds it to a TOML object.
+ ///
+ /// \param source The source TOML object.
+ /// \param flags Format option flags.
+ TOML_NODISCARD_CTOR
+ explicit toml_formatter(const toml::node& source, format_flags flags = default_flags) noexcept
+ : base{&source, nullptr, constants, {flags, " "sv}} {}
#if TOML_DOXYGEN || (TOML_ENABLE_PARSER && !TOML_EXCEPTIONS)
- /// \brief Constructs a TOML formatter and binds it to a toml::parse_result.
- ///
- /// \availability This constructor is only available when exceptions are disabled.
- ///
- /// \attention Formatting a failed parse result will simply dump the error message out as-is.
- /// This will not be valid TOML, but at least gives you something to log or show up in diagnostics:
- /// \cpp
- /// std::cout << toml::toml_formatter{ toml::parse("a = 'b'"sv) } // ok
- /// << "\n\n"
- /// << toml::toml_formatter{ toml::parse("a = "sv) } // malformed
- /// << "\n";
- /// \ecpp
- /// \out
- /// a = 'b'
- ///
- /// Error while parsing key-value pair: encountered end-of-file
- /// (error occurred at line 1, column 5)
- /// \eout
- /// Use the library with exceptions if you want to avoid this scenario.
- ///
- /// \param result The parse result.
- /// \param flags Format option flags.
- TOML_NODISCARD_CTOR
- explicit toml_formatter(const toml::parse_result& result, format_flags flags = default_flags) noexcept
- : base{ nullptr, &result, constants, { flags, " "sv } }
- {}
+ /// \brief Constructs a TOML formatter and binds it to a toml::parse_result.
+ ///
+ /// \availability This constructor is only available when exceptions are disabled.
+ ///
+ /// \attention Formatting a failed parse result will simply dump the error message out as-is.
+ /// This will not be valid TOML, but at least gives you something to log or show up in
+ ///diagnostics:
+ /// \cpp
+ /// std::cout << toml::toml_formatter{ toml::parse("a = 'b'"sv) } // ok
+ /// << "\n\n"
+ /// << toml::toml_formatter{ toml::parse("a = "sv) } // malformed
+ /// << "\n";
+ /// \ecpp
+ /// \out
+ /// a = 'b'
+ ///
+ /// Error while parsing key-value pair: encountered end-of-file
+ /// (error occurred at line 1, column 5)
+ /// \eout
+ /// Use the library with exceptions if you want to avoid this scenario.
+ ///
+ /// \param result The parse result.
+ /// \param flags Format option flags.
+ TOML_NODISCARD_CTOR
+ explicit toml_formatter(const toml::parse_result& result,
+ format_flags flags = default_flags) noexcept
+ : base{nullptr, &result, constants, {flags, " "sv}} {}
#endif
- /// \brief Prints the bound TOML object out to the stream as formatted TOML.
- friend std::ostream& operator<<(std::ostream& lhs, toml_formatter& rhs)
- {
- rhs.attach(lhs);
- rhs.key_path_.clear();
- rhs.print();
- rhs.detach();
- return lhs;
- }
-
- /// \brief Prints the bound TOML object out to the stream as formatted TOML (rvalue overload).
- friend std::ostream& operator<<(std::ostream& lhs, toml_formatter&& rhs)
- {
- return lhs << rhs; // as lvalue
- }
- };
+ /// \brief Prints the bound TOML object out to the stream as formatted TOML.
+ friend std::ostream& operator<<(std::ostream& lhs, toml_formatter& rhs) {
+ rhs.attach(lhs);
+ rhs.key_path_.clear();
+ rhs.print();
+ rhs.detach();
+ return lhs;
+ }
+
+ /// \brief Prints the bound TOML object out to the stream as formatted TOML (rvalue overload).
+ friend std::ostream& operator<<(std::ostream& lhs, toml_formatter&& rhs) {
+ return lhs << rhs; // as lvalue
+ }
+ };
}
TOML_NAMESPACE_END;
#include "header_end.hpp"
-#endif // TOML_ENABLE_FORMATTERS
+#endif // TOML_ENABLE_FORMATTERS