Skip to content

Commit

Permalink
fixup... use an unordered_map to substitute in numeric format string
Browse files Browse the repository at this point in the history
  • Loading branch information
christopherlam committed Apr 13, 2024
1 parent e86d4a9 commit d180161
Showing 1 changed file with 31 additions and 6 deletions.
37 changes: 31 additions & 6 deletions libgnucash/app-utils/gnc-ui-util.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1500,18 +1500,43 @@ gnc_wrap_text_with_bidi_ltr_isolate (const char* text)
/********************************************************************\
********************************************************************/

using StrStrVec = std::vector<std::pair<std::string, std::string>>;

static std::string
string_replace_substring (const std::string& input, const StrStrVec& replacements)
{
std::string result = input;
for (const auto& [key, val] : replacements)
for (auto pos = result.find(key); pos != std::string::npos; pos = result.find(key))
result.replace(pos, key.length(), val);
return result;
}

template <typename T>
static std::string num_to_words (T num)
{
std::ostringstream ss;
ss.imbue(gnc_get_boost_locale());
ss << boost::locale::as::spellout << num;
return ss.str();
}

static std::string
number_to_words(double val, int64_t denom)
{
double int_part;
const int frac_part = std::round(std::modf (std::fabs(val), &int_part) * denom);
const std::vector<std::string> tail =
{ " ", _("and"), " ", std::to_string (frac_part), "/", std::to_string (denom) };
std::ostringstream ss;

ss.imbue(gnc_get_boost_locale());
ss << boost::locale::as::spellout << int_part;
return std::accumulate (tail.begin(), tail.end(), ss.str());
StrStrVec replacements = {
{"{int_part}", num_to_words<double>(int_part)},
{"{frac_part}", num_to_words<int> (frac_part)},
{"{value}", num_to_words<double>(val)},
{"{int_part_num}", std::to_string (int_part)},
{"{frac_part_num}", std::to_string (frac_part)},
{"{denom_num}", std::to_string (denom)},
};

return string_replace_substring("{int_part} and {frac_part_num}/{denom_num}", replacements);
}

#ifdef _MSC_VER
Expand Down

0 comments on commit d180161

Please sign in to comment.