diff --git a/src/format.hpp b/src/format.hpp index 3d4a25f27..de5c20739 100644 --- a/src/format.hpp +++ b/src/format.hpp @@ -12,6 +12,7 @@ #define FMT_HEADER_ONLY #include +#include #include diff --git a/src/gen/params.cpp b/src/gen/params.cpp index 1806981cc..f22f836ee 100644 --- a/src/gen/params.cpp +++ b/src/gen/params.cpp @@ -14,15 +14,6 @@ #include "overloaded.hpp" #include "pgsql.hpp" -std::string to_string(param_value_t const &value) -{ - return std::visit( - overloaded{[](null_param_t) { return std::string{}; }, - [](std::string val) { return val; }, - [](auto const &val) { return fmt::to_string(val); }}, - value); -} - param_value_t params_t::get(std::string const &key) const { return m_map.at(key); @@ -58,7 +49,7 @@ double params_t::get_double(std::string const &key, double default_value) const return static_cast(std::get(it->second)); } - throw fmt_error("Invalid value '{}' for {}.", to_string(it->second), key); + throw fmt_error("Invalid value '{}' for {}.", it->second, key); } std::string params_t::get_string(std::string const &key) const @@ -67,7 +58,7 @@ std::string params_t::get_string(std::string const &key) const if (it == m_map.end()) { throw fmt_error("Missing parameter '{}' on generalizer.", key); } - return to_string(it->second); + return fmt::format("{}", it->second); } std::string params_t::get_string(std::string const &key, @@ -82,7 +73,7 @@ std::string params_t::get_identifier(std::string const &key) const if (it == m_map.end()) { return {}; } - std::string result = to_string(it->second); + std::string result = fmt::format("{}", it->second); check_identifier(result, key.c_str()); return result; } @@ -94,7 +85,7 @@ void params_t::check_identifier_with_default(std::string const &key, if (it == m_map.end()) { m_map.emplace(key, std::move(default_value)); } else { - check_identifier(to_string(it->second), key.c_str()); + check_identifier(fmt::format("{}", it->second), key.c_str()); } } @@ -120,6 +111,6 @@ void write_to_debug_log(params_t const ¶ms, char const *message) } log_debug("{}", message); for (auto const &[key, value] : params) { - log_debug(" {}={}", key, to_string(value)); + log_debug(" {}={}", key, value); } } diff --git a/src/gen/params.hpp b/src/gen/params.hpp index 174465820..51da49d1a 100644 --- a/src/gen/params.hpp +++ b/src/gen/params.hpp @@ -24,9 +24,6 @@ using null_param_t = std::monostate; using param_value_t = std::variant; -/// Convert a parameter value into a string. -std::string to_string(param_value_t const &value); - /** * A collection of parameters. */ @@ -79,8 +76,7 @@ class params_t } if (!std::holds_alternative(it->second)) { - throw fmt_error("Invalid value '{}' for {}.", to_string(it->second), - key); + throw fmt_error("Invalid value '{}' for {}.", it->second, key); } return std::get(it->second); }