https://mooseframework.inl.gov
InputParameters.C
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://mooseframework.inl.gov
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
10 #include "InputParameters.h"
11 
12 // MOOSE includes
13 #include "MooseEnum.h"
14 #include "MooseTypes.h"
15 #include "MooseUtils.h"
16 #include "MultiMooseEnum.h"
17 #include "ExecFlagEnum.h"
18 #include "MooseObject.h"
19 #include "MooseApp.h"
20 
21 #include "libmesh/utility.h"
22 #include "libmesh/simple_range.h"
23 
24 #include "pcrecpp.h"
25 #include "hit/parse.h"
26 
27 #include <cmath>
28 #include <filesystem>
29 
32 {
33  InputParameters params;
34  return params;
35 }
36 
38  : Parameters(),
39  _collapse_nesting(false),
40  _moose_object_syntax_visibility(true),
41  _show_deprecated_message(true),
42  _allow_copy(true),
43  _hit_node(nullptr),
44  _finalized(false)
45 {
46 }
47 
49  : Parameters(), _show_deprecated_message(true), _allow_copy(true)
50 {
51  *this = rhs;
52 }
53 
54 InputParameters::InputParameters(const Parameters & rhs)
55  : _show_deprecated_message(true), _allow_copy(true)
56 {
57  _params.clear();
59  _collapse_nesting = false;
61 }
62 
63 void
65 {
67  _params.clear();
68  _coupled_vars.clear();
70  _collapse_nesting = false;
73  _allow_copy = true;
75  _new_to_old_names.clear();
76  _hit_node = nullptr;
77  _finalized = false;
78 }
79 
80 void
81 InputParameters::addClassDescription(const std::string & doc_string)
82 {
83  _class_description = doc_string;
84 }
85 
86 void
87 InputParameters::set_attributes(const std::string & name_in, bool inserted_only)
88 {
89  const auto name = checkForRename(name_in);
90 
91  if (!inserted_only)
92  {
93  auto & metadata = _params[name];
100  metadata._set_by_add_param = false;
101 
102  // valid_params don't make sense for MooseEnums
103  if (!have_parameter<MooseEnum>(name) && !have_parameter<MultiMooseEnum>(name))
104  metadata._valid = true;
105  }
106 }
107 
108 std::optional<std::string>
109 InputParameters::queryDeprecatedParamMessage(const std::string & name_in) const
110 {
111  const auto name = checkForRename(name_in);
113  {
114  auto deprecation_message = [this](const auto & name, const auto & message) -> std::string
115  { return paramMessagePrefix(name) + message; };
116 
117  if (_params.count(name) && !libmesh_map_find(_params, name)._deprecation_message.empty())
118  return deprecation_message(name,
119  "The parameter '" + name + "' is deprecated.\n" +
120  libmesh_map_find(_params, name)._deprecation_message);
121  else if (auto it = _old_to_new_name_and_dep.find(name_in);
122  it != _old_to_new_name_and_dep.end() && !it->second.second.empty())
123  return deprecation_message(name_in, it->second.second);
124  }
125  return {};
126 }
127 
128 std::string
130 {
131  return _class_description;
132 }
133 
136 {
137  // An error to help minimize the segmentation faults that occure when MooseObjects do not have the
138  // correct constructor
139  if (!rhs._allow_copy)
140  {
141  // If _allow_parameter_copy is set, these should be too (see
142  // InputParameterWarehouse::addInputParameters)
143  const std::string & name = rhs.getObjectName();
144  const std::string & type = rhs.getObjectType(); // could be empty
145  const std::string name_example = type.size() ? type : "the " + name + " object";
146  const std::string type_example = type.size() ? type : "MyObject";
147  ::mooseError(
148  "Copying of the InputParameters object for ",
149  name_example,
150  " is not allowed.\n\nThe likely cause for this error ",
151  "is having a constructor that does not use a const reference, all constructors\nfor "
152  "MooseObject based classes should be as follows:\n\n",
153  " ",
154  type_example,
155  "::",
156  type_example,
157  "(const InputParameters & parameters);");
158  }
159 
161 
162  _params = rhs._params;
163 
170  _allow_copy = rhs._allow_copy;
173  _hit_node = rhs._hit_node;
174  _finalized = false;
175 
176  return *this;
177 }
178 
181 {
182  Parameters::operator+=(rhs);
183 
184  // TODO: this is not a proper merge - if a particular parameter exists in both this and rhs,
185  // then we should actually smartly merge both metadata structs before storing in this.
186  for (auto it = rhs._params.begin(); it != rhs._params.end(); ++it)
187  _params[it->first] = it->second;
188 
189  _buildable_types.insert(
190  _buildable_types.end(), rhs._buildable_types.begin(), rhs._buildable_types.end());
191  _buildable_rm_types.insert(
192  _buildable_rm_types.end(), rhs._buildable_rm_types.begin(), rhs._buildable_rm_types.end());
193 
194  // Collapse nesting and moose object syntax hiding are not modified with +=
195  _coupled_vars.insert(rhs._coupled_vars.begin(), rhs._coupled_vars.end());
198 
200  rhs._old_to_new_name_and_dep.end());
201  _new_to_old_names.insert(rhs._new_to_old_names.begin(), rhs._new_to_old_names.end());
202  return *this;
203 }
204 
205 void
206 InputParameters::setDeprecatedVarDocString(const std::string & new_name,
207  const std::string & doc_string)
208 {
209  auto coupled_vars_it = _new_to_deprecated_coupled_vars.find(new_name);
210  if (coupled_vars_it != _new_to_deprecated_coupled_vars.end())
211  {
212  auto params_it = _params.find(coupled_vars_it->second);
213  if (params_it == _params.end())
214  mooseError("There must have been a mistake in the construction of the new to deprecated "
215  "coupled vars map because the old name ",
216  coupled_vars_it->second,
217  " doesn't exist in the parameters data.");
218 
219  params_it->second._doc_string = doc_string;
220  }
221 }
222 
223 void
224 InputParameters::addCoupledVar(const std::string & name, Real value, const std::string & doc_string)
225 {
226  addParam<std::vector<VariableName>>(name, doc_string);
227  _coupled_vars.insert(name);
228  auto & metadata = _params[name];
229  metadata._coupled_default.assign(1, value);
230  metadata._have_coupled_default = true;
231 
232  // Set the doc string for any associated deprecated coupled var
233  setDeprecatedVarDocString(name, doc_string);
234 }
235 
236 void
237 InputParameters::addCoupledVar(const std::string & name,
238  const std::vector<Real> & value,
239  const std::string & doc_string)
240 {
241  // std::vector<VariableName>(1, Moose::stringify(value)),
242  addParam<std::vector<VariableName>>(name, doc_string);
243  _coupled_vars.insert(name);
244  auto & metadata = _params[name];
245  metadata._coupled_default = value;
246  metadata._have_coupled_default = true;
247 
248  // Set the doc string for any associated deprecated coupled var
249  setDeprecatedVarDocString(name, doc_string);
250 }
251 
252 void
253 InputParameters::addCoupledVar(const std::string & name, const std::string & doc_string)
254 {
255  addParam<std::vector<VariableName>>(name, doc_string);
256  _coupled_vars.insert(name);
257 
258  // Set the doc string for any associated deprecated coupled var
259  setDeprecatedVarDocString(name, doc_string);
260 }
261 
262 void
263 InputParameters::addDeprecatedCoupledVar(const std::string & old_name,
264  const std::string & new_name,
265  const std::string & removal_date /*=""*/)
266 {
267  mooseDeprecated("Please use 'deprecateCoupledVar'");
268 
269  _show_deprecated_message = false;
270 
271  // Set the doc string if we are adding the deprecated var after the new var has already been added
272  auto params_it = _params.find(new_name);
273  std::string doc_string;
274  if (params_it != _params.end())
275  doc_string = params_it->second._doc_string;
276 
277  addParam<std::vector<VariableName>>(old_name, doc_string);
278  _coupled_vars.insert(old_name);
279  _new_to_deprecated_coupled_vars.emplace(new_name, old_name);
280 
281  std::string deprecation_message =
282  "The coupled variable parameter '" + old_name + "' has been deprecated";
283  if (!removal_date.empty())
284  deprecation_message += " and will be removed " + removal_date;
285  deprecation_message += ". Please use the '" + new_name + "' coupled variable parameter instead.";
286  _params[old_name]._deprecation_message = deprecation_message;
288 }
289 
290 void
292  const std::string & base_name,
293  const std::string & num_name,
294  const std::string & doc_string)
295 {
296  addParam<std::vector<VariableName>>(name, doc_string);
297  _coupled_vars.insert(name);
298  _params[name]._autobuild_vecs = std::make_pair(base_name, num_name);
299 
300  // Additionally there are two more parameters that need to be added:
301  addParam<std::string>(base_name, doc_string + " (base_name)");
302  addParam<unsigned int>(num_name, doc_string + " (num_name)");
303 }
304 
305 void
307  const std::string & base_name,
308  const std::string & num_name,
309  const std::string & doc_string)
310 {
311  addRequiredParam<std::vector<VariableName>>(name, doc_string);
312 
313  addCoupledVarWithAutoBuild(name, base_name, num_name, doc_string);
314 }
315 
316 void
317 InputParameters::addRequiredCoupledVar(const std::string & name, const std::string & doc_string)
318 {
319  addRequiredParam<std::vector<VariableName>>(name, doc_string);
320  _coupled_vars.insert(name);
321 }
322 
323 std::string
324 InputParameters::getDocString(const std::string & name_in) const
325 {
326  const auto name = checkForRename(name_in);
327 
328  std::string doc_string;
329  auto it = _params.find(name);
330  if (it != _params.end())
331  for (const auto & ch : it->second._doc_string)
332  {
333  if (ch == '\n')
334  doc_string += " ... ";
335  else
336  doc_string += ch;
337  }
338 
339  return doc_string;
340 }
341 
342 void
343 InputParameters::setDocString(const std::string & name_in, const std::string & doc)
344 {
345  const auto name = checkForRename(name_in);
346 
347  auto it = _params.find(name);
348  if (it == _params.end())
349  mooseError("Unable to set the documentation string (using setDocString) for the \"",
350  name,
351  "\" parameter, the parameter does not exist.");
352  it->second._doc_string = doc;
353 }
354 
355 std::string
356 InputParameters::getDocUnit(const std::string & name_in) const
357 {
358  const auto name = checkForRename(name_in);
359  return _params.at(name)._doc_unit;
360 }
361 
362 void
363 InputParameters::setDocUnit(const std::string & name_in, const std::string & doc_unit)
364 {
365  const auto name = checkForRename(name_in);
366  _params[name]._doc_unit = doc_unit;
367 }
368 
369 bool
370 InputParameters::isParamRequired(const std::string & name_in) const
371 {
372  const auto name = checkForRename(name_in);
373  return _params.count(name) > 0 && _params.at(name)._required;
374 }
375 
376 void
377 InputParameters::makeParamNotRequired(const std::string & name_in)
378 {
379  const auto name = checkForRename(name_in);
380 
381  if (_params.count(name))
382  _params[name]._required = false;
383 }
384 
385 bool
386 InputParameters::isParamValid(const std::string & name_in) const
387 {
388  const auto name = checkForRename(name_in);
389  if (have_parameter<MooseEnum>(name))
390  return get<MooseEnum>(name).isValid();
391  else if (have_parameter<std::vector<MooseEnum>>(name))
392  {
393  for (auto it = get<std::vector<MooseEnum>>(name).begin();
394  it != get<std::vector<MooseEnum>>(name).end();
395  ++it)
396  if (!it->isValid())
397  return false;
398  return true;
399  }
400  else if (have_parameter<MultiMooseEnum>(name))
401  return get<MultiMooseEnum>(name).isValid();
402  else if (have_parameter<std::vector<MultiMooseEnum>>(name))
403  {
404  for (auto it = get<std::vector<MultiMooseEnum>>(name).begin();
405  it != get<std::vector<MultiMooseEnum>>(name).end();
406  ++it)
407  if (!it->isValid())
408  return false;
409  return true;
410  }
411  else if (have_parameter<ExecFlagEnum>(name))
412  return get<ExecFlagEnum>(name).isValid();
413  else
414  return _params.count(name) > 0 && _params.at(name)._valid;
415 }
416 
417 bool
418 InputParameters::isParamSetByAddParam(const std::string & name_in) const
419 {
420  const auto name = checkForRename(name_in);
421  return _params.count(name) > 0 && _params.at(name)._set_by_add_param;
422 }
423 
424 bool
425 InputParameters::isParamDeprecated(const std::string & name_in) const
426 {
427  const auto name = checkForRename(name_in);
428  return _params.count(name) > 0 && !_params.at(name)._deprecation_message.empty();
429 }
430 
431 #ifdef MOOSE_KOKKOS_ENABLED
432 bool
434 {
436 }
437 #endif
438 
439 bool
441 {
442  for (const auto & it : *this)
443  if (isParamRequired(it.first) && !isParamValid(it.first))
444  return false;
445  return true;
446 }
447 
448 bool
449 InputParameters::isPrivate(const std::string & name_in) const
450 {
451  const auto name = checkForRename(name_in);
452  return _params.count(name) > 0 && _params.at(name)._is_private;
453 }
454 
455 void
456 InputParameters::declareControllable(const std::string & input_names,
457  std::set<ExecFlagType> execute_flags)
458 {
459  std::vector<std::string> names;
460  MooseUtils::tokenize<std::string>(input_names, names, 1, " ");
461  for (auto & name_in : names)
462  {
463  const auto name = checkForRename(name_in);
464  auto map_iter = _params.find(name);
465  if (map_iter != _params.end()) // error is handled by checkParams method
466  {
467  map_iter->second._controllable = true;
468  map_iter->second._controllable_flags = execute_flags;
469  }
470  else
471  mooseError("The input parameter '",
472  name,
473  "' does not exist, thus cannot be marked as controllable.");
474  }
475 }
476 
477 bool
478 InputParameters::isControllable(const std::string & name_in) const
479 {
480  const auto name = checkForRename(name_in);
481  return _params.count(name) > 0 && _params.at(name)._controllable;
482 }
483 
484 const std::set<ExecFlagType> &
485 InputParameters::getControllableExecuteOnTypes(const std::string & name_in) const
486 {
487  const auto name = checkForRename(name_in);
488  return at(name)._controllable_flags;
489 }
490 
491 void
492 InputParameters::registerBase(const std::string & value)
493 {
494  InputParameters::set<std::string>(MooseBase::moose_base_param) = value;
495  _params[MooseBase::moose_base_param]._is_private = true;
496 }
497 
498 bool
500 {
501  return have_parameter<std::string>(MooseBase::moose_base_param);
502 }
503 
504 const std::string &
506 {
507  if (!have_parameter<std::string>(MooseBase::moose_base_param))
508  mooseError("InputParameters::getBase(): Parameters do not have base; one needs to be set with "
509  "registerBase()");
510  return get<std::string>(MooseBase::moose_base_param);
511 }
512 
513 void
515 {
516  InputParameters::set<std::string>("_moose_warehouse_system_name") = value;
517  _params["_moose_warehouse_system_name"]._is_private = true;
518 }
519 
520 const std::string &
522 {
523  mooseAssert(have_parameter<std::string>("_moose_warehouse_system_name"),
524  "SystemAttributeName is not available! Call 'registerSystemAttributeName' (usually "
525  "in the validParams function) before you try accessing it!");
526  return Parameters::get<std::string>("_moose_warehouse_system_name");
527 }
528 
529 void
530 InputParameters::registerBuildableTypes(const std::string & names)
531 {
532  _buildable_types.clear();
533  MooseUtils::tokenize(names, _buildable_types, 1, " \t\n\v\f\r"); // tokenize on whitespace
534 }
535 
536 void
538  const std::string & name,
540  Moose::RelationshipManagerInputParameterCallback input_parameter_callback)
541 {
542  _buildable_rm_types.emplace_back(name, rm_type, input_parameter_callback);
543 }
544 
545 const std::vector<std::string> &
547 {
548  return _buildable_types;
549 }
550 
551 const std::vector<std::tuple<std::string,
555 {
556  return _buildable_rm_types;
557 }
558 
559 void
561 {
562  _collapse_nesting = collapse;
563 }
564 
565 bool
567 {
568  return _collapse_nesting;
569 }
570 
571 void
573 {
574  _moose_object_syntax_visibility = visibility;
575 }
576 
577 bool
579 {
581 }
582 
583 #define checkMooseType(param_type, name) \
584  if (have_parameter<param_type>(name) || have_parameter<std::vector<param_type>>(name)) \
585  error = "non-controllable type '" + type(name) + "' for parameter '" + \
586  paramFullpath(param_name) + "' marked controllable";
587 
588 void
589 InputParameters::checkParams(const std::string & parsing_syntax)
590 {
591  const std::string parampath = blockFullpath() != "" ? blockFullpath() : parsing_syntax;
592 
593  // Required parameters
594  std::vector<std::string> required_param_errors;
595  for (const auto & it : *this)
596  {
597  const auto param_name = checkForRename(it.first);
598  if (!isParamValid(param_name) && isParamRequired(param_name))
599  {
600  // check if an old, deprecated name exists for this parameter that may be specified
601  auto oit = _new_to_deprecated_coupled_vars.find(param_name);
602  if (oit != _new_to_deprecated_coupled_vars.end() && isParamValid(oit->second))
603  continue;
604 
605  required_param_errors.push_back("missing required parameter '" + parampath + "/" +
606  param_name + "'\n\tDoc String: \"" +
607  getDocString(param_name) + "\"");
608  }
609  }
610 
611  if (required_param_errors.size())
612  mooseError(MooseUtils::stringJoin(required_param_errors, "\n"));
613 
614  // Range checked parameters
615  for (const auto & [name, param_ptr] : *this)
616  {
617  if (const auto error = parameterRangeCheck(*param_ptr, parampath + "/" + name, name, false))
618  {
619  if (error->first)
620  paramError(name, error->second);
621  else
622  mooseError("For range checked parameter '" + name + "': " + error->second);
623  }
624  }
625 
626  // Controllable parameters
627  for (const auto & param_name : getControllableParameters())
628  {
629  if (isPrivate(param_name))
630  paramError(param_name,
631  "private parameter '" + paramFullpath(param_name) + "' marked controllable");
632 
633  std::optional<std::string> error;
634  checkMooseType(NonlinearVariableName, param_name);
635  checkMooseType(AuxVariableName, param_name);
636  checkMooseType(VariableName, param_name);
637  checkMooseType(BoundaryName, param_name);
638  checkMooseType(SubdomainName, param_name);
639  checkMooseType(PostprocessorName, param_name);
640  checkMooseType(VectorPostprocessorName, param_name);
641  checkMooseType(UserObjectName, param_name);
642  checkMooseType(MaterialPropertyName, param_name);
643  if (error)
644  paramError(param_name, *error);
645  }
646 }
647 
648 std::optional<std::pair<bool, std::string>>
649 InputParameters::parameterRangeCheck(const Parameters::Value & value,
650  const std::string & long_name,
651  const std::string & short_name,
652  const bool include_param_path)
653 {
654 #define dynamicCastRangeCheck(type, up_type, long_name, short_name) \
655  do \
656  { \
657  if (const auto scalar_p = dynamic_cast<const InputParameters::Parameter<type> *>(&value)) \
658  return rangeCheck<type, up_type>(long_name, short_name, *scalar_p, include_param_path); \
659  if (const auto vector_p = \
660  dynamic_cast<const InputParameters::Parameter<std::vector<type>> *>(&value)) \
661  return rangeCheck<type, up_type>(long_name, short_name, *vector_p, include_param_path); \
662  } while (0)
663 
664  dynamicCastRangeCheck(Real, Real, long_name, short_name);
665  dynamicCastRangeCheck(int, long, long_name, short_name);
666  dynamicCastRangeCheck(long, long, long_name, short_name);
667  dynamicCastRangeCheck(unsigned int, long, long_name, short_name);
668 #undef dynamicCastRangeCheck
669 
670  return {};
671 }
672 
673 void
674 InputParameters::finalize(const std::string & parsing_syntax)
675 {
676  mooseAssert(!isFinalized(), "Already finalized");
677 
678  checkParams(parsing_syntax);
679 
680  // Set parameters that represent file types
681  for (const auto & name_value : *this)
682  {
683  const auto & param_name = name_value.first;
684  const auto & param_value = name_value.second;
685 
686  // Helper for setting a file typed parameter value
687  const auto set_filename = [&](auto & value)
688  {
689  constexpr bool is_data_file_name =
690  std::is_same_v<std::decay_t<decltype(value)>, DataFileName>;
691 
692  // We have behavior (which is gross) that requires that for
693  // everything but DataFileName, if the value is empty we
694  // don't bother looking for it
695  if constexpr (!is_data_file_name)
696  {
697  if (value.empty())
698  return;
699  }
700 
701  // Setup options for searching for the path
703  // Associate relative path searches with the folder
704  // that input file that has this parameter is located
705  options.base = getFileBase(param_name);
706  // If we don't explicitly have a DataFileName parameter,
707  // we only want to augment cases where a data name is
708  // explicitly set (like moose:file). We don't want to
709  // search all other data. To presere previous behavior,
710  // we also don't want to error if nothing is found; for
711  // example if a relative or absolute path is not found.
712  // The only time we'll error is if the data name is
713  // explicitly set and the path doesn't exist in the data
714  // or if that data name isn't registered.
715  if constexpr (!is_data_file_name)
716  {
717  options.search_all_data = false;
718  options.graceful = true;
719  }
720 
722  try
723  {
724  Moose::ScopedThrowOnError scoped_throw_on_error;
725  path = Moose::DataFileUtils::getPath(value, options);
726  }
727  catch (std::exception & e)
728  {
729  paramError(param_name, e.what());
730  }
731 
732  value = path.path;
733  at(param_name)._data_file_name_path = path;
734  };
735 
736 #define set_if_filename(type) \
737  else if (auto type_value = dynamic_cast<Parameters::Parameter<type> *>(param_value.get())) \
738  set_filename(type_value->set()); \
739  else if (auto type_values = dynamic_cast<Parameters::Parameter<std::vector<type>> *>( \
740  param_value.get())) for (auto & value : type_values->set()) set_filename(value)
741 
742  if (false)
743  ;
744  set_if_filename(FileName);
745  set_if_filename(FileNameNoExtension);
746  set_if_filename(MeshFileName);
747  set_if_filename(MatrixFileName);
748  set_if_filename(DataFileName);
749 #undef set_if_filename
750  }
751 
752  _finalized = true;
753 }
754 
755 std::filesystem::path
756 InputParameters::getFileBase(const std::optional<std::string> & param_name) const
757 {
758  mooseAssert(!have_parameter<std::string>("_app_name"),
759  "Not currently setup to work with app FileName parameters");
760 
761  const hit::Node * hit_node = nullptr;
762 
763  // Context from the individual parameter
764  if (param_name)
765  hit_node = getHitNode(*param_name);
766  // Context from the parameters
767  if (!hit_node)
768  hit_node = getHitNode();
769  // No hit node, so use the cwd (no input files)
770  if (!hit_node)
771  return std::filesystem::current_path();
772 
773  // Find any context that isn't command line arguments
774  while (hit_node && hit_node->filename() == "CLI_ARGS")
775  hit_node = hit_node->parent();
776 
777  // Failed to find a node up the tree that isn't a command line argument
778  if (!hit_node)
779  {
780  const std::string error = "Input context was set via a command-line argument and does not have "
781  "sufficient context for determining a file path.";
782  if (param_name)
783  paramError(*param_name, error);
784  else
785  mooseError(error);
786  }
787 
788  return std::filesystem::absolute(std::filesystem::path(hit_node->filename()).parent_path());
789 }
790 
791 bool
792 InputParameters::isRangeChecked(const std::string & param_name) const
793 {
794  const auto name = checkForRename(param_name);
795  return !_params.find(name)->second._range_function.empty();
796 }
797 
798 std::string
799 InputParameters::rangeCheckedFunction(const std::string & param_name) const
800 {
801  const auto name = checkForRename(param_name);
802  return _params.at(name)._range_function;
803 }
804 
805 bool
806 InputParameters::hasDefault(const std::string & param_name) const
807 {
808  const auto name = checkForRename(param_name);
810  return true;
811  // If it has a default, it's already valid
812  else if (isParamSetByAddParam(name))
813  return true;
814  else if (isParamValid(name))
815  mooseError("No way to know if the parameter '", param_name, "' has a default");
816  else
817  return false;
818 }
819 
820 bool
821 InputParameters::hasCoupledValue(const std::string & coupling_name) const
822 {
823  return _coupled_vars.find(coupling_name) != _coupled_vars.end();
824 }
825 
826 bool
827 InputParameters::hasDefaultCoupledValue(const std::string & coupling_name) const
828 {
829  return _params.count(coupling_name) > 0 && _params.at(coupling_name)._have_coupled_default &&
830  _coupled_vars.count(coupling_name) > 0;
831 }
832 
833 void
834 InputParameters::defaultCoupledValue(const std::string & coupling_name, Real value, unsigned int i)
835 {
836  const auto actual_name = checkForRename(coupling_name);
837  _params[actual_name]._coupled_default.resize(i + 1);
838  _params[actual_name]._coupled_default[i] = value;
839  _params[actual_name]._have_coupled_default = true;
840 }
841 
842 Real
843 InputParameters::defaultCoupledValue(const std::string & coupling_name, unsigned int i) const
844 {
845  auto value_it = _params.find(coupling_name);
846 
847  if (value_it == _params.end() || !value_it->second._have_coupled_default)
848  mooseError("Attempted to retrieve default value for coupled variable '",
849  coupling_name,
850  "' when none was provided. \n\nThere are three reasons why this may have "
851  "occurred:\n 1. The other version of params.addCoupledVar() should be used in order "
852  "to provide a default value. \n 2. This should have been a required coupled "
853  "variable added with params.addRequiredCoupledVar() \n 3. The call to get the "
854  "coupled value should have been properly guarded with isCoupled()\n");
855 
856  return value_it->second._coupled_default.at(i);
857 }
858 
859 unsigned int
860 InputParameters::numberDefaultCoupledValues(const std::string & coupling_name) const
861 {
862  auto value_it = _params.find(coupling_name);
863  if (value_it == _params.end())
864  mooseError("Attempted to retrieve default value for coupled variable '",
865  coupling_name,
866  "' when none was provided.");
867  return value_it->second._coupled_default.size();
868 }
869 
870 std::map<std::string, std::pair<std::string, std::string>>
872 {
873  std::map<std::string, std::pair<std::string, std::string>> abv;
874  for (auto it = _params.begin(); it != _params.end(); ++it)
875  {
876  if (!it->second._autobuild_vecs.first.empty())
877  abv[it->first] = it->second._autobuild_vecs;
878  }
879  return abv;
880 }
881 
882 std::string
883 InputParameters::type(const std::string & name_in) const
884 {
885  const auto name = checkForRename(name_in);
886  if (!_values.count(name))
887  mooseError("Parameter \"", name, "\" not found.\n\n", *this);
888 
889  if (_coupled_vars.find(name) != _coupled_vars.end())
890  return "std::vector<VariableName>";
891  else if (_params.count(name) > 0 && !_params.at(name)._custom_type.empty())
892  return _params.at(name)._custom_type;
893  return _values.at(name)->type();
894 }
895 
896 std::string
897 InputParameters::getMooseType(const std::string & name_in) const
898 {
899  const auto name = checkForRename(name_in);
900  std::string var;
901 
902  if (have_parameter<VariableName>(name))
903  var = get<VariableName>(name);
904  else if (have_parameter<NonlinearVariableName>(name))
905  var = get<NonlinearVariableName>(name);
906  else if (have_parameter<LinearVariableName>(name))
907  var = get<LinearVariableName>(name);
908  else if (have_parameter<AuxVariableName>(name))
909  var = get<AuxVariableName>(name);
910  else if (have_parameter<PostprocessorName>(name))
911  var = get<PostprocessorName>(name);
912  else if (have_parameter<VectorPostprocessorName>(name))
913  var = get<VectorPostprocessorName>(name);
914  else if (have_parameter<FunctionName>(name))
915  var = get<FunctionName>(name);
916  else if (have_parameter<UserObjectName>(name))
917  var = get<UserObjectName>(name);
918  else if (have_parameter<MaterialPropertyName>(name))
919  var = get<MaterialPropertyName>(name);
920  else if (have_parameter<std::string>(name))
921  var = get<std::string>(name);
922 
923  return var;
924 }
925 
926 std::vector<std::string>
927 InputParameters::getVecMooseType(const std::string & name_in) const
928 {
929  const auto name = checkForRename(name_in);
930  std::vector<std::string> svars;
931 
932  if (have_parameter<std::vector<VariableName>>(name))
933  {
934  std::vector<VariableName> vars = get<std::vector<VariableName>>(name);
935  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
936  }
937  else if (have_parameter<std::vector<NonlinearVariableName>>(name))
938  {
939  std::vector<NonlinearVariableName> vars = get<std::vector<NonlinearVariableName>>(name);
940  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
941  }
942  else if (have_parameter<std::vector<AuxVariableName>>(name))
943  {
944  std::vector<AuxVariableName> vars = get<std::vector<AuxVariableName>>(name);
945  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
946  }
947  else if (have_parameter<std::vector<MaterialPropertyName>>(name))
948  {
949  std::vector<MaterialPropertyName> vars = get<std::vector<MaterialPropertyName>>(name);
950  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
951  }
952  else if (have_parameter<std::vector<std::string>>(name))
953  {
954  std::vector<std::string> vars = get<std::vector<std::string>>(name);
955  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
956  }
957 
958  return svars;
959 }
960 
961 bool
963 {
964  return have_parameter<std::string>(MooseBase::type_param) &&
965  get<std::string>(MooseBase::type_param).size() &&
966  have_parameter<std::string>(MooseBase::name_param);
967 }
968 
969 const std::string *
971 {
972  return have_parameter<std::string>(MooseBase::type_param)
973  ? &get<std::string>(MooseBase::type_param)
974  : nullptr;
975 }
976 
977 const std::string &
979 {
980  if (const auto type_ptr = queryObjectType())
981  return *type_ptr;
982  ::mooseError("InputParameters::getObjectType(): Missing '", MooseBase::type_param, "' param");
983 }
984 
985 const std::string &
987 {
988  if (!have_parameter<std::string>(MooseBase::name_param))
989  ::mooseError("InputParameters::getObjectName(): Missing '", MooseBase::name_param, "' param");
990  return get<std::string>(MooseBase::name_param);
991 }
992 
993 void
994 InputParameters::addParamNamesToGroup(const std::string & space_delim_names,
995  const std::string group_name)
996 {
997  std::vector<std::string> elements;
998  MooseUtils::tokenize(space_delim_names, elements, 1, " \t\n\v\f\r"); // tokenize on whitespace
999 
1000  // Since we don't require types (templates) for this method, we need
1001  // to get a raw list of parameter names to compare against.
1002  std::set<std::string> param_names;
1003  for (const auto & it : *this)
1004  param_names.insert(it.first);
1005 
1006  for (const auto & param_name : elements)
1007  if (_params.count(param_name) > 0)
1008  _params[param_name]._group = group_name;
1009  else
1010  mooseError("Unable to find a parameter with name: ",
1011  param_name,
1012  " when adding to group ",
1013  group_name,
1014  '.');
1015 }
1016 
1017 void
1018 InputParameters::renameParameterGroup(const std::string & old_name, const std::string & new_name)
1019 {
1020  for (auto & param : _params)
1021  if (param.second._group == old_name)
1022  param.second._group = new_name;
1023 }
1024 
1025 void
1027 {
1028  auto & cl_data = at(checkForRename(name))._cl_data;
1029  if (!cl_data)
1030  mooseError("InputParameters::setGlobalCommandLineParam: The parameter '",
1031  name,
1032  "' is not a command line parameter");
1033  cl_data->global = true;
1034 }
1035 
1036 bool
1037 InputParameters::isCommandLineParameter(const std::string & name) const
1038 {
1039  return at(checkForRename(name))._cl_data.has_value();
1040 }
1041 
1042 std::optional<InputParameters::CommandLineMetadata>
1043 InputParameters::queryCommandLineMetadata(const std::string & name) const
1044 {
1045  const auto & cl_data = at(checkForRename(name))._cl_data;
1046  if (!cl_data)
1047  return {};
1048  return *cl_data;
1049 }
1050 
1052 InputParameters::getCommandLineMetadata(const std::string & name) const
1053 {
1054  const auto & cl_data = at(checkForRename(name))._cl_data;
1055  if (!cl_data)
1056  mooseError("InputParameters::getCommandLineMetadata: The parameter '",
1057  name,
1058  "' is not a command line parameter");
1059  return *cl_data;
1060 }
1061 
1062 void
1064 {
1065  auto & cl_data = at(checkForRename(name))._cl_data;
1066  if (!cl_data)
1067  mooseError("InputParameters::commandLineParamSet: The parameter '",
1068  name,
1069  "' is not a command line parameter");
1070  cl_data->set_by_command_line = true;
1071 }
1072 
1073 std::string
1074 InputParameters::getGroupName(const std::string & param_name_in) const
1075 {
1076  const auto param_name = checkForRename(param_name_in);
1077  auto it = _params.find(param_name);
1078  if (it != _params.end())
1079  return it->second._group;
1080  return std::string();
1081 }
1082 
1083 void
1085  const std::vector<std::string> & exclude,
1086  const bool allow_private)
1087 {
1088  // If we're applying all of the things, also associate the top level hit node
1089  if (exclude.empty() && !getHitNode() && common.getHitNode())
1090  setHitNode(*common.getHitNode(), {});
1091 
1092  // Loop through the common parameters
1093  for (const auto & it : common)
1094  {
1095  // Common parameter name
1096  const std::string & common_name = it.first;
1097  // Continue to next parameter, if the current is in list of excluded parameters
1098  if (std::find(exclude.begin(), exclude.end(), common_name) != exclude.end())
1099  continue;
1100 
1101  applyParameter(common, common_name, allow_private);
1102  }
1103 
1104  // Loop through the coupled variables
1105  for (const auto & var_name : common._coupled_vars)
1106  {
1107  // Continue to next variable, if the current is in list of excluded parameters
1108  if (std::find(exclude.begin(), exclude.end(), var_name) != exclude.end())
1109  continue;
1110 
1111  applyCoupledVar(common, var_name);
1112  }
1113 }
1114 
1115 void
1117  const std::vector<std::string> & exclude,
1118  const bool allow_private)
1119 {
1120  for (const auto & it : common)
1121  {
1122  const std::string & common_name = it.first;
1123  if (std::find(exclude.begin(), exclude.end(), common_name) != exclude.end())
1124  continue;
1125  if (!common.isParamSetByUser(common_name))
1126  continue;
1127  applyParameter(common, common_name, allow_private);
1128  }
1129 
1130  for (const auto & var_name : common._coupled_vars)
1131  {
1132  if (std::find(exclude.begin(), exclude.end(), var_name) != exclude.end())
1133  continue;
1134  if (!common.isParamSetByUser(var_name))
1135  continue;
1136  applyCoupledVar(common, var_name);
1137  }
1138 }
1139 
1140 void
1142  const std::vector<std::string> & include,
1143  bool allow_private)
1144 {
1145  // Loop through the common parameters
1146  for (const auto & it : common)
1147  {
1148  // Common parameter name
1149  const std::string & common_name = it.first;
1150 
1151  // Continue to next parameter, if the current is not in list of included parameters
1152  if (std::find(include.begin(), include.end(), common_name) == include.end())
1153  continue;
1154 
1155  applyParameter(common, common_name, allow_private);
1156  }
1157 
1158  // Loop through the coupled variables
1159  for (std::set<std::string>::const_iterator it = common.coupledVarsBegin();
1160  it != common.coupledVarsEnd();
1161  ++it)
1162  {
1163  // Variable name
1164  const std::string var_name = *it;
1165 
1166  // Continue to next variable, if the current is not in list of included parameters
1167  if (std::find(include.begin(), include.end(), var_name) == include.end())
1168  continue;
1169 
1170  applyCoupledVar(common, var_name);
1171  }
1172 }
1173 
1174 void
1175 InputParameters::applyCoupledVar(const InputParameters & common, const std::string & var_name)
1176 {
1177  // Disable the display of deprecated message when applying common parameters, this avoids a dump
1178  // of messages
1179  _show_deprecated_message = false;
1180 
1181  // If the local parameters has a coupled variable, populate it with the value from the common
1182  // parameters, if the common parameters has the coupled variable too
1183  if (hasCoupledValue(var_name))
1184  {
1185  if (common.hasDefaultCoupledValue(var_name))
1186  {
1187  // prepare a vector of default coupled values
1188  std::vector<Real> defaults(common.numberDefaultCoupledValues(var_name));
1189  for (unsigned int j = 0; j < common.numberDefaultCoupledValues(var_name); ++j)
1190  defaults[j] = common.defaultCoupledValue(var_name, j);
1191  addCoupledVar(var_name, defaults, common.getDocString(var_name));
1192  }
1193  else if (common.hasCoupledValue(var_name))
1194  addCoupledVar(var_name, common.getDocString(var_name));
1195  }
1196 
1197  // Enable deprecated message printing
1198  _show_deprecated_message = true;
1199 }
1200 
1201 void
1203  const std::string & common_name,
1204  bool allow_private)
1205 {
1206  // Disable the display of deprecated message when applying common parameters, this avoids a dump
1207  // of messages
1208  _show_deprecated_message = false;
1209 
1210  const auto local_name = checkForRename(common_name);
1211 
1212  // Extract the properties from the local parameter for the current common parameter name
1213  const bool local_exist = _values.find(local_name) != _values.end();
1214  const bool local_set = _params.count(local_name) > 0 && !_params[local_name]._set_by_add_param;
1215  const bool local_priv = allow_private ? false : isPrivate(local_name);
1216  const bool local_valid = isParamValid(local_name);
1217 
1218  // Extract the properties from the common parameter
1219  const bool common_exist = common._values.find(common_name) != common._values.end();
1220  const bool common_priv = allow_private ? false : common.isPrivate(common_name);
1221  const bool common_valid = common.isParamValid(common_name);
1222 
1223  /* In order to apply a common parameter 4 statements must be satisfied
1224  * (1) A local parameter must exist with the same name as the common parameter
1225  * (2) Common parameter must be valid and exist
1226  * (3) Local parameter must be invalid OR not have been set from its default
1227  * (4) Both cannot be private
1228  */
1229  if (local_exist && common_exist && common_valid && (!local_valid || !local_set) &&
1230  (!common_priv || !local_priv))
1231  {
1232  remove(local_name);
1233  _values[local_name] = common._values.find(common_name)->second->clone();
1234  set_attributes(local_name, false);
1235  _params[local_name]._set_by_add_param =
1236  libmesh_map_find(common._params, common_name)._set_by_add_param;
1237  // Keep track of where this param came from if we can. This will enable us to
1238  // produce param errors from objects created within an action that link to
1239  // the parameter in the action
1240  at(local_name)._hit_node = common.getHitNode(common_name);
1241  }
1242  else if (!local_exist && !common_exist)
1243  mooseError("InputParameters::applyParameter(): Attempted to apply invalid parameter \"",
1244  common_name,
1245  "\"");
1246 
1247  // Enable deprecated message printing
1248  _show_deprecated_message = true;
1249 }
1250 
1252 bool
1253 InputParameters::paramSetByUser(const std::string & name) const
1254 {
1255  mooseDeprecated("paramSetByUser() is deprecated. Use isParamSetByUser() instead.");
1256  return isParamSetByUser(name);
1257 }
1258 
1259 bool
1260 InputParameters::isParamSetByUser(const std::string & name_in) const
1261 {
1262  const auto name = checkForRename(name_in);
1263  // Invalid; for sure not set by the user
1264  if (!isParamValid(name))
1265  return false;
1266  // Parameter is not located in the list (called Parameters::set)
1267  if (!_params.count(name))
1268  return false;
1269  // Special case for a command line option, which is a private parameter
1270  if (const auto cl_data = queryCommandLineMetadata(name))
1271  return cl_data->set_by_command_line;
1272  // Not a command line option, not set by addParam and not private
1273  return !_params.at(name)._set_by_add_param && !_params.at(name)._is_private;
1274 }
1275 
1276 bool
1277 InputParameters::isParamDefined(const std::string & name_in) const
1278 {
1279  const auto name = checkForRename(name_in);
1280  return _params.count(name) > 0;
1281 }
1282 
1283 const std::string &
1284 InputParameters::getDescription(const std::string & name_in) const
1285 {
1286  const auto name = checkForRename(name_in);
1287  auto it = _params.find(name);
1288  if (it == _params.end())
1289  mooseError("No parameter exists with the name ", name);
1290  return it->second._doc_string;
1291 }
1292 
1293 template <>
1294 void
1295 InputParameters::addRequiredParam<MooseEnum>(const std::string & name,
1296  const MooseEnum & moose_enum,
1297  const std::string & doc_string)
1298 {
1299  InputParameters::set<MooseEnum>(name) = moose_enum; // valid parameter is set by set_attributes
1300  auto & metadata = _params[name];
1301  metadata._required = true;
1302  metadata._doc_string = doc_string;
1303 }
1304 
1305 template <>
1306 void
1307 InputParameters::addRequiredParam<MultiMooseEnum>(const std::string & name,
1308  const MultiMooseEnum & moose_enum,
1309  const std::string & doc_string)
1310 {
1311  InputParameters::set<MultiMooseEnum>(name) =
1312  moose_enum; // valid parameter is set by set_attributes
1313  auto & metadata = _params[name];
1314  metadata._required = true;
1315  metadata._doc_string = doc_string;
1316 }
1317 
1318 template <>
1319 void
1320 InputParameters::addRequiredParam<std::vector<MooseEnum>>(
1321  const std::string & name,
1322  const std::vector<MooseEnum> & moose_enums,
1323  const std::string & doc_string)
1324 {
1325  InputParameters::set<std::vector<MooseEnum>>(name) =
1326  moose_enums; // valid parameter is set by set_attributes
1327  auto & metadata = _params[name];
1328  metadata._required = true;
1329  metadata._doc_string = doc_string;
1330 }
1331 
1332 template <>
1333 void
1334 InputParameters::addRequiredParam<std::vector<MultiMooseEnum>>(
1335  const std::string & name,
1336  const std::vector<MultiMooseEnum> & moose_enums,
1337  const std::string & doc_string)
1338 {
1339  mooseAssert(
1340  moose_enums.size() == 1,
1341  "Only 1 MultiMooseEnum is supported in addRequiredParam<std::vector<MultiMooseEnum>> for " +
1342  name);
1343  mooseAssert(!moose_enums[0].items().empty(),
1344  "The MultiMooseEnum in addRequiredParam<std::vector<MultiMooseEnum>> is empty for " +
1345  name);
1346  InputParameters::set<std::vector<MultiMooseEnum>>(name) =
1347  moose_enums; // valid parameter is set by set_attributes
1348  auto & metadata = _params[name];
1349  metadata._required = true;
1350  metadata._doc_string = doc_string;
1351 }
1352 
1353 template <>
1354 void
1355 InputParameters::addParam<MooseEnum>(const std::string & /*name*/,
1356  const std::string & /*doc_string*/)
1357 {
1358  mooseError("You must supply a MooseEnum object when using addParam, even if the parameter is not "
1359  "required!");
1360 }
1361 
1362 template <>
1363 void
1364 InputParameters::addParam<MultiMooseEnum>(const std::string & /*name*/,
1365  const std::string & /*doc_string*/)
1366 {
1367  mooseError("You must supply a MultiMooseEnum object when using addParam, even if the parameter "
1368  "is not required!");
1369 }
1370 
1371 template <>
1372 void
1373 InputParameters::addParam<std::vector<MooseEnum>>(const std::string & /*name*/,
1374  const std::string & /*doc_string*/)
1375 {
1376  mooseError("You must supply a vector of MooseEnum object(s) when using addParam, even if the "
1377  "parameter is not required!");
1378 }
1379 
1380 template <>
1381 void
1382 InputParameters::addParam<std::vector<MultiMooseEnum>>(const std::string & /*name*/,
1383  const std::string & /*doc_string*/)
1384 {
1385  mooseError(
1386  "You must supply a vector of MultiMooseEnum object(s) when using addParam, even if the "
1387  "parameter is not required!");
1388 }
1389 
1390 template <>
1391 void
1392 InputParameters::addRequiredParam<std::vector<MultiMooseEnum>>(const std::string & /*name*/,
1393  const std::string & /*doc_string*/)
1394 {
1395  mooseError("You must supply a vector of MultiMooseEnum object(s) when using addRequiredParam!");
1396 }
1397 
1398 template <>
1399 void
1400 InputParameters::addPrivateParam<MooseEnum>(const std::string & /*name*/)
1401 {
1402  mooseError("You must supply a MooseEnum object when using addPrivateParam, even if the parameter "
1403  "is not required!");
1404 }
1405 
1406 template <>
1407 void
1408 InputParameters::addPrivateParam<MultiMooseEnum>(const std::string & /*name*/)
1409 {
1410  mooseError("You must supply a MultiMooseEnum object when using addPrivateParam, even if the "
1411  "parameter is not required!");
1412 }
1413 
1414 template <>
1415 void
1416 InputParameters::addDeprecatedParam<MooseEnum>(const std::string & /*name*/,
1417  const std::string & /*doc_string*/,
1418  const std::string & /*deprecation_message*/)
1419 {
1420  mooseError("You must supply a MooseEnum object and the deprecation string when using "
1421  "addDeprecatedParam, even if the parameter is not required!");
1422 }
1423 
1424 template <>
1425 void
1426 InputParameters::addDeprecatedParam<MultiMooseEnum>(const std::string & /*name*/,
1427  const std::string & /*doc_string*/,
1428  const std::string & /*deprecation_message*/)
1429 {
1430  mooseError("You must supply a MultiMooseEnum object and the deprecation string when using "
1431  "addDeprecatedParam, even if the parameter is not required!");
1432 }
1433 
1434 template <>
1435 void
1436 InputParameters::addDeprecatedParam<std::vector<MooseEnum>>(
1437  const std::string & /*name*/,
1438  const std::string & /*doc_string*/,
1439  const std::string & /*deprecation_message*/)
1440 {
1441  mooseError("You must supply a vector of MooseEnum object(s) and the deprecation string when "
1442  "using addDeprecatedParam, even if the parameter is not required!");
1443 }
1444 
1445 template <>
1446 void
1447 InputParameters::setParamHelper<PostprocessorName, Real>(const std::string & /*name*/,
1448  PostprocessorName & l_value,
1449  const Real & r_value)
1450 {
1451  // Assign the default value so that it appears in the dump
1452  std::ostringstream oss;
1453  oss << r_value;
1454  l_value = oss.str();
1455 }
1456 
1457 template <>
1458 void
1459 InputParameters::setParamHelper<PostprocessorName, int>(const std::string & /*name*/,
1460  PostprocessorName & l_value,
1461  const int & r_value)
1462 {
1463  // Assign the default value so that it appears in the dump
1464  std::ostringstream oss;
1465  oss << r_value;
1466  l_value = oss.str();
1467 }
1468 
1469 template <>
1470 void
1471 InputParameters::setParamHelper<FunctionName, Real>(const std::string & /*name*/,
1472  FunctionName & l_value,
1473  const Real & r_value)
1474 {
1475  // Assign the default value so that it appears in the dump
1476  std::ostringstream oss;
1477  oss << r_value;
1478  l_value = oss.str();
1479 }
1480 
1481 template <>
1482 void
1483 InputParameters::setParamHelper<FunctionName, int>(const std::string & /*name*/,
1484  FunctionName & l_value,
1485  const int & r_value)
1486 {
1487  // Assign the default value so that it appears in the dump
1488  std::ostringstream oss;
1489  oss << r_value;
1490  l_value = oss.str();
1491 }
1492 
1493 template <>
1494 void
1495 InputParameters::setParamHelper<MaterialPropertyName, Real>(const std::string & /*name*/,
1496  MaterialPropertyName & l_value,
1497  const Real & r_value)
1498 {
1499  // Assign the default value so that it appears in the dump
1500  std::ostringstream oss;
1501  oss << r_value;
1502  l_value = oss.str();
1503 }
1504 
1505 template <>
1506 void
1507 InputParameters::setParamHelper<MaterialPropertyName, int>(const std::string & /*name*/,
1508  MaterialPropertyName & l_value,
1509  const int & r_value)
1510 {
1511  // Assign the default value so that it appears in the dump
1512  std::ostringstream oss;
1513  oss << r_value;
1514  l_value = oss.str();
1515 }
1516 
1517 template <>
1518 void
1519 InputParameters::setParamHelper<MooseFunctorName, Real>(const std::string & /*name*/,
1520  MooseFunctorName & l_value,
1521  const Real & r_value)
1522 {
1523  // Assign the default value so that it appears in the dump
1524  std::ostringstream oss;
1525  oss << r_value;
1526  l_value = oss.str();
1527 }
1528 
1529 template <>
1530 void
1531 InputParameters::setParamHelper<MooseFunctorName, int>(const std::string & /*name*/,
1532  MooseFunctorName & l_value,
1533  const int & r_value)
1534 {
1535  // Assign the default value so that it appears in the dump
1536  std::ostringstream oss;
1537  oss << r_value;
1538  l_value = oss.str();
1539 }
1540 
1541 template <>
1542 const MooseEnum &
1543 InputParameters::getParamHelper<MooseEnum>(const std::string & name_in,
1544  const InputParameters & pars)
1545 {
1546  const auto name = pars.checkForRename(name_in);
1547  return pars.get<MooseEnum>(name);
1548 }
1549 
1550 template <>
1551 const MultiMooseEnum &
1552 InputParameters::getParamHelper<MultiMooseEnum>(const std::string & name_in,
1553  const InputParameters & pars)
1554 {
1555  const auto name = pars.checkForRename(name_in);
1556  return pars.get<MultiMooseEnum>(name);
1557 }
1558 
1559 void
1560 InputParameters::setReservedValues(const std::string & name_in,
1561  const std::set<std::string> & reserved)
1562 {
1563  const auto name = checkForRename(name_in);
1564  _params[name]._reserved_values = reserved;
1565 }
1566 
1567 std::set<std::string>
1568 InputParameters::reservedValues(const std::string & name_in) const
1569 {
1570  const auto name = checkForRename(name_in);
1571  auto it = _params.find(name);
1572  if (it == _params.end())
1573  return std::set<std::string>();
1574  return it->second._reserved_values;
1575 }
1576 
1577 std::string
1579 {
1580  if (const auto hit_node = getHitNode())
1581  return hit_node->fileLocation(/* with_column = */ false);
1582  return "";
1583 }
1584 
1585 std::string
1587 {
1588  if (const auto hit_node = getHitNode())
1589  return hit_node->fullpath();
1590  return "";
1591 }
1592 
1593 const hit::Node *
1594 InputParameters::getHitNode(const std::string & param) const
1595 {
1596  return at(param)._hit_node;
1597 }
1598 
1599 void
1600 InputParameters::setHitNode(const std::string & param,
1601  const hit::Node & node,
1603 {
1604  mooseAssert(node.type() == hit::NodeType::Field, "Must be a field");
1605  at(param)._hit_node = &node;
1606 }
1607 
1608 std::string
1609 InputParameters::inputLocation(const std::string & param) const
1610 {
1611  if (const auto hit_node = getHitNode(param))
1612  return hit_node->fileLocation(/* with_column = */ false);
1613  return "";
1614 }
1615 
1616 std::string
1617 InputParameters::paramFullpath(const std::string & param) const
1618 {
1619  if (const auto hit_node = getHitNode(param))
1620  return hit_node->fullpath();
1621  return "";
1622 }
1623 
1624 void
1625 InputParameters::checkParamName(const std::string & name) const
1626 {
1627  const static pcrecpp::RE valid("[\\w:/]+");
1628  if (!valid.FullMatch(name))
1629  mooseError("Invalid parameter name: '", name, "'");
1630 }
1631 
1632 bool
1633 InputParameters::shouldIgnore(const std::string & name_in)
1634 {
1635  const auto name = checkForRename(name_in);
1636  auto it = _params.find(name);
1637  if (it != _params.end())
1638  return it->second._ignore;
1639  mooseError("Parameter ", name, " does not exist");
1640 }
1641 
1642 std::set<std::string>
1643 InputParameters::getGroupParameters(const std::string & group) const
1644 {
1645  std::set<std::string> names;
1646  for (auto it = _params.begin(); it != _params.end(); ++it)
1647  if (it->second._group == group)
1648  names.emplace(it->first);
1649  return names;
1650 }
1651 
1652 std::set<std::string>
1654 {
1655  std::set<std::string> param_set;
1656  for (auto it = _params.begin(); it != _params.end(); ++it)
1657  param_set.emplace(it->first);
1658  return param_set;
1659 }
1660 
1661 std::set<std::string>
1663 {
1664  std::set<std::string> controllable;
1665  for (auto it = _params.begin(); it != _params.end(); ++it)
1666  if (it->second._controllable)
1667  controllable.emplace(it->first);
1668  return controllable;
1669 }
1670 
1671 std::string
1672 InputParameters::paramLocationPrefix(const std::string & param) const
1673 {
1674  auto prefix = param + ":";
1675  if (!inputLocation(param).empty())
1676  prefix = inputLocation(param) + ": (" + paramFullpath(param) + ")";
1677  return prefix;
1678 }
1679 
1680 std::string
1681 InputParameters::rawParamVal(const std::string & param) const
1682 {
1683  if (const auto hit_node = getHitNode(param))
1684  return hit_node->strVal();
1685  return "";
1686 }
1687 
1688 std::string
1689 InputParameters::varName(const std::string & var_param_name,
1690  const std::string & moose_object_with_var_param_name) const
1691 {
1692  // Try the scalar version first
1693  std::string variable_name = getMooseType(var_param_name);
1694  if (variable_name == "")
1695  {
1696  auto vec = getVecMooseType(var_param_name);
1697 
1698  // Catch the (very unlikely) case where a user specifies
1699  // variable = '' (the empty string)
1700  // in their input file. This could happen if e.g. something goes
1701  // wrong with dollar bracket expression expansion.
1702  if (vec.empty())
1703  mooseError("Error constructing object '",
1704  moose_object_with_var_param_name,
1705  "' while retrieving value for '",
1706  var_param_name,
1707  "' parameter! Did you forget to set '",
1708  var_param_name,
1709  "' or set it to '' (empty string) by accident?");
1710 
1711  // When using vector variables, we are only going to use the first one in the list at the
1712  // interface level...
1713  variable_name = vec[0];
1714  }
1715 
1716  return variable_name;
1717 }
1718 
1719 void
1720 InputParameters::renameParamInternal(const std::string & old_name,
1721  const std::string & new_name,
1722  const std::string & docstring,
1723  const std::string & removal_date)
1724 {
1725  auto params_it = _params.find(old_name);
1726  if (params_it == _params.end())
1727  mooseError("Requested to rename parameter '",
1728  old_name,
1729  "' but that parameter name doesn't exist in the parameters object.");
1730  mooseAssert(params_it->second._deprecation_message.empty(),
1731  "Attempting to rename the parameter, '" << old_name << "', that is deprecated");
1732 
1733  auto new_metadata = std::move(params_it->second);
1734  if (!docstring.empty())
1735  new_metadata._doc_string = docstring;
1736  _params.emplace(new_name, std::move(new_metadata));
1737  _params.erase(params_it);
1738 
1739  auto values_it = _values.find(old_name);
1740  auto new_value = std::move(values_it->second);
1741  _values.emplace(new_name, std::move(new_value));
1742  _values.erase(values_it);
1743 
1744  std::string deprecation_message;
1745  if (!removal_date.empty())
1746  deprecation_message = "'" + old_name + "' has been deprecated and will be removed on " +
1747  removal_date + ". Please use '" + new_name + "' instead.";
1748 
1749  _old_to_new_name_and_dep.emplace(old_name, std::make_pair(new_name, deprecation_message));
1750  _new_to_old_names.emplace(new_name, old_name);
1751 }
1752 
1753 void
1754 InputParameters::renameCoupledVarInternal(const std::string & old_name,
1755  const std::string & new_name,
1756  const std::string & docstring,
1757  const std::string & removal_date)
1758 {
1759  auto coupled_vars_it = _coupled_vars.find(old_name);
1760  if (coupled_vars_it == _coupled_vars.end())
1761  mooseError("Requested to rename coupled variable '",
1762  old_name,
1763  "' but that coupled variable name doesn't exist in the parameters object.");
1764 
1765  _coupled_vars.insert(new_name);
1766  _coupled_vars.erase(coupled_vars_it);
1767 
1768  renameParamInternal(old_name, new_name, docstring, removal_date);
1769 }
1770 
1771 void
1772 InputParameters::renameParam(const std::string & old_name,
1773  const std::string & new_name,
1774  const std::string & new_docstring)
1775 {
1776  renameParamInternal(old_name, new_name, new_docstring, "");
1777 }
1778 
1779 void
1780 InputParameters::renameCoupledVar(const std::string & old_name,
1781  const std::string & new_name,
1782  const std::string & new_docstring)
1783 {
1784  renameCoupledVarInternal(old_name, new_name, new_docstring, "");
1785 }
1786 
1787 void
1788 InputParameters::deprecateParam(const std::string & old_name,
1789  const std::string & new_name,
1790  const std::string & removal_date)
1791 {
1792  renameParamInternal(old_name, new_name, "", removal_date);
1793 }
1794 
1795 void
1796 InputParameters::deprecateCoupledVar(const std::string & old_name,
1797  const std::string & new_name,
1798  const std::string & removal_date)
1799 {
1800  renameCoupledVarInternal(old_name, new_name, "", removal_date);
1801 }
1802 
1803 std::string
1804 InputParameters::checkForRename(const std::string & name) const
1805 {
1806  if (auto it = _old_to_new_name_and_dep.find(name); it != _old_to_new_name_and_dep.end())
1807  return it->second.first;
1808  else
1809  return name;
1810 }
1811 
1812 std::vector<std::string>
1813 InputParameters::paramAliases(const std::string & param_name) const
1814 {
1815  mooseAssert(_values.find(param_name) != _values.end(),
1816  "The parameter we are searching for aliases for should exist in our parameter map");
1817  std::vector<std::string> aliases = {param_name};
1818 
1819  for (const auto & pr : as_range(_new_to_old_names.equal_range(param_name)))
1820  aliases.push_back(pr.second);
1821 
1822  return aliases;
1823 }
1824 
1825 std::optional<Moose::DataFileUtils::Path>
1826 InputParameters::queryDataFileNamePath(const std::string & name) const
1827 {
1829 }
1830 
1831 std::optional<std::string>
1832 InputParameters::setupVariableNames(std::vector<VariableName> & names,
1833  const hit::Node & node,
1835 {
1836  // Whether or not a name was found
1837  bool has_name = false;
1838  // Whether or not a default value (real) was found
1839  bool has_default = false;
1840 
1841  // Search through the names for values that convert to Real values,
1842  // which are default values. If defaults are found, set appropriately
1843  // in the InputParameters object. Keep track of if names or defaults
1844  // were found because we don't allow having both
1845  for (const auto i : index_range(names))
1846  {
1847  auto & name = names[i];
1848  Real real_value;
1849  if (MooseUtils::convert<Real>(name, real_value, false))
1850  {
1851  has_default = true;
1852  defaultCoupledValue(node.path(), real_value, i);
1853  }
1854  else
1855  has_name = true;
1856  }
1857 
1858  if (has_default)
1859  {
1860  if (has_name)
1861  return {"invalid value for '" + node.fullpath() +
1862  "': coupled vectors where some parameters are reals and others are variables are not "
1863  "supported"};
1864 
1865  // Don't actually use the names if these don't represent names
1866  names.clear();
1867  }
1868 
1869  return {};
1870 }
1871 
1872 std::pair<std::string, const hit::Node *>
1873 InputParameters::paramMessageContext(const std::string & param) const
1874 {
1875  const hit::Node * node = nullptr;
1876 
1877  std::string fullpath;
1878  // First try to find the parameter
1879  if (const hit::Node * param_node = getHitNode(param))
1880  {
1881  fullpath = param_node->fullpath();
1882  node = param_node;
1883  }
1884  // If no parameter node, hope for a block node
1885  else if (const hit::Node * block_node = getHitNode())
1886  {
1887  node = block_node;
1888  fullpath = block_node->fullpath() + "/" + param;
1889  }
1890  // Didn't find anything, at least use the parameter
1891  else
1892  fullpath = param;
1893 
1894  return {fullpath + ": ", node};
1895 }
1896 
1897 std::string
1898 InputParameters::paramMessagePrefix(const std::string & param) const
1899 {
1900  auto [prefix, node] = paramMessageContext(param);
1901  if (node)
1902  prefix = Moose::hitMessagePrefix(*node) + prefix;
1903  return prefix;
1904 }
1905 
1906 [[noreturn]] void
1908  const bool with_prefix /* = true */,
1909  const hit::Node * node /* = nullptr */,
1910  const bool show_trace /* = true */) const
1911 {
1912  // Find the context of the app if we can. This will let our errors be
1913  // prefixed by the multiapp name (if applicable) and will flush the
1914  // console before outputting an error
1915  MooseApp * app = nullptr;
1916  if (isMooseBaseObject() && have_parameter<MooseApp *>(MooseBase::app_param))
1917  app = get<MooseApp *>(MooseBase::app_param);
1918 
1919  MooseBase::callMooseError(app, *this, msg, with_prefix, node, show_trace);
1920 }
std::multimap< std::string, std::string > _new_to_old_names
A map from derived-class/blessed parameter names to associated base-class/deprecated parameter names...
std::string name(const ElemQuality q)
std::optional< std::string > queryDeprecatedParamMessage(const std::string &name) const
std::string getMooseType(const std::string &name) const
Utility functions for retrieving one of the MooseTypes variables into the common "string" base class...
bool isRangeChecked(const std::string &param_name) const
Return whether a parameter has a range check.
void renameParam(const std::string &old_name, const std::string &new_name, const std::string &new_docstring)
Rename a parameter and provide a new documentation string.
bool isParamDefined(const std::string &name) const
Method returns true if the parameter is defined for any type.
const hit::Node * getHitNode(const std::string &param) const
static const std::string name_param
The name of the parameter that contains the object name.
Definition: MooseBase.h:55
KOKKOS_INLINE_FUNCTION const T * find(const T &target, const T *const begin, const T *const end)
Find a value in an array.
Definition: KokkosUtils.h:40
static const std::string app_param
The name of the parameter that contains the MooseApp.
Definition: MooseBase.h:59
void setGlobalCommandLineParam(const std::string &name)
Sets the command line parameter with name as global.
bool hasCoupledValue(const std::string &coupling_name) const
Return whether or not the coupled variable exists.
void isValid(MooseObject *obj)
Definition: TheWarehouse.C:294
bool _allow_copy
A flag for toggling the error message in the copy constructor.
void tokenize(const std::string &str, std::vector< T > &elements, unsigned int min_len=1, const std::string &delims="/")
This function will split the passed in string on a set of delimiters appending the substrings to the ...
bool search_all_data
Whether or not to search all registered data.
Definition: DataFileUtils.h:67
RelationshipManagerType
Main types of Relationship Managers.
Definition: MooseTypes.h:1012
InputParameters & operator=(const InputParameters &rhs)
void setDocUnit(const std::string &name, const std::string &doc_unit)
Set the unit string of a parameter.
std::map< std::string, std::pair< std::string, std::string > > getAutoBuildVectors() const
Returns the auto build vectors for all parameters.
static const std::string type_param
The name of the parameter that contains the object type.
Definition: MooseBase.h:53
std::set< std::string > getParametersList() const
void applySpecificParameters(const InputParameters &common, const std::vector< std::string > &include, bool allow_private=false)
Method for applying common parameters.
void setDocString(const std::string &name, const std::string &doc)
Set the doc string of a parameter.
bool isParamDeprecated(const std::string &name) const
Returns True if the parameters is deprecated.
const std::vector< std::tuple< std::string, Moose::RelationshipManagerType, Moose::RelationshipManagerInputParameterCallback > > & getBuildableRelationshipManagerTypes() const
Returns the list of buildable (or required) RelationshipManager object types for this object...
const std::string & getObjectName() const
bool isControllable(const std::string &name) const
Returns a Boolean indicating whether the specified parameter is controllable.
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
std::set< ExecFlagType > _controllable_flags
Controllable execute flag restriction.
const hit::Node * _hit_node
Original location of parameter node; used for error messages.
char ** vars
std::unordered_map< std::string, std::string > _new_to_deprecated_coupled_vars
A map from deprecated coupled variable names to the new blessed name.
const std::vector< std::string > & getBuildableTypes() const
Returns the list of buildable types as a std::vector<std::string>
void setDeprecatedVarDocString(const std::string &new_name, const std::string &doc_string)
Private method for setting deprecated coupled variable documentation strings.
InputParameters & operator+=(const InputParameters &rhs)
bool isKokkosObject() const
Returns whether this InputParameters belongs to a Kokkos object Checks whether MooseBase::kokkos_obje...
std::optional< Moose::DataFileUtils::Path > _data_file_name_path
The searched path information pertaining to a DataFileName parameter.
void registerSystemAttributeName(const std::string &value)
This method is used to define the MOOSE system name that is used by the TheWarehouse object for stori...
Base class for MOOSE-based applications.
Definition: MooseApp.h:108
The main MOOSE class responsible for handling user-defined parameters in almost every MOOSE system...
void applyParameters(const InputParameters &common, const std::vector< std::string > &exclude={}, const bool allow_private=false)
Method for applying common parameters.
void renameCoupledVar(const std::string &old_name, const std::string &new_name, const std::string &new_docstring)
Rename a coupled variable and provide a new documentation string.
bool graceful
Whether or not to error whenever a path is not found.
Definition: DataFileUtils.h:72
bool hasBase() const
void applyCoupledVar(const InputParameters &common, const std::string &var_name)
Apply properties of a single coupled variable in common, to a single coupled variable stored in this ...
void registerBuildableTypes(const std::string &names)
This method is here to indicate which Moose types a particular Action may build.
bool isPrivate(const std::string &name) const
Returns a Boolean indicating whether the specified parameter is private or not.
void mooseError(Args &&... args) const
Emits an error prefixed with the object information, if available.
std::vector< std::string > paramAliases(const std::string &param_name) const
Return all the aliased names associated with param_name.
void addRelationshipManager(const std::string &name, Moose::RelationshipManagerType rm_type, Moose::RelationshipManagerInputParameterCallback input_parameter_callback=nullptr)
Tells MOOSE about a RelationshipManager that this object needs.
void renameParameterGroup(const std::string &old_name, const std::string &new_name)
This method renames a parameter group.
void finalize(const std::string &parsing_syntax)
Finalizes the parameters, which must be done before constructing any objects with these parameters (t...
const std::string & getBase() const
void checkParamName(const std::string &name) const
Make sure the parameter name doesn&#39;t have any invalid characters.
void renameParamInternal(const std::string &old_name, const std::string &new_name, const std::string &docstring, const std::string &removal_date)
bool mooseObjectSyntaxVisibility() const
unsigned int numberDefaultCoupledValues(const std::string &coupling_name) const
Get the number of defaulted coupled value entries.
void registerBase(const std::string &value)
This method must be called from every base "Moose System" to create linkage with the Action System...
const std::string * queryObjectType() const
const std::string & getDescription(const std::string &name) const
Get the documentation string for a parameter.
void paramError(const std::string &param, Args... args) const
Emits a parameter error prefixed with the parameter location and object information if available...
Structure for storing information about a command line parameter.
bool isParamSetByAddParam(const std::string &name) const
Returns whether or not the parameter was set due to addParam.
void commandLineParamSet(const std::string &name, const CommandLineParamSetKey)
Marks the command line parameter name as set by the CommandLine.
bool _show_deprecated_message
Flag for disabling deprecated parameters message, this is used by applyParameters to avoid dumping me...
Path getPath(std::string path, const GetPathOptions &options={})
Get the data path for a given path, searching the registered data.
Definition: DataFileUtils.C:22
static const std::string moose_base_param
The name of the parameter that contains the moose system base.
Definition: MooseBase.h:61
bool _collapse_nesting
This parameter collapses one level of nesting in the syntax blocks.
std::string getDocString(const std::string &name) const
Returns the documentation string for the specified parameter name.
static const std::string kokkos_object_param
The name of the parameter that indicates an object is a Kokkos functor.
Definition: MooseBase.h:64
Real value(unsigned n, unsigned alpha, unsigned beta, Real x)
void deprecateParam(const std::string &old_name, const std::string &new_name, const std::string &removal_date)
sideset clear()
Class that is used as a parameter to commandLineParamSet() that allows only the CommandLine to set th...
std::string getDocUnit(const std::string &name) const
Returns the documentation unit string for the specified parameter name.
bool shouldIgnore(const std::string &name)
Whether to ignore the value of an input parameter set in the input file or from the command line...
std::pair< std::string, const hit::Node * > paramMessageContext(const std::string &param) const
Get the context associated with a parameter for a message.
std::function< void(const InputParameters &, InputParameters &)> RelationshipManagerInputParameterCallback
The type for the callback to set RelationshipManager parameters.
Definition: MooseTypes.h:1038
bool hasDefaultCoupledValue(const std::string &coupling_name) const
Return whether or not the requested parameter has a default coupled value.
bool areAllRequiredParamsValid() const
This method returns true if all of the parameters in this object are valid (i.e.
std::string rawParamVal(const std::string &param) const
Real defaultCoupledValue(const std::string &coupling_name, unsigned int i=0) const
Get the default value for an optionally coupled variable.
SimpleRange< IndexType > as_range(const std::pair< IndexType, IndexType > &p)
void addDeprecatedCoupledVar(const std::string &old_name, const std::string &new_name, const std::string &removal_date="")
This method adds a deprecated coupled variable name pair.
std::string _class_description
The class description for the owning object.
const std::set< ExecFlagType > & getControllableExecuteOnTypes(const std::string &name) const
Return the allowed execute flags for a controllable parameter.
void renameCoupledVarInternal(const std::string &old_name, const std::string &new_name, const std::string &docstring, const std::string &removal_date)
std::string docstring(const std::string &desc)
Augment docstring if NEML2 is not enabled.
Definition: NEML2Utils.C:71
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
Definition: MooseEnum.h:54
void deprecateCoupledVar(const std::string &old_name, const std::string &new_name, const std::string &removal_date)
void mooseDeprecated(Args &&... args)
Emit a deprecated code/feature message with the given stringified, concatenated args.
Definition: MooseError.h:363
void checkParams(const std::string &parsing_syntax)
This function checks parameters stored in the object to make sure they are in the correct state as th...
std::string inputLocation(const std::string &param) const
void applyParameter(const InputParameters &common, const std::string &common_name, bool allow_private=false)
Apply values from a single parameter in common, to a single parameter stored in this object...
Options to be passed to getPath().
Definition: DataFileUtils.h:60
bool isMooseBaseObject() const
Representation of a data file path.
Definition: DataFileUtils.h:40
std::optional< std::string > base
The base path by which to search for relative paths.
Definition: DataFileUtils.h:65
std::set< std::string > reservedValues(const std::string &name) const
Get a set of reserved parameter values.
void addCoupledVar(const std::string &name, const std::string &doc_string)
This method adds a coupled variable name pair.
void setReservedValues(const std::string &name, const std::set< std::string > &reserved)
Provide a set of reserved values for a parameter.
void addRequiredCoupledVar(const std::string &name, const std::string &doc_string)
This method adds a coupled variable name pair.
void makeParamNotRequired(const std::string &name)
Changes the parameter to not be required.
bool have_parameter(std::string_view name) const
A wrapper around the Parameters base class method.
std::optional< std::pair< bool, std::string > > parameterRangeCheck(const Parameters::Value &value, const std::string &long_name, const std::string &short_name, const bool include_param_path)
Performs a range check on the parameter (which must have a range check)
bool isParamSetByUser(const std::string &name) const
Method returns true if the parameter was set by the user.
std::string paramMessagePrefix(const std::string &param) const
Get a prefix for messages associated with a parameter.
infix_ostream_iterator< T, charT, traits > & operator=(T const &item)
Definition: InfixIterator.h:47
std::string varName(const std::string &var_param_name, const std::string &moose_object_with_var_param_name) const
Determine the actual variable name from the given variable parameter name.
const std::string & getObjectType() const
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
bool isFinalized() const
std::set< std::string > _coupled_vars
The coupled variables set.
std::vector< std::tuple< std::string, Moose::RelationshipManagerType, Moose::RelationshipManagerInputParameterCallback > > _buildable_rm_types
The RelationshipManagers that this object may either build or require.
void addRequiredCoupledVarWithAutoBuild(const std::string &name, const std::string &base_name, const std::string &num_name, const std::string &doc_string)
void addCoupledVarWithAutoBuild(const std::string &name, const std::string &base_name, const std::string &num_name, const std::string &doc_string)
These methods add a coupled variable name pair.
std::string getGroupName(const std::string &param_name) const
This method retrieves the group name for the passed parameter name if one exists. ...
std::string paramLocationPrefix(const std::string &param) const
Returns a prefix containing the parameter name and location (if available)
std::string checkForRename(const std::string &name) const
Checks whether the provided name is a renamed parameter name.
bool _finalized
Whether or not we&#39;ve called finalize() on these parameters yet.
std::string type(const std::string &name) const
Prints the type of the requested parameter by name.
Scoped helper for setting Moose::_throw_on_error during this scope.
Definition: Moose.h:295
std::string blockFullpath() const
bool isCommandLineParameter(const std::string &name) const
const hit::Node * _hit_node
The hit node representing the syntax that created these parameters, if any.
bool paramSetByUser(const std::string &name) const
Deprecated method.
std::optional< InputParameters::CommandLineMetadata > queryCommandLineMetadata(const std::string &name) const
bool isParamRequired(const std::string &name) const
Returns a boolean indicating whether the specified parameter is required or not.
void addClassDescription(const std::string &doc_string)
This method adds a description of the class that will be displayed in the input file syntax dump...
const std::string & getSystemAttributeName() const
Get the system attribute name if it was registered.
const InputParameters::CommandLineMetadata & getCommandLineMetadata(const std::string &name) const
std::vector< std::string > _buildable_types
The parameter is used to restrict types that can be built.
void addParam(const std::string &name, const S &value, const std::string &doc_string)
These methods add an optional parameter and a documentation string to the InputParameters object...
void callMooseError(std::string msg, const bool with_prefix, const hit::Node *node=nullptr, const bool show_trace=true) const
External method for calling moose error with added object context.
Definition: MooseBase.C:105
bool _moose_object_syntax_visibility
This parameter hides derived MOOSE object types from appearing in syntax dumps.
virtual void clear() override
bool hasDefault(const std::string &param_name) const
Return whether a parameter has a default.
void setHitNode(const std::string &param, const hit::Node &node, const SetParamHitNodeKey)
Sets the hit node associated with the parameter param to node.
std::map< std::string, Metadata > _params
The actual parameter data.
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type...
virtual void set_attributes(const std::string &name, bool inserted_only) override
Override from libMesh to set user-defined attributes on our parameter.
std::string blockLocation() const
std::string getClassDescription() const
Returns the class description.
InputParameters emptyInputParameters()
std::map< std::string, std::pair< std::string, std::string > > _old_to_new_name_and_dep
A map from base-class/deprecated parameter names to derived-class/blessed parameter names and the dep...
std::set< std::string > getControllableParameters() const
Return list of controllable parameters.
std::optional< Moose::DataFileUtils::Path > queryDataFileNamePath(const std::string &name) const
std::vector< ElemQuality > valid(const ElemType t)
void callMooseError(std::string msg, const bool with_prefix=true, const hit::Node *node=nullptr, const bool show_trace=true) const
Internal helper for calling back to mooseError(), ideally from the underlying MooseBase object if it ...
std::string hitMessagePrefix(const hit::Node &node)
Get the prefix to be associated with a hit node for a message.
Definition: Moose.C:832
std::filesystem::path getFileBase(const std::optional< std::string > &param_name=std::optional< std::string >()) const
std::vector< std::string > getVecMooseType(const std::string &name) const
const hit::Node * getHitNode() const
std::optional< std::string > setupVariableNames(std::vector< VariableName > &names, const hit::Node &node, const Moose::PassKey< Moose::Builder >)
Entrypoint for the Builder to setup a std::vector<VariableName> parameter, which will setup the defau...
std::optional< CommandLineMetadata > _cl_data
The data pertaining to a command line parameter (empty if not a command line param) ...
std::string stringJoin(const std::vector< std::string > &values, const std::string &separator=" ")
Concatenates value into a single string separated by separator.
Metadata & at(const std::string &param_name)
void declareControllable(const std::string &name, std::set< ExecFlagType > execute_flags={})
Declare the given parameters as controllable.
std::string paramFullpath(const std::string &param) const
auto index_range(const T &sizable)
std::string rangeCheckedFunction(const std::string &name) const
Return the range check function for any parameter (empty string if it is not range checked) ...
bool collapseSyntaxNesting() const
Class that is used as a parameter to setHitNode(param) that allows only relevant classes to set the h...
void applyCommonUserSetParameters(const InputParameters &common, const std::vector< std::string > &exclude={}, const bool allow_private=false)
Variant of applyParameters that only applies parameters explicitly set by the user in common (i...
ExecFlagEnum execute_flags
Storage for the registered execute flags.
void addParamNamesToGroup(const std::string &space_delim_names, const std::string group_name)
This method takes a space delimited list of parameter names and adds them to the specified group name...
std::set< std::string > getGroupParameters(const std::string &group) const
Return names of parameters within a group.
bool isParamValid(const std::string &name) const
This method returns parameters that have been initialized in one fashion or another, i.e.