From a571d7f9540ecbf2f31f379f53f8b35a1a275719 Mon Sep 17 00:00:00 2001 From: rubidium Date: Thu, 21 Jun 2007 15:57:14 +0000 Subject: [PATCH] (svn r10252) -Fix: never overflow when applying exchange rates before drawing the amount of money. --- src/strings.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/strings.cpp b/src/strings.cpp index 5ac7133c4f..94c937e4f2 100644 --- a/src/strings.cpp +++ b/src/strings.cpp @@ -340,15 +340,17 @@ static char *FormatTinyDate(char *buff, Date date, const char* last) return FormatString(buff, GetStringPtr(STR_DATE_TINY), args, 0, last); } -static char *FormatGenericCurrency(char *buff, const CurrencySpec *spec, int64 number, bool compact, const char* last) +static char *FormatGenericCurrency(char *buff, const CurrencySpec *spec, Money number, bool compact, const char* last) { const char* multiplier = ""; char buf[40]; char* p; int j; - /* multiply by exchange rate */ - number *= spec->rate; + /* Multiply by exchange rate, but do it safely. */ + CommandCost cs(number); + cs.MultiplyCost(spec->rate); + number = cs.GetCost(); /* convert from negative */ if (number < 0) {