libexplain  1.4.D001
libexplain/strtod_on_error.c
Go to the documentation of this file.
00001 /*
00002  * libexplain - Explain errno values returned by libc functions
00003  * Copyright (C) 2009, 2010, 2012, 2013 Peter Miller
00004  *
00005  * This program is free software; you can redistribute it and/or modify it
00006  * under the terms of the GNU Lesser General Public License as published by
00007  * the Free Software Foundation; either version 3 of the License, or (at
00008  * your option) any later version.
00009  *
00010  * This program is distributed in the hope that it will be useful,
00011  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00012  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00013  * Lesser General Public License for more details.
00014  *
00015  * You should have received a copy of the GNU Lesser General Public License
00016  * along with this program. If not, see <http://www.gnu.org/licenses/>.
00017  */
00018 
00019 #include <libexplain/ac/errno.h>
00020 #include <libexplain/ac/stdlib.h>
00021 
00022 #include <libexplain/strtod.h>
00023 #include <libexplain/output.h>
00024 
00025 
00026 double
00027 explain_strtod_on_error(const char *nptr, char **endptr)
00028 {
00029     int             hold_errno;
00030     char            *dummy;
00031     double          result;
00032 
00033     dummy = 0;
00034     hold_errno = errno;
00035     errno = 0;
00036     result = strtod(nptr, endptr ? endptr : &dummy);
00037     if (errno == 0 && (endptr ? *endptr : dummy) == nptr)
00038     {
00039         /*
00040          * Some implementations do this natively.
00041          * Fake it on those that don't.
00042          */
00043         errno = EINVAL;
00044     }
00045     if (errno != 0)
00046     {
00047         hold_errno = errno;
00048         explain_output_message
00049         (
00050             explain_errno_strtod(hold_errno, nptr, endptr)
00051         );
00052     }
00053     errno = hold_errno;
00054     return result;
00055 }
00056 
00057 
00058 /* vim: set ts=8 sw=4 et : */