Warn for type mismatch for gmx printf like functions 2/3
[gromacs.git] / src / gromacs / utility / strconvert.cpp
blobc59dd01100144dc1493c46ae5df9eba2981e12dc
1 /*
2 * This file is part of the GROMACS molecular simulation package.
4 * Copyright (c) 2016,2018, by the GROMACS development team, led by
5 * Mark Abraham, David van der Spoel, Berk Hess, and Erik Lindahl,
6 * and including many others, as listed in the AUTHORS file in the
7 * top-level source directory and at http://www.gromacs.org.
9 * GROMACS is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public License
11 * as published by the Free Software Foundation; either version 2.1
12 * of the License, or (at your option) any later version.
14 * GROMACS is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Lesser General Public License for more details.
19 * You should have received a copy of the GNU Lesser General Public
20 * License along with GROMACS; if not, see
21 * http://www.gnu.org/licenses, or write to the Free Software Foundation,
22 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24 * If you want to redistribute modifications to GROMACS, please
25 * consider that scientific software is very special. Version
26 * control is crucial - bugs must be traceable. We will be happy to
27 * consider code for inclusion in the official distribution, but
28 * derived work must not be called official GROMACS. Details are found
29 * in the README & COPYING files - if they are missing, get the
30 * official version at http://www.gromacs.org.
32 * To help us fund GROMACS development, we humbly ask that you cite
33 * the research papers on the package. Check out http://www.gromacs.org.
35 /*! \internal \file
36 * \brief
37 * Implements functions in strconvert.h.
39 * \author Teemu Murtola <teemu.murtola@gmail.com>
40 * \ingroup module_utility
42 #include "gmxpre.h"
44 #include "strconvert.h"
46 #include <cerrno>
47 #include <cstdlib>
49 #include <limits>
50 #include <string>
52 #include "gromacs/utility/cstringutil.h"
53 #include "gromacs/utility/exceptions.h"
55 namespace gmx
58 //! \cond libapi
60 bool boolFromString(const char *value)
62 if (gmx_strcasecmp(value, "1") == 0
63 || gmx_strcasecmp(value, "yes") == 0
64 || gmx_strcasecmp(value, "true") == 0)
66 return true;
68 if (gmx_strcasecmp(value, "0") == 0
69 || gmx_strcasecmp(value, "no") == 0
70 || gmx_strcasecmp(value, "false") == 0)
72 return false;
74 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(value) + "'; supported values are: 1, 0, yes, no, true, false"));
77 int intFromString(const char *str)
79 errno = 0;
80 char *endptr;
81 const long int value = std::strtol(str, &endptr, 10);
82 if (errno == ERANGE
83 || value < std::numeric_limits<int>::min()
84 || value > std::numeric_limits<int>::max())
86 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
87 + "'; it causes an integer overflow"));
89 if (str[0] == '\0' || *endptr != '\0')
91 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
92 + "'; expected an integer"));
94 return value;
97 int64_t int64FromString(const char *str)
99 errno = 0;
100 char *endptr;
101 const int64_t value = str_to_int64_t(str, &endptr);
102 if (errno == ERANGE)
104 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
105 + "'; it causes an integer overflow"));
107 if (str[0] == '\0' || *endptr != '\0')
109 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
110 + "'; expected an integer"));
112 return value;
115 float floatFromString(const char *str)
117 errno = 0;
118 char *endptr;
119 const double value = std::strtod(str, &endptr);
120 if (errno == ERANGE
121 || value < -std::numeric_limits<float>::max()
122 || value > std::numeric_limits<float>::max())
124 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
125 + "'; it causes an overflow/underflow"));
127 if (str[0] == '\0' || *endptr != '\0')
129 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
130 + "'; expected a number"));
132 return value;
135 double doubleFromString(const char *str)
137 errno = 0;
138 char *endptr;
139 const double value = std::strtod(str, &endptr);
140 if (errno == ERANGE)
142 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
143 + "'; it causes an overflow/underflow"));
145 if (str[0] == '\0' || *endptr != '\0')
147 GMX_THROW(InvalidInputError("Invalid value: '" + std::string(str)
148 + "'; expected a number"));
150 return value;
153 //! \endcond
155 } // namespace gmx