Skip to content

Commit

Permalink
Refactor: Use fmt builtin functionality to format variants
Browse files Browse the repository at this point in the history
When including the fmt/std.h header the fmt library has support for
formatting std::variant. So we don't need to do this ourselves.
  • Loading branch information
joto committed Dec 12, 2024
1 parent cc0ea60 commit 0ac9189
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 22 deletions.
1 change: 1 addition & 0 deletions src/format.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@

#define FMT_HEADER_ONLY
#include <fmt/format.h>
#include <fmt/std.h>

#include <stdexcept>

Expand Down
6 changes: 3 additions & 3 deletions src/gen/gen-base.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ pg_result_t gen_base_t::dbexec(std::string const &templ)
{
fmt::dynamic_format_arg_store<fmt::format_context> format_store;
for (auto const &[key, value] : get_params()) {
format_store.push_back(fmt::arg(key.c_str(), to_string(value)));
format_store.push_back(fmt::arg(key.c_str(), value));
}
return dbexec_internal(connection(), templ, format_store);
}
Expand All @@ -115,10 +115,10 @@ pg_result_t gen_base_t::dbexec(params_t const &tmp_params,
{
fmt::dynamic_format_arg_store<fmt::format_context> format_store;
for (auto const &[key, value] : get_params()) {
format_store.push_back(fmt::arg(key.c_str(), to_string(value)));
format_store.push_back(fmt::arg(key.c_str(), value));
}
for (auto const &[key, value] : tmp_params) {
format_store.push_back(fmt::arg(key.c_str(), to_string(value)));
format_store.push_back(fmt::arg(key.c_str(), value));
}
return dbexec_internal(connection(), templ, format_store);
}
Expand Down
19 changes: 5 additions & 14 deletions src/gen/params.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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);
Expand Down Expand Up @@ -58,7 +49,7 @@ double params_t::get_double(std::string const &key, double default_value) const
return static_cast<double>(std::get<int64_t>(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
Expand All @@ -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,
Expand All @@ -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;
}
Expand All @@ -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());
}
}

Expand All @@ -120,6 +111,6 @@ void write_to_debug_log(params_t const &params, char const *message)
}
log_debug("{}", message);
for (auto const &[key, value] : params) {
log_debug(" {}={}", key, to_string(value));
log_debug(" {}={}", key, value);
}
}
6 changes: 1 addition & 5 deletions src/gen/params.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,9 +24,6 @@ using null_param_t = std::monostate;
using param_value_t =
std::variant<null_param_t, std::string, int64_t, double, bool>;

/// Convert a parameter value into a string.
std::string to_string(param_value_t const &value);

/**
* A collection of parameters.
*/
Expand Down Expand Up @@ -79,8 +76,7 @@ class params_t
}

if (!std::holds_alternative<T>(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<T>(it->second);
}
Expand Down

0 comments on commit 0ac9189

Please sign in to comment.