Commit 98ddfacd authored by Milo Yip's avatar Milo Yip

Another try with volatile

parent 58d8d9ab
...@@ -791,8 +791,16 @@ public: ...@@ -791,8 +791,16 @@ public:
// Checks whether a number can be losslessly converted to a double. // Checks whether a number can be losslessly converted to a double.
bool IsLosslessDouble() const { bool IsLosslessDouble() const {
if (!IsNumber()) return false; if (!IsNumber()) return false;
if (IsUint64()) return static_cast<volatile uint64_t>(static_cast<volatile double>(GetUint64())) == GetUint64(); if (IsUint64()) {
if (IsInt64()) return static_cast<volatile int64_t>(static_cast<volatile double>(GetInt64())) == GetInt64(); uint64_t u = GetUint64();
volatile double d = static_cast<double>(u);
return static_cast<uint64_t>(d) == u;
}
if (IsInt64()) {
int64_t i = GetInt64();
volatile double d = static_cast<double>(i);
return static_cast< int64_t>(d) == i;
}
return true; // double, int, uint are always lossless return true; // double, int, uint are always lossless
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment