Libeval: consistent formatting for NaN

On some platforms like MSVC, NaN prints as "-nan(ind)". This
is a bit needlessly ugly, so print "NaN" on all platforms
consistently.

This fixes a test failure on MSVC.
This commit is contained in:
John Beard 2019-04-08 16:21:21 +01:00
parent 3b194d6993
commit dd17f24c04
2 changed files with 12 additions and 2 deletions

View File

@ -104,7 +104,17 @@ void NUMERIC_EVALUATOR::parseOk()
void NUMERIC_EVALUATOR::parseSetResult( double val )
{
snprintf( m_token.token, m_token.OutLen, "%.10g", val );
if( std::isnan( val ) )
{
// Naively printing this with %g produces "nan" on some platforms
// and "-nan(ind)" on others (e.g. MSVC). So force a "standard" string.
snprintf( m_token.token, m_token.OutLen, "%s", "NaN" );
}
else
{
// Can be printed as a floating point
snprintf( m_token.token, m_token.OutLen, "%.10g", val );
}
}

View File

@ -117,7 +117,7 @@ static const std::vector<EVAL_CASE> eval_cases_valid = {
{ "1.5", "1.5" },
{ "1,5", "1.5" },
// Semicolon is valid, but the result is NaN
{ "1;", "nan" },
{ "1;", "NaN" },
// With own unit
{ "1mm", "1" },
// Unit that's not the evaluator's unit