X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fxstrtod.c;h=86e124f2093a43b2719620be6ca8d5762981c742;hb=1d8f627a4e74800e2d2e9ec0a46f7988bd2c7257;hp=8639869f9990845057addcadf141cbf757fbadae;hpb=485eb21c324b8e6a558df69a06e46ca904c33f39;p=gnulib.git diff --git a/lib/xstrtod.c b/lib/xstrtod.c index 8639869f9..86e124f20 100644 --- a/lib/xstrtod.c +++ b/lib/xstrtod.c @@ -1,7 +1,7 @@ /* error-checking interface to strtod-like functions - Copyright (C) 1996, 1999, 2000, 2003, 2004, 2005 Free Software - Foundation, Inc. + Copyright (C) 1996, 1999, 2000, 2003, 2004, 2005, 2006 Free + Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -19,9 +19,7 @@ /* Written by Jim Meyering. */ -#ifdef HAVE_CONFIG_H -# include -#endif +#include #include "xstrtod.h" @@ -29,17 +27,26 @@ #include #include -/* An interface to strtod that encapsulates all the error checking - one should usually perform. Like strtod, but upon successful +#if LONG +# define XSTRTOD xstrtold +# define DOUBLE long double +#else +# define XSTRTOD xstrtod +# define DOUBLE double +#endif + +/* An interface to a string-to-floating-point conversion function that + encapsulates all the error checking one should usually perform. + Like strtod/strtold, but upon successful conversion put the result in *RESULT and return true. Return false and don't modify *RESULT upon any failure. CONVERT specifies the conversion function, e.g., strtod itself. */ bool -xstrtod (char const *str, char const **ptr, double *result, - double (*convert) (char const *, char **)) +XSTRTOD (char const *str, char const **ptr, DOUBLE *result, + DOUBLE (*convert) (char const *, char **)) { - double val; + DOUBLE val; char *terminator; bool ok = true; @@ -51,9 +58,9 @@ xstrtod (char const *str, char const **ptr, double *result, ok = false; else { - /* Allow underflow (in which case strtod returns zero), + /* Allow underflow (in which case CONVERT returns zero), but flag overflow as an error. */ - if (val != 0.0 && errno == ERANGE) + if (val != 0 && errno == ERANGE) ok = false; }