mirror of https://github.com/Icinga/icinga2.git
Merge pull request #8742 from Icinga/bugfix/double-to-string
Convert::ToString(double): handle integral values too large for long long correctly
This commit is contained in:
commit
005fac0a23
|
@ -3,6 +3,7 @@
|
||||||
#include "base/convert.hpp"
|
#include "base/convert.hpp"
|
||||||
#include "base/datetime.hpp"
|
#include "base/datetime.hpp"
|
||||||
#include <boost/lexical_cast.hpp>
|
#include <boost/lexical_cast.hpp>
|
||||||
|
#include <iomanip>
|
||||||
|
|
||||||
using namespace icinga;
|
using namespace icinga;
|
||||||
|
|
||||||
|
@ -21,10 +22,10 @@ String Convert::ToString(double val)
|
||||||
double integral;
|
double integral;
|
||||||
double fractional = std::modf(val, &integral);
|
double fractional = std::modf(val, &integral);
|
||||||
|
|
||||||
if (fractional == 0)
|
|
||||||
return Convert::ToString(static_cast<long long>(val));
|
|
||||||
|
|
||||||
std::ostringstream msgbuf;
|
std::ostringstream msgbuf;
|
||||||
|
if (fractional == 0) {
|
||||||
|
msgbuf << std::setprecision(0);
|
||||||
|
}
|
||||||
msgbuf << std::fixed << val;
|
msgbuf << std::fixed << val;
|
||||||
return msgbuf.str();
|
return msgbuf.str();
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,12 +33,14 @@ BOOST_AUTO_TEST_CASE(tostring)
|
||||||
BOOST_CHECK(Convert::ToString(7) == "7");
|
BOOST_CHECK(Convert::ToString(7) == "7");
|
||||||
BOOST_CHECK(Convert::ToString(7.5) == "7.500000");
|
BOOST_CHECK(Convert::ToString(7.5) == "7.500000");
|
||||||
BOOST_CHECK(Convert::ToString("hello") == "hello");
|
BOOST_CHECK(Convert::ToString("hello") == "hello");
|
||||||
|
BOOST_CHECK(Convert::ToString(18446744073709551616.0) == "18446744073709551616"); // pow(2, 64)
|
||||||
|
|
||||||
String str = "hello";
|
String str = "hello";
|
||||||
BOOST_CHECK(Convert::ToString(str) == "hello");
|
BOOST_CHECK(Convert::ToString(str) == "hello");
|
||||||
|
|
||||||
BOOST_CHECK(Convert::ToString(Value(7)) == "7");
|
BOOST_CHECK(Convert::ToString(Value(7)) == "7");
|
||||||
BOOST_CHECK(Convert::ToString(Value(7.5)) == "7.500000");
|
BOOST_CHECK(Convert::ToString(Value(7.5)) == "7.500000");
|
||||||
|
BOOST_CHECK(Convert::ToString(Value(18446744073709551616.0)) == "18446744073709551616"); // pow(2, 64)
|
||||||
BOOST_CHECK(Convert::ToString(Value("hello")) == "hello");
|
BOOST_CHECK(Convert::ToString(Value("hello")) == "hello");
|
||||||
BOOST_CHECK(Convert::ToString(Value("hello hello")) == "hello hello");
|
BOOST_CHECK(Convert::ToString(Value("hello hello")) == "hello hello");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue