annotate lib/xstrtod.c @ 3063:e0287ca43594

*** empty log message ***
author Jim Meyering <jim@meyering.net>
date Tue, 19 Dec 2000 08:16:25 +0000
parents a81cc8789f1f
children ce37d22a271f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
569
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
1 /* xstrtod.c - error-checking interface to strtod
2081
a81cc8789f1f Add #pragma STDC FENV_ACCESS ON if C99.
Jim Meyering <jim@meyering.net>
parents: 1853
diff changeset
2 Copyright (C) 1996, 1999, 2000 Free Software Foundation, Inc.
569
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
3
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
4 This program is free software; you can redistribute it and/or modify
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
5 it under the terms of the GNU General Public License as published by
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
6 the Free Software Foundation; either version 2, or (at your option)
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
7 any later version.
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
8
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
9 This program is distributed in the hope that it will be useful,
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
12 GNU General Public License for more details.
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
13
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
14 You should have received a copy of the GNU General Public License
570
Jim Meyering <jim@meyering.net>
parents: 569
diff changeset
15 along with this program; if not, write to the Free Software Foundation,
Jim Meyering <jim@meyering.net>
parents: 569
diff changeset
16 Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
569
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
17
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
18 /* Written by Jim Meyering. */
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
19
513
Jim Meyering <jim@meyering.net>
parents:
diff changeset
20 #ifdef HAVE_CONFIG_H
653
b63f146fd963 indent cpp-directives
Jim Meyering <jim@meyering.net>
parents: 570
diff changeset
21 # include <config.h>
513
Jim Meyering <jim@meyering.net>
parents:
diff changeset
22 #endif
Jim Meyering <jim@meyering.net>
parents:
diff changeset
23
Jim Meyering <jim@meyering.net>
parents:
diff changeset
24 #ifdef STDC_HEADERS
653
b63f146fd963 indent cpp-directives
Jim Meyering <jim@meyering.net>
parents: 570
diff changeset
25 # include <stdlib.h>
513
Jim Meyering <jim@meyering.net>
parents:
diff changeset
26 #else
Jim Meyering <jim@meyering.net>
parents:
diff changeset
27 double strtod ();
Jim Meyering <jim@meyering.net>
parents:
diff changeset
28 #endif
Jim Meyering <jim@meyering.net>
parents:
diff changeset
29
Jim Meyering <jim@meyering.net>
parents:
diff changeset
30 #include <errno.h>
Jim Meyering <jim@meyering.net>
parents:
diff changeset
31 #include <stdio.h>
Jim Meyering <jim@meyering.net>
parents:
diff changeset
32 #include <limits.h>
Jim Meyering <jim@meyering.net>
parents:
diff changeset
33 #include "xstrtod.h"
Jim Meyering <jim@meyering.net>
parents:
diff changeset
34
2081
a81cc8789f1f Add #pragma STDC FENV_ACCESS ON if C99.
Jim Meyering <jim@meyering.net>
parents: 1853
diff changeset
35 /* Tell the compiler that non-default rounding modes are used. */
a81cc8789f1f Add #pragma STDC FENV_ACCESS ON if C99.
Jim Meyering <jim@meyering.net>
parents: 1853
diff changeset
36 #if 199901 <= __STDC_VERSION__
a81cc8789f1f Add #pragma STDC FENV_ACCESS ON if C99.
Jim Meyering <jim@meyering.net>
parents: 1853
diff changeset
37 #pragma STDC FENV_ACCESS ON
a81cc8789f1f Add #pragma STDC FENV_ACCESS ON if C99.
Jim Meyering <jim@meyering.net>
parents: 1853
diff changeset
38 #endif
a81cc8789f1f Add #pragma STDC FENV_ACCESS ON if C99.
Jim Meyering <jim@meyering.net>
parents: 1853
diff changeset
39
568
Jim Meyering <jim@meyering.net>
parents: 513
diff changeset
40 /* An interface to strtod that encapsulates all the error checking
569
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
41 one should usually perform. Like strtod, but upon successful
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
42 conversion put the result in *RESULT and return zero. Return
Jim Meyering <jim@meyering.net>
parents: 568
diff changeset
43 non-zero and don't modify *RESULT upon any failure. */
568
Jim Meyering <jim@meyering.net>
parents: 513
diff changeset
44
513
Jim Meyering <jim@meyering.net>
parents:
diff changeset
45 int
Jim Meyering <jim@meyering.net>
parents:
diff changeset
46 xstrtod (str, ptr, result)
Jim Meyering <jim@meyering.net>
parents:
diff changeset
47 const char *str;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
48 const char **ptr;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
49 double *result;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
50 {
Jim Meyering <jim@meyering.net>
parents:
diff changeset
51 double val;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
52 char *terminator;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
53 int fail;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
54
Jim Meyering <jim@meyering.net>
parents:
diff changeset
55 fail = 0;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
56 errno = 0;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
57 val = strtod (str, &terminator);
Jim Meyering <jim@meyering.net>
parents:
diff changeset
58
Jim Meyering <jim@meyering.net>
parents:
diff changeset
59 /* Having a non-zero terminator is an error only when PTR is NULL. */
Jim Meyering <jim@meyering.net>
parents:
diff changeset
60 if (terminator == str || (ptr == NULL && *terminator != '\0'))
Jim Meyering <jim@meyering.net>
parents:
diff changeset
61 fail = 1;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
62 else
Jim Meyering <jim@meyering.net>
parents:
diff changeset
63 {
Jim Meyering <jim@meyering.net>
parents:
diff changeset
64 /* Allow underflow (in which case strtod returns zero),
Jim Meyering <jim@meyering.net>
parents:
diff changeset
65 but flag overflow as an error. */
Jim Meyering <jim@meyering.net>
parents:
diff changeset
66 if (val != 0.0 && errno == ERANGE)
Jim Meyering <jim@meyering.net>
parents:
diff changeset
67 fail = 1;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
68 }
Jim Meyering <jim@meyering.net>
parents:
diff changeset
69
Jim Meyering <jim@meyering.net>
parents:
diff changeset
70 if (ptr != NULL)
Jim Meyering <jim@meyering.net>
parents:
diff changeset
71 *ptr = terminator;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
72
Jim Meyering <jim@meyering.net>
parents:
diff changeset
73 *result = val;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
74 return fail;
Jim Meyering <jim@meyering.net>
parents:
diff changeset
75 }