opm-simulators
parametersystem.hpp
Go to the documentation of this file.
1 // -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 // vi: set et ts=4 sw=4 sts=4:
3 /*
4  This file is part of the Open Porous Media project (OPM).
5 
6  OPM is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 2 of the License, or
9  (at your option) any later version.
10 
11  OPM is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with OPM. If not, see <http://www.gnu.org/licenses/>.
18 
19  Consult the COPYING file in the top-level source directory of this
20  module for the precise wording of the license and the list of
21  copyright holders.
22 */
32 #ifndef OPM_PARAMETER_SYSTEM_HPP
33 #define OPM_PARAMETER_SYSTEM_HPP
34 
35 #include <dune/common/classname.hh>
36 
37 #include <cstring>
38 #include <functional>
39 #include <set>
40 #include <sstream>
41 #include <string>
42 #include <type_traits>
43 #include <vector>
44 
45 namespace Opm::Parameters {
46 
47 namespace detail {
48 
49 template <typename, class = void>
50 struct has_name : public std::false_type {};
51 
52 template <typename T>
53 struct has_name<T, std::void_t<decltype(std::declval<T>().name)>>
54 : public std::true_type {};
55 
57 template<class Parameter>
59 {
60  if constexpr (has_name<Parameter>::value) {
61  return Parameter::name;
62  } else {
63  std::string paramName = Dune::className<Parameter>();
64  paramName.replace(0, std::strlen("Opm::Parameters::"), "");
65  const auto pos = paramName.find_first_of('<');
66  if (pos != std::string::npos) {
67  paramName.erase(pos);
68  }
69  return paramName;
70  }
71 }
72 
74 template<class ParamType>
75 ParamType Get_(const std::string& paramName, ParamType defaultValue,
76  bool errorIfNotRegistered);
77 
79 void Hide_(const std::string& paramName);
80 
82 bool IsSet_(const std::string& paramName, bool errorIfNotRegistered);
83 
85 void Register_(const std::string& paramName,
86  const std::string& paramTypeName,
87  const std::string& defaultValue,
88  const char* usageString);
89 
91 void SetDefault_(const std::string& paramName,
92  const std::string& paramValue);
93 
94 }
95 
97 
108 void printUsage(const std::string& helpPreamble,
109  std::ostream& os,
110  const std::string& errorMsg = "",
111  const bool showAll = false);
112 
114 using PositionalArgumentCallback = std::function<int(std::function<void(const std::string&,
115  const std::string&)>,
116  std::set<std::string>&,
117  std::string&,
118  int,
119  const char**,
120  int,
121  int)>;
139 std::string
140 parseCommandLineOptions(int argc,
141  const char **argv,
142  const PositionalArgumentCallback& posArgCallback,
143  const std::string& helpPreamble = "");
144 
151 bool parseParameterFile(const std::string& fileName, bool overwrite = true);
152 
159 void printValues(std::ostream& os);
160 
169 bool printUnused(std::ostream& os);
170 
186 template <class Param>
187 auto Get(bool errorIfNotRegistered = true)
188 {
189  using ParamType = std::conditional_t<std::is_same_v<decltype(Param::value),
190  const char* const>, std::string,
191  std::remove_const_t<decltype(Param::value)>>;
192  ParamType defaultValue = Param::value;
193  return detail::Get_(detail::getParamName<Param>(),
194  defaultValue, errorIfNotRegistered);
195 }
196 
211 template <class Param>
212 void SetDefault(decltype(Param::value) new_value)
213 {
214  const std::string paramName = detail::getParamName<Param>();
215  std::ostringstream oss;
216  oss << new_value;
217  detail::SetDefault_(paramName, oss.str());
218 }
219 
223 struct Parameter
224 {
225  Parameter(const std::string& k, const std::string& v)
226  : key(k), value(v)
227  {}
228 
229  friend std::ostream& operator<<(std::ostream& os, const Parameter& param)
230  {
231  os << param.key << "=\"" << param.value << '"';
232  return os;
233  }
234 
235  bool operator==(const Parameter& setting) const
236  {
237  return setting.key == key
238  && setting.value == value;
239  }
240 
241  bool operator !=(const Parameter& setting) const
242  {
243  return !(*this == setting);
244  }
245 
246  std::string key, value;
247 };
248 
255 void getLists(std::vector<Parameter>& usedParams,
256  std::vector<Parameter>& unusedParams);
257 
261 void reset();
262 
269 template <class Param>
270 bool IsSet(bool errorIfNotRegistered = true)
271 {
272  return detail::IsSet_(detail::getParamName<Param>(), errorIfNotRegistered);
273 }
274 
291 template <class Param>
292 void Register(const char* usageString)
293 {
294  const std::string paramName = detail::getParamName<Param>();
295  const auto defaultValue = Param::value;
296  using ParamType = std::conditional_t<std::is_same_v<decltype(defaultValue),
297  const char* const>, std::string,
298  std::remove_const_t<decltype(defaultValue)>>;
299 
300  std::ostringstream oss;
301  oss << defaultValue;
302  detail::Register_(paramName, Dune::className<ParamType>(), oss.str(), usageString);
303 }
304 
310 template <class Param>
311 void Hide()
312 {
313  detail::Hide_(detail::getParamName<Param>());
314 }
315 
320 bool IsRegistrationOpen();
321 
329 void endRegistration();
331 
332 } // namespace Opm::Parameters
333 
334 #endif // OPM_PARAMETER_SYSTEM_HPP
auto Get(bool errorIfNotRegistered=true)
Retrieve a runtime parameter.
Definition: parametersystem.hpp:187
void Hide()
Indicate that a given parameter should not be mentioned in the help message.
Definition: parametersystem.hpp:311
void SetDefault(decltype(Param::value) new_value)
Set a runtime parameter.
Definition: parametersystem.hpp:212
bool parseParameterFile(const std::string &fileName, bool overwrite)
Read the parameters from an INI-style file.
Definition: parametersystem.cpp:564
std::string parseCommandLineOptions(int argc, const char **argv, const PositionalArgumentCallback &posArgCallback, const std::string &helpPreamble)
Parse the parameters provided on the command line.
Definition: parametersystem.cpp:637
bool printUnused(std::ostream &os)
Print the list of unused run-time parameters.
Definition: parametersystem.cpp:791
Definition: parametersystem.hpp:50
A struct holding the key-value pair for a parameter.
Definition: parametersystem.hpp:223
Definition: blackoilnewtonmethodparams.hpp:31
void Register(const char *usageString)
Register a run-time parameter.
Definition: parametersystem.hpp:292
void reset()
Reset parameter system.
Definition: parametersystem.cpp:486
auto getParamName()
get the name data member of a parameter
Definition: parametersystem.hpp:58
bool IsSet(bool errorIfNotRegistered=true)
Returns true if a parameter has been specified at runtime, false otherwise.
Definition: parametersystem.hpp:270
void getLists(std::vector< Parameter > &usedParams, std::vector< Parameter > &unusedParams)
Retrieves the lists of parameters specified at runtime and their values.
Definition: parametersystem.cpp:506
std::function< int(std::function< void(const std::string &, const std::string &)>, std::set< std::string > &, std::string &, int, const char **, int, int)> PositionalArgumentCallback
Callback function for command line parsing.
Definition: parametersystem.hpp:121
void printValues(std::ostream &os)
Print values of the run-time parameters.
Definition: parametersystem.cpp:742