Fix NaN recognition in math parser.

This commit is contained in:
David Tschumperlé 2018-06-09 14:04:45 +02:00 committed by Stefan Haustein
parent bd1410a2fe
commit e3b51a1b15

View File

@ -15508,20 +15508,15 @@ namespace cimg_library_suffixed {
CImgList<ulongT> l_opcode; CImgList<ulongT> l_opcode;
// Look for a single value or a pre-defined variable. // Look for a single value or a pre-defined variable.
int nb = cimg_sscanf(ss,"%lf%c%c",&val,&(sep=0),&(end=0)); int nb = 0;
s = ss + (*ss=='+' || *ss=='-'?1:0);
#if cimg_OS==2 if (*s=='i' || *s=='I' || *s=='n' || *s=='N') { // Particular cases : +/-NaN and +/-Inf
// Check for +/-NaN and +/-inf as Microsoft's sscanf() version is not able is_sth = !(*ss=='-');
// to read those particular values.
if (!nb && (*ss=='+' || *ss=='-' || *ss=='i' || *ss=='I' || *ss=='n' || *ss=='N')) {
is_sth = true;
s = ss;
if (*s=='+') ++s; else if (*s=='-') { ++s; is_sth = false; }
if (!cimg::strcasecmp(s,"inf")) { val = cimg::type<double>::inf(); nb = 1; } if (!cimg::strcasecmp(s,"inf")) { val = cimg::type<double>::inf(); nb = 1; }
else if (!cimg::strcasecmp(s,"nan")) { val = cimg::type<double>::nan(); nb = 1; } else if (!cimg::strcasecmp(s,"nan")) { val = cimg::type<double>::nan(); nb = 1; }
if (nb==1 && !is_sth) val = -val; if (nb==1 && !is_sth) val = -val;
} }
#endif if (!nb) nb = cimg_sscanf(ss,"%lf%c%c",&val,&(sep=0),&(end=0));
if (nb==1) _cimg_mp_constant(val); if (nb==1) _cimg_mp_constant(val);
if (nb==2 && sep=='%') _cimg_mp_constant(val/100); if (nb==2 && sep=='%') _cimg_mp_constant(val/100);
@ -19807,12 +19802,12 @@ namespace cimg_library_suffixed {
unsigned int constant(const double val) { unsigned int constant(const double val) {
// Search for built-in constant. // Search for built-in constant.
if (cimg::type<double>::is_nan(val)) return _cimg_mp_slot_nan;
if (val==(double)(int)val) { if (val==(double)(int)val) {
if (val>=0 && val<=10) return (unsigned int)val; if (val>=0 && val<=10) return (unsigned int)val;
if (val<0 && val>=-5) return (unsigned int)(10 - val); if (val<0 && val>=-5) return (unsigned int)(10 - val);
} }
if (val==0.5) return 16; if (val==0.5) return 16;
if (cimg::type<double>::is_nan(val)) return _cimg_mp_slot_nan;
// Search for constant already requested before (in const cache). // Search for constant already requested before (in const cache).
unsigned int ind = ~0U; unsigned int ind = ~0U;