fast_atof: If a literal ends with a trailing dot (.), only parse further if the next character is a digit. In cases where the dot ends the literal (i.e. "1.") this would cause strtoul10_64 to throw an exception. To preserve as much of the old behaviour, we still consume trailing dots though. This "regression" was introduced (exposed) by #261, which added the extra check to strtoul10_64 that triggered here. This commit now fixes #304 (IFC file reading broken due to IFC files containing "(1.,1.,1.)" lists.
parent
7e48c1cce9
commit
2edccb7f34
|
@ -231,13 +231,13 @@ inline const char* fast_atoreal_move( const char* c, Real& out, bool check_comma
|
||||||
{
|
{
|
||||||
Real f;
|
Real f;
|
||||||
|
|
||||||
bool inv = (*c=='-');
|
bool inv = (*c == '-');
|
||||||
if (inv || *c=='+') {
|
if (inv || *c == '+') {
|
||||||
++c;
|
++c;
|
||||||
}
|
}
|
||||||
|
|
||||||
f = static_cast<Real>( strtoul10_64 ( c, &c) );
|
f = static_cast<Real>( strtoul10_64 ( c, &c) );
|
||||||
if (*c == '.' || (check_comma && c[0] == ',' && c[1] >= '0' && c[1] <= '9')) // allow for commas, too
|
if ((*c == '.' || (check_comma && c[0] == ',')) && c[1] >= '0' && c[1] <= '9')
|
||||||
{
|
{
|
||||||
++c;
|
++c;
|
||||||
|
|
||||||
|
@ -255,6 +255,10 @@ inline const char* fast_atoreal_move( const char* c, Real& out, bool check_comma
|
||||||
pl *= fast_atof_table[diff];
|
pl *= fast_atof_table[diff];
|
||||||
f += static_cast<Real>( pl );
|
f += static_cast<Real>( pl );
|
||||||
}
|
}
|
||||||
|
// For backwards compatibility: eat trailing dots, but not trailing commas.
|
||||||
|
else if (*c == '.') {
|
||||||
|
++c;
|
||||||
|
}
|
||||||
|
|
||||||
// A major 'E' must be allowed. Necessary for proper reading of some DXF files.
|
// A major 'E' must be allowed. Necessary for proper reading of some DXF files.
|
||||||
// Thanks to Zhao Lei to point out that this if() must be outside the if (*c == '.' ..)
|
// Thanks to Zhao Lei to point out that this if() must be outside the if (*c == '.' ..)
|
||||||
|
|
Loading…
Reference in New Issue