From 4570f3e6b0c7e964181ffb4ac2486b223cf80cde Mon Sep 17 00:00:00 2001 From: Ray Speth Date: Mon, 25 Oct 2021 21:27:43 -0400 Subject: [PATCH] [Input] Improve documentation of AnyMap YAML emitters --- src/base/AnyMap.cpp | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/src/base/AnyMap.cpp b/src/base/AnyMap.cpp index 7099d6a1d9..0786b4e0d7 100644 --- a/src/base/AnyMap.cpp +++ b/src/base/AnyMap.cpp @@ -213,6 +213,7 @@ Cantera::AnyValue Empty; namespace YAML { // YAML converters using namespace Cantera; +static const int max_line_length = 87; template<> struct convert { @@ -275,7 +276,9 @@ YAML::Emitter& operator<<(YAML::Emitter& out, const AnyMap& rhs) } if (foundType) { - if (width + name.size() + valueStr.size() + 4 > 87) { + // Check if this item will fit on the current line, including spaces + // for delimiters and whitespace. If not, wrap to the next line. + if (width + name.size() + valueStr.size() + 4 > max_line_length) { out << YAML::Newline; width = 15; } @@ -301,6 +304,10 @@ YAML::Emitter& operator<<(YAML::Emitter& out, const AnyMap& rhs) return out; } +//! Write a vector in YAML "flow" style, wrapping lines to avoid exceeding the +//! preferred maximum line length (set by `max_line_length`). Specialized for +//! `vector` to be able to use the custom `formatDouble` function with +//! a given precision. void emitFlowVector(YAML::Emitter& out, const vector& v, long int precision) { out << YAML::Flow; @@ -308,16 +315,19 @@ void emitFlowVector(YAML::Emitter& out, const vector& v, long int precis size_t width = 15; // wild guess, but no better value is available for (auto& x : v) { string xstr = formatDouble(x, precision); - if (width + xstr.size() > 87) { + // Wrap to the next line if this item would exceed the target line length + if (width + xstr.size() > max_line_length) { out << YAML::Newline; width = 15; } out << xstr; - width += xstr.size() + 2; + width += xstr.size() + 2; // Update width including comma and space } out << YAML::EndSeq; } +//! Write a vector in YAML "flow" style, wrapping lines to avoid exceeding the +//! preferred maximum line length (set by `max_line_length`). template void emitFlowVector(YAML::Emitter& out, const vector& v) { @@ -326,7 +336,8 @@ void emitFlowVector(YAML::Emitter& out, const vector& v) size_t width = 15; // wild guess, but no better value is available for (const auto& x : v) { string xstr = fmt::format("{}", x); - if (width + xstr.size() > 87) { + // Wrap to the next line if this item would exceed the target line length + if (width + xstr.size() > max_line_length) { out << YAML::Newline; width = 15; }