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 bool
433 {
434  for (const auto & it : *this)
435  if (isParamRequired(it.first) && !isParamValid(it.first))
436  return false;
437  return true;
438 }
439 
440 bool
441 InputParameters::isPrivate(const std::string & name_in) const
442 {
443  const auto name = checkForRename(name_in);
444  return _params.count(name) > 0 && _params.at(name)._is_private;
445 }
446 
447 void
448 InputParameters::declareControllable(const std::string & input_names,
449  std::set<ExecFlagType> execute_flags)
450 {
451  std::vector<std::string> names;
452  MooseUtils::tokenize<std::string>(input_names, names, 1, " ");
453  for (auto & name_in : names)
454  {
455  const auto name = checkForRename(name_in);
456  auto map_iter = _params.find(name);
457  if (map_iter != _params.end()) // error is handled by checkParams method
458  {
459  map_iter->second._controllable = true;
460  map_iter->second._controllable_flags = execute_flags;
461  }
462  else
463  mooseError("The input parameter '",
464  name,
465  "' does not exist, thus cannot be marked as controllable.");
466  }
467 }
468 
469 bool
470 InputParameters::isControllable(const std::string & name_in) const
471 {
472  const auto name = checkForRename(name_in);
473  return _params.count(name) > 0 && _params.at(name)._controllable;
474 }
475 
476 const std::set<ExecFlagType> &
477 InputParameters::getControllableExecuteOnTypes(const std::string & name_in) const
478 {
479  const auto name = checkForRename(name_in);
480  return at(name)._controllable_flags;
481 }
482 
483 void
484 InputParameters::registerBase(const std::string & value)
485 {
486  InputParameters::set<std::string>(MooseBase::moose_base_param) = value;
487  _params[MooseBase::moose_base_param]._is_private = true;
488 }
489 
490 bool
492 {
493  return have_parameter<std::string>(MooseBase::moose_base_param);
494 }
495 
496 const std::string &
498 {
499  if (!have_parameter<std::string>(MooseBase::moose_base_param))
500  mooseError("InputParameters::getBase(): Parameters do not have base; one needs to be set with "
501  "registerBase()");
502  return get<std::string>(MooseBase::moose_base_param);
503 }
504 
505 void
507 {
508  InputParameters::set<std::string>("_moose_warehouse_system_name") = value;
509  _params["_moose_warehouse_system_name"]._is_private = true;
510 }
511 
512 const std::string &
514 {
515  mooseAssert(have_parameter<std::string>("_moose_warehouse_system_name"),
516  "SystemAttributeName is not available! Call 'registerSystemAttributeName' (usually "
517  "in the validParams function) before you try accessing it!");
518  return Parameters::get<std::string>("_moose_warehouse_system_name");
519 }
520 
521 void
522 InputParameters::registerBuildableTypes(const std::string & names)
523 {
524  _buildable_types.clear();
525  MooseUtils::tokenize(names, _buildable_types, 1, " \t\n\v\f\r"); // tokenize on whitespace
526 }
527 
528 void
530  const std::string & name,
532  Moose::RelationshipManagerInputParameterCallback input_parameter_callback)
533 {
534  _buildable_rm_types.emplace_back(name, rm_type, input_parameter_callback);
535 }
536 
537 const std::vector<std::string> &
539 {
540  return _buildable_types;
541 }
542 
543 const std::vector<std::tuple<std::string,
547 {
548  return _buildable_rm_types;
549 }
550 
551 void
553 {
554  _collapse_nesting = collapse;
555 }
556 
557 bool
559 {
560  return _collapse_nesting;
561 }
562 
563 void
565 {
566  _moose_object_syntax_visibility = visibility;
567 }
568 
569 bool
571 {
573 }
574 
575 #define checkMooseType(param_type, name) \
576  if (have_parameter<param_type>(name) || have_parameter<std::vector<param_type>>(name)) \
577  error = "non-controllable type '" + type(name) + "' for parameter '" + \
578  paramFullpath(param_name) + "' marked controllable";
579 
580 void
581 InputParameters::checkParams(const std::string & parsing_syntax)
582 {
583  const std::string parampath = blockFullpath() != "" ? blockFullpath() : parsing_syntax;
584 
585  // Required parameters
586  std::vector<std::string> required_param_errors;
587  for (const auto & it : *this)
588  {
589  const auto param_name = checkForRename(it.first);
590  if (!isParamValid(param_name) && isParamRequired(param_name))
591  {
592  // check if an old, deprecated name exists for this parameter that may be specified
593  auto oit = _new_to_deprecated_coupled_vars.find(param_name);
594  if (oit != _new_to_deprecated_coupled_vars.end() && isParamValid(oit->second))
595  continue;
596 
597  required_param_errors.push_back("missing required parameter '" + parampath + "/" +
598  param_name + "'\n\tDoc String: \"" +
599  getDocString(param_name) + "\"");
600  }
601  }
602 
603  if (required_param_errors.size())
604  mooseError(MooseUtils::stringJoin(required_param_errors, "\n"));
605 
606  // Range checked parameters
607  for (const auto & [name, param_ptr] : *this)
608  {
609  if (const auto error = parameterRangeCheck(*param_ptr, parampath + "/" + name, name, false))
610  {
611  if (error->first)
612  paramError(name, error->second);
613  else
614  mooseError("For range checked parameter '" + name + "': " + error->second);
615  }
616  }
617 
618  // Controllable parameters
619  for (const auto & param_name : getControllableParameters())
620  {
621  if (isPrivate(param_name))
622  paramError(param_name,
623  "private parameter '" + paramFullpath(param_name) + "' marked controllable");
624 
625  std::optional<std::string> error;
626  checkMooseType(NonlinearVariableName, param_name);
627  checkMooseType(AuxVariableName, param_name);
628  checkMooseType(VariableName, param_name);
629  checkMooseType(BoundaryName, param_name);
630  checkMooseType(SubdomainName, param_name);
631  checkMooseType(PostprocessorName, param_name);
632  checkMooseType(VectorPostprocessorName, param_name);
633  checkMooseType(UserObjectName, param_name);
634  checkMooseType(MaterialPropertyName, param_name);
635  if (error)
636  paramError(param_name, *error);
637  }
638 }
639 
640 std::optional<std::pair<bool, std::string>>
641 InputParameters::parameterRangeCheck(const Parameters::Value & value,
642  const std::string & long_name,
643  const std::string & short_name,
644  const bool include_param_path)
645 {
646 #define dynamicCastRangeCheck(type, up_type, long_name, short_name) \
647  do \
648  { \
649  if (const auto scalar_p = dynamic_cast<const InputParameters::Parameter<type> *>(&value)) \
650  return rangeCheck<type, up_type>(long_name, short_name, *scalar_p, include_param_path); \
651  if (const auto vector_p = \
652  dynamic_cast<const InputParameters::Parameter<std::vector<type>> *>(&value)) \
653  return rangeCheck<type, up_type>(long_name, short_name, *vector_p, include_param_path); \
654  } while (0)
655 
656  dynamicCastRangeCheck(Real, Real, long_name, short_name);
657  dynamicCastRangeCheck(int, long, long_name, short_name);
658  dynamicCastRangeCheck(long, long, long_name, short_name);
659  dynamicCastRangeCheck(unsigned int, long, long_name, short_name);
660 #undef dynamicCastRangeCheck
661 
662  return {};
663 }
664 
665 void
666 InputParameters::finalize(const std::string & parsing_syntax)
667 {
668  mooseAssert(!isFinalized(), "Already finalized");
669 
670  checkParams(parsing_syntax);
671 
672  // Helper for setting the absolute paths for each set file name parameter
673  const auto set_absolute_path = [this](const std::string & param_name, auto & value)
674  {
675  // We don't need to set a path if nothing is there
676  if (value.empty())
677  return;
678 
679  std::filesystem::path value_path = std::string(value);
680  // Is already absolute, nothing to do
681  if (value_path.is_absolute())
682  return;
683 
684  // The base by which to make things relative to
685  const auto file_base = getFileBase(param_name);
686  value = std::filesystem::absolute(file_base / value_path).c_str();
687  };
688 
689  // Set the absolute path for each file name typed parameter
690  for (const auto & [param_name, param_value] : *this)
691  {
692 #define set_if_filename(type) \
693  else if (auto type_value = dynamic_cast<Parameters::Parameter<type> *>(param_value.get())) \
694  set_absolute_path(param_name, type_value->set()); \
695  else if (auto type_values = dynamic_cast<Parameters::Parameter<std::vector<type>> *>( \
696  param_value.get())) for (auto & value : type_values->set()) \
697  set_absolute_path(param_name, value)
698 
699  if (false)
700  ;
701  // Note that we explicitly skip DataFileName here because we do not want absolute
702  // file paths for data files, as they're searched in the data directories
703  set_if_filename(FileName);
704  set_if_filename(FileNameNoExtension);
705  set_if_filename(MeshFileName);
706  set_if_filename(MatrixFileName);
707 #undef set_if_filename
708  // Set paths for data files
709  else if (auto data_file_name =
710  dynamic_cast<Parameters::Parameter<DataFileName> *>(param_value.get()))
711  {
712  Moose::DataFileUtils::Path found_path;
713  std::optional<std::string> error;
714 
715  // Catch this so that we can add additional error context if it fails (the param path)
716  {
717  Moose::ScopedThrowOnError scoped_throw_on_error;
718  try
719  {
720  found_path =
721  Moose::DataFileUtils::getPath(data_file_name->get(), getFileBase(param_name));
722  }
723  catch (std::exception & e)
724  {
725  error = e.what();
726  }
727  }
728 
729  if (error)
730  paramError(param_name, *error);
731 
732  // Set the value to the absolute searched path
733  data_file_name->set() = found_path.path;
734  // And store the path in metadata so that we can dump it later
735  at(param_name)._data_file_name_path = found_path;
736  }
737  }
738 
739  _finalized = true;
740 }
741 
742 std::filesystem::path
743 InputParameters::getFileBase(const std::optional<std::string> & param_name) const
744 {
745  mooseAssert(!have_parameter<std::string>("_app_name"),
746  "Not currently setup to work with app FileName parameters");
747 
748  const hit::Node * hit_node = nullptr;
749 
750  // Context from the individual parameter
751  if (param_name)
752  hit_node = getHitNode(*param_name);
753  // Context from the parameters
754  if (!hit_node)
755  hit_node = getHitNode();
756  // No hit node, so use the cwd (no input files)
757  if (!hit_node)
758  return std::filesystem::current_path();
759 
760  // Find any context that isn't command line arguments
761  while (hit_node && hit_node->filename() == "CLI_ARGS")
762  hit_node = hit_node->parent();
763 
764  // Failed to find a node up the tree that isn't a command line argument
765  if (!hit_node)
766  {
767  const std::string error = "Input context was set via a command-line argument and does not have "
768  "sufficient context for determining a file path.";
769  if (param_name)
770  paramError(*param_name, error);
771  else
772  mooseError(error);
773  }
774 
775  return std::filesystem::absolute(std::filesystem::path(hit_node->filename()).parent_path());
776 }
777 
778 bool
779 InputParameters::isRangeChecked(const std::string & param_name) const
780 {
781  const auto name = checkForRename(param_name);
782  return !_params.find(name)->second._range_function.empty();
783 }
784 
785 std::string
786 InputParameters::rangeCheckedFunction(const std::string & param_name) const
787 {
788  const auto name = checkForRename(param_name);
789  return _params.at(name)._range_function;
790 }
791 
792 bool
793 InputParameters::hasDefault(const std::string & param_name) const
794 {
795  const auto name = checkForRename(param_name);
797  return true;
798  // If it has a default, it's already valid
799  else if (isParamSetByAddParam(name))
800  return true;
801  else if (isParamValid(name))
802  mooseError("No way to know if the parameter '", param_name, "' has a default");
803  else
804  return false;
805 }
806 
807 bool
808 InputParameters::hasCoupledValue(const std::string & coupling_name) const
809 {
810  return _coupled_vars.find(coupling_name) != _coupled_vars.end();
811 }
812 
813 bool
814 InputParameters::hasDefaultCoupledValue(const std::string & coupling_name) const
815 {
816  return _params.count(coupling_name) > 0 && _params.at(coupling_name)._have_coupled_default &&
817  _coupled_vars.count(coupling_name) > 0;
818 }
819 
820 void
821 InputParameters::defaultCoupledValue(const std::string & coupling_name, Real value, unsigned int i)
822 {
823  const auto actual_name = checkForRename(coupling_name);
824  _params[actual_name]._coupled_default.resize(i + 1);
825  _params[actual_name]._coupled_default[i] = value;
826  _params[actual_name]._have_coupled_default = true;
827 }
828 
829 Real
830 InputParameters::defaultCoupledValue(const std::string & coupling_name, unsigned int i) const
831 {
832  auto value_it = _params.find(coupling_name);
833 
834  if (value_it == _params.end() || !value_it->second._have_coupled_default)
835  mooseError("Attempted to retrieve default value for coupled variable '",
836  coupling_name,
837  "' when none was provided. \n\nThere are three reasons why this may have "
838  "occurred:\n 1. The other version of params.addCoupledVar() should be used in order "
839  "to provide a default value. \n 2. This should have been a required coupled "
840  "variable added with params.addRequiredCoupledVar() \n 3. The call to get the "
841  "coupled value should have been properly guarded with isCoupled()\n");
842 
843  return value_it->second._coupled_default.at(i);
844 }
845 
846 unsigned int
847 InputParameters::numberDefaultCoupledValues(const std::string & coupling_name) const
848 {
849  auto value_it = _params.find(coupling_name);
850  if (value_it == _params.end())
851  mooseError("Attempted to retrieve default value for coupled variable '",
852  coupling_name,
853  "' when none was provided.");
854  return value_it->second._coupled_default.size();
855 }
856 
857 std::map<std::string, std::pair<std::string, std::string>>
859 {
860  std::map<std::string, std::pair<std::string, std::string>> abv;
861  for (auto it = _params.begin(); it != _params.end(); ++it)
862  {
863  if (!it->second._autobuild_vecs.first.empty())
864  abv[it->first] = it->second._autobuild_vecs;
865  }
866  return abv;
867 }
868 
869 std::string
870 InputParameters::type(const std::string & name_in) const
871 {
872  const auto name = checkForRename(name_in);
873  if (!_values.count(name))
874  mooseError("Parameter \"", name, "\" not found.\n\n", *this);
875 
876  if (_coupled_vars.find(name) != _coupled_vars.end())
877  return "std::vector<VariableName>";
878  else if (_params.count(name) > 0 && !_params.at(name)._custom_type.empty())
879  return _params.at(name)._custom_type;
880  return _values.at(name)->type();
881 }
882 
883 std::string
884 InputParameters::getMooseType(const std::string & name_in) const
885 {
886  const auto name = checkForRename(name_in);
887  std::string var;
888 
889  if (have_parameter<VariableName>(name))
890  var = get<VariableName>(name);
891  else if (have_parameter<NonlinearVariableName>(name))
892  var = get<NonlinearVariableName>(name);
893  else if (have_parameter<LinearVariableName>(name))
894  var = get<LinearVariableName>(name);
895  else if (have_parameter<AuxVariableName>(name))
896  var = get<AuxVariableName>(name);
897  else if (have_parameter<PostprocessorName>(name))
898  var = get<PostprocessorName>(name);
899  else if (have_parameter<VectorPostprocessorName>(name))
900  var = get<VectorPostprocessorName>(name);
901  else if (have_parameter<FunctionName>(name))
902  var = get<FunctionName>(name);
903  else if (have_parameter<UserObjectName>(name))
904  var = get<UserObjectName>(name);
905  else if (have_parameter<MaterialPropertyName>(name))
906  var = get<MaterialPropertyName>(name);
907  else if (have_parameter<std::string>(name))
908  var = get<std::string>(name);
909 
910  return var;
911 }
912 
913 std::vector<std::string>
914 InputParameters::getVecMooseType(const std::string & name_in) const
915 {
916  const auto name = checkForRename(name_in);
917  std::vector<std::string> svars;
918 
919  if (have_parameter<std::vector<VariableName>>(name))
920  {
921  std::vector<VariableName> vars = get<std::vector<VariableName>>(name);
922  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
923  }
924  else if (have_parameter<std::vector<NonlinearVariableName>>(name))
925  {
926  std::vector<NonlinearVariableName> vars = get<std::vector<NonlinearVariableName>>(name);
927  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
928  }
929  else if (have_parameter<std::vector<AuxVariableName>>(name))
930  {
931  std::vector<AuxVariableName> vars = get<std::vector<AuxVariableName>>(name);
932  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
933  }
934  else if (have_parameter<std::vector<MaterialPropertyName>>(name))
935  {
936  std::vector<MaterialPropertyName> vars = get<std::vector<MaterialPropertyName>>(name);
937  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
938  }
939  else if (have_parameter<std::vector<std::string>>(name))
940  {
941  std::vector<std::string> vars = get<std::vector<std::string>>(name);
942  std::copy(vars.begin(), vars.end(), std::back_inserter(svars));
943  }
944 
945  return svars;
946 }
947 
948 bool
950 {
951  return have_parameter<std::string>(MooseBase::type_param) &&
952  get<std::string>(MooseBase::type_param).size() &&
953  have_parameter<std::string>(MooseBase::name_param);
954 }
955 
956 const std::string *
958 {
959  return have_parameter<std::string>(MooseBase::type_param)
960  ? &get<std::string>(MooseBase::type_param)
961  : nullptr;
962 }
963 
964 const std::string &
966 {
967  if (const auto type_ptr = queryObjectType())
968  return *type_ptr;
969  ::mooseError("InputParameters::getObjectType(): Missing '", MooseBase::type_param, "' param");
970 }
971 
972 const std::string &
974 {
975  if (!have_parameter<std::string>(MooseBase::name_param))
976  ::mooseError("InputParameters::getObjectName(): Missing '", MooseBase::name_param, "' param");
977  return get<std::string>(MooseBase::name_param);
978 }
979 
980 void
981 InputParameters::addParamNamesToGroup(const std::string & space_delim_names,
982  const std::string group_name)
983 {
984  std::vector<std::string> elements;
985  MooseUtils::tokenize(space_delim_names, elements, 1, " \t\n\v\f\r"); // tokenize on whitespace
986 
987  // Since we don't require types (templates) for this method, we need
988  // to get a raw list of parameter names to compare against.
989  std::set<std::string> param_names;
990  for (const auto & it : *this)
991  param_names.insert(it.first);
992 
993  for (const auto & param_name : elements)
994  if (_params.count(param_name) > 0)
995  _params[param_name]._group = group_name;
996  else
997  mooseError("Unable to find a parameter with name: ",
998  param_name,
999  " when adding to group ",
1000  group_name,
1001  '.');
1002 }
1003 
1004 void
1005 InputParameters::renameParameterGroup(const std::string & old_name, const std::string & new_name)
1006 {
1007  for (auto & param : _params)
1008  if (param.second._group == old_name)
1009  param.second._group = new_name;
1010 }
1011 
1012 void
1014 {
1015  auto & cl_data = at(checkForRename(name))._cl_data;
1016  if (!cl_data)
1017  mooseError("InputParameters::setGlobalCommandLineParam: The parameter '",
1018  name,
1019  "' is not a command line parameter");
1020  cl_data->global = true;
1021 }
1022 
1023 bool
1024 InputParameters::isCommandLineParameter(const std::string & name) const
1025 {
1026  return at(checkForRename(name))._cl_data.has_value();
1027 }
1028 
1029 std::optional<InputParameters::CommandLineMetadata>
1030 InputParameters::queryCommandLineMetadata(const std::string & name) const
1031 {
1032  const auto & cl_data = at(checkForRename(name))._cl_data;
1033  if (!cl_data)
1034  return {};
1035  return *cl_data;
1036 }
1037 
1039 InputParameters::getCommandLineMetadata(const std::string & name) const
1040 {
1041  const auto & cl_data = at(checkForRename(name))._cl_data;
1042  if (!cl_data)
1043  mooseError("InputParameters::getCommandLineMetadata: The parameter '",
1044  name,
1045  "' is not a command line parameter");
1046  return *cl_data;
1047 }
1048 
1049 void
1051 {
1052  auto & cl_data = at(checkForRename(name))._cl_data;
1053  if (!cl_data)
1054  mooseError("InputParameters::commandLineParamSet: The parameter '",
1055  name,
1056  "' is not a command line parameter");
1057  cl_data->set_by_command_line = true;
1058 }
1059 
1060 std::string
1061 InputParameters::getGroupName(const std::string & param_name_in) const
1062 {
1063  const auto param_name = checkForRename(param_name_in);
1064  auto it = _params.find(param_name);
1065  if (it != _params.end())
1066  return it->second._group;
1067  return std::string();
1068 }
1069 
1070 void
1072  const std::vector<std::string> & exclude,
1073  const bool allow_private)
1074 {
1075  // If we're applying all of the things, also associate the top level hit node
1076  if (exclude.empty() && !getHitNode() && common.getHitNode())
1077  setHitNode(*common.getHitNode(), {});
1078 
1079  // Loop through the common parameters
1080  for (const auto & it : common)
1081  {
1082  // Common parameter name
1083  const std::string & common_name = it.first;
1084  // Continue to next parameter, if the current is in list of excluded parameters
1085  if (std::find(exclude.begin(), exclude.end(), common_name) != exclude.end())
1086  continue;
1087 
1088  applyParameter(common, common_name, allow_private);
1089  }
1090 
1091  // Loop through the coupled variables
1092  for (std::set<std::string>::const_iterator it = common.coupledVarsBegin();
1093  it != common.coupledVarsEnd();
1094  ++it)
1095  {
1096  // Variable name
1097  const std::string var_name = *it;
1098 
1099  // Continue to next variable, if the current is in list of excluded parameters
1100  if (std::find(exclude.begin(), exclude.end(), var_name) != exclude.end())
1101  continue;
1102 
1103  applyCoupledVar(common, var_name);
1104  }
1105 }
1106 
1107 void
1109  const std::vector<std::string> & include,
1110  bool allow_private)
1111 {
1112  // Loop through the common parameters
1113  for (const auto & it : common)
1114  {
1115  // Common parameter name
1116  const std::string & common_name = it.first;
1117 
1118  // Continue to next parameter, if the current is not in list of included parameters
1119  if (std::find(include.begin(), include.end(), common_name) == include.end())
1120  continue;
1121 
1122  applyParameter(common, common_name, allow_private);
1123  }
1124 
1125  // Loop through the coupled variables
1126  for (std::set<std::string>::const_iterator it = common.coupledVarsBegin();
1127  it != common.coupledVarsEnd();
1128  ++it)
1129  {
1130  // Variable name
1131  const std::string var_name = *it;
1132 
1133  // Continue to next variable, if the current is not in list of included parameters
1134  if (std::find(include.begin(), include.end(), var_name) == include.end())
1135  continue;
1136 
1137  applyCoupledVar(common, var_name);
1138  }
1139 }
1140 
1141 void
1142 InputParameters::applyCoupledVar(const InputParameters & common, const std::string & var_name)
1143 {
1144  // Disable the display of deprecated message when applying common parameters, this avoids a dump
1145  // of messages
1146  _show_deprecated_message = false;
1147 
1148  // If the local parameters has a coupled variable, populate it with the value from the common
1149  // parameters, if the common parameters has the coupled variable too
1150  if (hasCoupledValue(var_name))
1151  {
1152  if (common.hasDefaultCoupledValue(var_name))
1153  {
1154  // prepare a vector of default coupled values
1155  std::vector<Real> defaults(common.numberDefaultCoupledValues(var_name));
1156  for (unsigned int j = 0; j < common.numberDefaultCoupledValues(var_name); ++j)
1157  defaults[j] = common.defaultCoupledValue(var_name, j);
1158  addCoupledVar(var_name, defaults, common.getDocString(var_name));
1159  }
1160  else if (common.hasCoupledValue(var_name))
1161  addCoupledVar(var_name, common.getDocString(var_name));
1162  }
1163 
1164  // Enable deprecated message printing
1165  _show_deprecated_message = true;
1166 }
1167 
1168 void
1170  const std::string & common_name,
1171  bool allow_private,
1172  bool override_default)
1173 {
1174  // Disable the display of deprecated message when applying common parameters, this avoids a dump
1175  // of messages
1176  _show_deprecated_message = false;
1177 
1178  const auto local_name = checkForRename(common_name);
1179 
1180  // Extract the properties from the local parameter for the current common parameter name
1181  const bool local_exist = _values.find(local_name) != _values.end();
1182  const bool local_set = _params.count(local_name) > 0 && !_params[local_name]._set_by_add_param;
1183  const bool local_priv = allow_private ? false : isPrivate(local_name);
1184  const bool local_valid = isParamValid(local_name);
1185 
1186  // Extract the properties from the common parameter
1187  const bool common_exist = common._values.find(common_name) != common._values.end();
1188  const bool common_priv = allow_private ? false : common.isPrivate(common_name);
1189  const bool common_valid = common.isParamValid(common_name) || override_default;
1190 
1191  /* In order to apply a common parameter 4 statements must be satisfied
1192  * (1) A local parameter must exist with the same name as the common parameter
1193  * (2) Common parameter must be valid and exist
1194  * (3) Local parameter must be invalid OR not have been set from its default
1195  * (4) Both cannot be private
1196  */
1197  if (local_exist && common_exist && common_valid && (!local_valid || !local_set) &&
1198  (!common_priv || !local_priv))
1199  {
1200  remove(local_name);
1201  _values[local_name] = common._values.find(common_name)->second->clone();
1202  set_attributes(local_name, false);
1203  _params[local_name]._set_by_add_param =
1204  libmesh_map_find(common._params, common_name)._set_by_add_param;
1205  // Keep track of where this param came from if we can. This will enable us to
1206  // produce param errors from objects created within an action that link to
1207  // the parameter in the action
1208  at(local_name)._hit_node = common.getHitNode(common_name);
1209  }
1210  else if (!local_exist && !common_exist)
1211  mooseError("InputParameters::applyParameter(): Attempted to apply invalid parameter \"",
1212  common_name,
1213  "\"");
1214 
1215  // Enable deprecated message printing
1216  _show_deprecated_message = true;
1217 }
1218 
1220 bool
1221 InputParameters::paramSetByUser(const std::string & name) const
1222 {
1223  mooseDeprecated("paramSetByUser() is deprecated. Use isParamSetByUser() instead.");
1224  return isParamSetByUser(name);
1225 }
1226 
1227 bool
1228 InputParameters::isParamSetByUser(const std::string & name_in) const
1229 {
1230  const auto name = checkForRename(name_in);
1231  // Invalid; for sure not set by the user
1232  if (!isParamValid(name))
1233  return false;
1234  // Parameter is not located in the list (called Parameters::set)
1235  if (!_params.count(name))
1236  return false;
1237  // Special case for a command line option, which is a private parameter
1238  if (const auto cl_data = queryCommandLineMetadata(name))
1239  return cl_data->set_by_command_line;
1240  // Not a command line option, not set by addParam and not private
1241  return !_params.at(name)._set_by_add_param && !_params.at(name)._is_private;
1242 }
1243 
1244 bool
1245 InputParameters::isParamDefined(const std::string & name_in) const
1246 {
1247  const auto name = checkForRename(name_in);
1248  return _params.count(name) > 0;
1249 }
1250 
1251 const std::string &
1252 InputParameters::getDescription(const std::string & name_in) const
1253 {
1254  const auto name = checkForRename(name_in);
1255  auto it = _params.find(name);
1256  if (it == _params.end())
1257  mooseError("No parameter exists with the name ", name);
1258  return it->second._doc_string;
1259 }
1260 
1261 template <>
1262 void
1263 InputParameters::addRequiredParam<MooseEnum>(const std::string & name,
1264  const MooseEnum & moose_enum,
1265  const std::string & doc_string)
1266 {
1267  InputParameters::set<MooseEnum>(name) = moose_enum; // valid parameter is set by set_attributes
1268  auto & metadata = _params[name];
1269  metadata._required = true;
1270  metadata._doc_string = doc_string;
1271 }
1272 
1273 template <>
1274 void
1275 InputParameters::addRequiredParam<MultiMooseEnum>(const std::string & name,
1276  const MultiMooseEnum & moose_enum,
1277  const std::string & doc_string)
1278 {
1279  InputParameters::set<MultiMooseEnum>(name) =
1280  moose_enum; // valid parameter is set by set_attributes
1281  auto & metadata = _params[name];
1282  metadata._required = true;
1283  metadata._doc_string = doc_string;
1284 }
1285 
1286 template <>
1287 void
1288 InputParameters::addRequiredParam<std::vector<MooseEnum>>(
1289  const std::string & name,
1290  const std::vector<MooseEnum> & moose_enums,
1291  const std::string & doc_string)
1292 {
1293  InputParameters::set<std::vector<MooseEnum>>(name) =
1294  moose_enums; // valid parameter is set by set_attributes
1295  auto & metadata = _params[name];
1296  metadata._required = true;
1297  metadata._doc_string = doc_string;
1298 }
1299 
1300 template <>
1301 void
1302 InputParameters::addRequiredParam<std::vector<MultiMooseEnum>>(
1303  const std::string & name,
1304  const std::vector<MultiMooseEnum> & moose_enums,
1305  const std::string & doc_string)
1306 {
1307  mooseAssert(
1308  moose_enums.size() == 1,
1309  "Only 1 MultiMooseEnum is supported in addRequiredParam<std::vector<MultiMooseEnum>> for " +
1310  name);
1311  mooseAssert(!moose_enums[0].items().empty(),
1312  "The MultiMooseEnum in addRequiredParam<std::vector<MultiMooseEnum>> is empty for " +
1313  name);
1314  InputParameters::set<std::vector<MultiMooseEnum>>(name) =
1315  moose_enums; // valid parameter is set by set_attributes
1316  auto & metadata = _params[name];
1317  metadata._required = true;
1318  metadata._doc_string = doc_string;
1319 }
1320 
1321 template <>
1322 void
1323 InputParameters::addParam<MooseEnum>(const std::string & /*name*/,
1324  const std::string & /*doc_string*/)
1325 {
1326  mooseError("You must supply a MooseEnum object when using addParam, even if the parameter is not "
1327  "required!");
1328 }
1329 
1330 template <>
1331 void
1332 InputParameters::addParam<MultiMooseEnum>(const std::string & /*name*/,
1333  const std::string & /*doc_string*/)
1334 {
1335  mooseError("You must supply a MultiMooseEnum object when using addParam, even if the parameter "
1336  "is not required!");
1337 }
1338 
1339 template <>
1340 void
1341 InputParameters::addParam<std::vector<MooseEnum>>(const std::string & /*name*/,
1342  const std::string & /*doc_string*/)
1343 {
1344  mooseError("You must supply a vector of MooseEnum object(s) when using addParam, even if the "
1345  "parameter is not required!");
1346 }
1347 
1348 template <>
1349 void
1350 InputParameters::addParam<std::vector<MultiMooseEnum>>(const std::string & /*name*/,
1351  const std::string & /*doc_string*/)
1352 {
1353  mooseError(
1354  "You must supply a vector of MultiMooseEnum object(s) when using addParam, even if the "
1355  "parameter is not required!");
1356 }
1357 
1358 template <>
1359 void
1360 InputParameters::addRequiredParam<std::vector<MultiMooseEnum>>(const std::string & /*name*/,
1361  const std::string & /*doc_string*/)
1362 {
1363  mooseError("You must supply a vector of MultiMooseEnum object(s) when using addRequiredParam!");
1364 }
1365 
1366 template <>
1367 void
1368 InputParameters::addPrivateParam<MooseEnum>(const std::string & /*name*/)
1369 {
1370  mooseError("You must supply a MooseEnum object when using addPrivateParam, even if the parameter "
1371  "is not required!");
1372 }
1373 
1374 template <>
1375 void
1376 InputParameters::addPrivateParam<MultiMooseEnum>(const std::string & /*name*/)
1377 {
1378  mooseError("You must supply a MultiMooseEnum object when using addPrivateParam, even if the "
1379  "parameter is not required!");
1380 }
1381 
1382 template <>
1383 void
1384 InputParameters::addDeprecatedParam<MooseEnum>(const std::string & /*name*/,
1385  const std::string & /*doc_string*/,
1386  const std::string & /*deprecation_message*/)
1387 {
1388  mooseError("You must supply a MooseEnum object and the deprecation string when using "
1389  "addDeprecatedParam, even if the parameter is not required!");
1390 }
1391 
1392 template <>
1393 void
1394 InputParameters::addDeprecatedParam<MultiMooseEnum>(const std::string & /*name*/,
1395  const std::string & /*doc_string*/,
1396  const std::string & /*deprecation_message*/)
1397 {
1398  mooseError("You must supply a MultiMooseEnum object and the deprecation string when using "
1399  "addDeprecatedParam, even if the parameter is not required!");
1400 }
1401 
1402 template <>
1403 void
1404 InputParameters::addDeprecatedParam<std::vector<MooseEnum>>(
1405  const std::string & /*name*/,
1406  const std::string & /*doc_string*/,
1407  const std::string & /*deprecation_message*/)
1408 {
1409  mooseError("You must supply a vector of MooseEnum object(s) and the deprecation string when "
1410  "using addDeprecatedParam, even if the parameter is not required!");
1411 }
1412 
1413 template <>
1414 void
1415 InputParameters::setParamHelper<PostprocessorName, Real>(const std::string & /*name*/,
1416  PostprocessorName & l_value,
1417  const Real & r_value)
1418 {
1419  // Assign the default value so that it appears in the dump
1420  std::ostringstream oss;
1421  oss << r_value;
1422  l_value = oss.str();
1423 }
1424 
1425 template <>
1426 void
1427 InputParameters::setParamHelper<PostprocessorName, int>(const std::string & /*name*/,
1428  PostprocessorName & l_value,
1429  const int & r_value)
1430 {
1431  // Assign the default value so that it appears in the dump
1432  std::ostringstream oss;
1433  oss << r_value;
1434  l_value = oss.str();
1435 }
1436 
1437 template <>
1438 void
1439 InputParameters::setParamHelper<FunctionName, Real>(const std::string & /*name*/,
1440  FunctionName & l_value,
1441  const Real & r_value)
1442 {
1443  // Assign the default value so that it appears in the dump
1444  std::ostringstream oss;
1445  oss << r_value;
1446  l_value = oss.str();
1447 }
1448 
1449 template <>
1450 void
1451 InputParameters::setParamHelper<FunctionName, int>(const std::string & /*name*/,
1452  FunctionName & l_value,
1453  const int & r_value)
1454 {
1455  // Assign the default value so that it appears in the dump
1456  std::ostringstream oss;
1457  oss << r_value;
1458  l_value = oss.str();
1459 }
1460 
1461 template <>
1462 void
1463 InputParameters::setParamHelper<MaterialPropertyName, Real>(const std::string & /*name*/,
1464  MaterialPropertyName & l_value,
1465  const Real & r_value)
1466 {
1467  // Assign the default value so that it appears in the dump
1468  std::ostringstream oss;
1469  oss << r_value;
1470  l_value = oss.str();
1471 }
1472 
1473 template <>
1474 void
1475 InputParameters::setParamHelper<MaterialPropertyName, int>(const std::string & /*name*/,
1476  MaterialPropertyName & l_value,
1477  const int & r_value)
1478 {
1479  // Assign the default value so that it appears in the dump
1480  std::ostringstream oss;
1481  oss << r_value;
1482  l_value = oss.str();
1483 }
1484 
1485 template <>
1486 void
1487 InputParameters::setParamHelper<MooseFunctorName, Real>(const std::string & /*name*/,
1488  MooseFunctorName & l_value,
1489  const Real & r_value)
1490 {
1491  // Assign the default value so that it appears in the dump
1492  std::ostringstream oss;
1493  oss << r_value;
1494  l_value = oss.str();
1495 }
1496 
1497 template <>
1498 void
1499 InputParameters::setParamHelper<MooseFunctorName, int>(const std::string & /*name*/,
1500  MooseFunctorName & l_value,
1501  const int & r_value)
1502 {
1503  // Assign the default value so that it appears in the dump
1504  std::ostringstream oss;
1505  oss << r_value;
1506  l_value = oss.str();
1507 }
1508 
1509 template <>
1510 const MooseEnum &
1511 InputParameters::getParamHelper<MooseEnum>(const std::string & name_in,
1512  const InputParameters & pars)
1513 {
1514  const auto name = pars.checkForRename(name_in);
1515  return pars.get<MooseEnum>(name);
1516 }
1517 
1518 template <>
1519 const MultiMooseEnum &
1520 InputParameters::getParamHelper<MultiMooseEnum>(const std::string & name_in,
1521  const InputParameters & pars)
1522 {
1523  const auto name = pars.checkForRename(name_in);
1524  return pars.get<MultiMooseEnum>(name);
1525 }
1526 
1527 void
1528 InputParameters::setReservedValues(const std::string & name_in,
1529  const std::set<std::string> & reserved)
1530 {
1531  const auto name = checkForRename(name_in);
1532  _params[name]._reserved_values = reserved;
1533 }
1534 
1535 std::set<std::string>
1536 InputParameters::reservedValues(const std::string & name_in) const
1537 {
1538  const auto name = checkForRename(name_in);
1539  auto it = _params.find(name);
1540  if (it == _params.end())
1541  return std::set<std::string>();
1542  return it->second._reserved_values;
1543 }
1544 
1545 std::string
1547 {
1548  if (const auto hit_node = getHitNode())
1549  return hit_node->fileLocation(/* with_column = */ false);
1550  return "";
1551 }
1552 
1553 std::string
1555 {
1556  if (const auto hit_node = getHitNode())
1557  return hit_node->fullpath();
1558  return "";
1559 }
1560 
1561 const hit::Node *
1562 InputParameters::getHitNode(const std::string & param) const
1563 {
1564  return at(param)._hit_node;
1565 }
1566 
1567 void
1568 InputParameters::setHitNode(const std::string & param,
1569  const hit::Node & node,
1571 {
1572  mooseAssert(node.type() == hit::NodeType::Field, "Must be a field");
1573  at(param)._hit_node = &node;
1574 }
1575 
1576 std::string
1577 InputParameters::inputLocation(const std::string & param) const
1578 {
1579  if (const auto hit_node = getHitNode(param))
1580  return hit_node->fileLocation(/* with_column = */ false);
1581  return "";
1582 }
1583 
1584 std::string
1585 InputParameters::paramFullpath(const std::string & param) const
1586 {
1587  if (const auto hit_node = getHitNode(param))
1588  return hit_node->fullpath();
1589  return "";
1590 }
1591 
1592 void
1593 InputParameters::checkParamName(const std::string & name) const
1594 {
1595  const static pcrecpp::RE valid("[\\w:/]+");
1596  if (!valid.FullMatch(name))
1597  mooseError("Invalid parameter name: '", name, "'");
1598 }
1599 
1600 bool
1601 InputParameters::shouldIgnore(const std::string & name_in)
1602 {
1603  const auto name = checkForRename(name_in);
1604  auto it = _params.find(name);
1605  if (it != _params.end())
1606  return it->second._ignore;
1607  mooseError("Parameter ", name, " does not exist");
1608 }
1609 
1610 std::set<std::string>
1611 InputParameters::getGroupParameters(const std::string & group) const
1612 {
1613  std::set<std::string> names;
1614  for (auto it = _params.begin(); it != _params.end(); ++it)
1615  if (it->second._group == group)
1616  names.emplace(it->first);
1617  return names;
1618 }
1619 
1620 std::set<std::string>
1622 {
1623  std::set<std::string> param_set;
1624  for (auto it = _params.begin(); it != _params.end(); ++it)
1625  param_set.emplace(it->first);
1626  return param_set;
1627 }
1628 
1629 std::set<std::string>
1631 {
1632  std::set<std::string> controllable;
1633  for (auto it = _params.begin(); it != _params.end(); ++it)
1634  if (it->second._controllable)
1635  controllable.emplace(it->first);
1636  return controllable;
1637 }
1638 
1639 std::string
1640 InputParameters::paramLocationPrefix(const std::string & param) const
1641 {
1642  auto prefix = param + ":";
1643  if (!inputLocation(param).empty())
1644  prefix = inputLocation(param) + ": (" + paramFullpath(param) + ")";
1645  return prefix;
1646 }
1647 
1648 std::string
1649 InputParameters::rawParamVal(const std::string & param) const
1650 {
1651  if (const auto hit_node = getHitNode(param))
1652  return hit_node->strVal();
1653  return "";
1654 }
1655 
1656 std::string
1657 InputParameters::varName(const std::string & var_param_name,
1658  const std::string & moose_object_with_var_param_name) const
1659 {
1660  // Try the scalar version first
1661  std::string variable_name = getMooseType(var_param_name);
1662  if (variable_name == "")
1663  {
1664  auto vec = getVecMooseType(var_param_name);
1665 
1666  // Catch the (very unlikely) case where a user specifies
1667  // variable = '' (the empty string)
1668  // in their input file. This could happen if e.g. something goes
1669  // wrong with dollar bracket expression expansion.
1670  if (vec.empty())
1671  mooseError("Error constructing object '",
1672  moose_object_with_var_param_name,
1673  "' while retrieving value for '",
1674  var_param_name,
1675  "' parameter! Did you forget to set '",
1676  var_param_name,
1677  "' or set it to '' (empty string) by accident?");
1678 
1679  // When using vector variables, we are only going to use the first one in the list at the
1680  // interface level...
1681  variable_name = vec[0];
1682  }
1683 
1684  return variable_name;
1685 }
1686 
1687 void
1688 InputParameters::renameParamInternal(const std::string & old_name,
1689  const std::string & new_name,
1690  const std::string & docstring,
1691  const std::string & removal_date)
1692 {
1693  auto params_it = _params.find(old_name);
1694  if (params_it == _params.end())
1695  mooseError("Requested to rename parameter '",
1696  old_name,
1697  "' but that parameter name doesn't exist in the parameters object.");
1698  mooseAssert(params_it->second._deprecation_message.empty(),
1699  "Attempting to rename the parameter, '" << old_name << "', that is deprecated");
1700 
1701  auto new_metadata = std::move(params_it->second);
1702  if (!docstring.empty())
1703  new_metadata._doc_string = docstring;
1704  _params.emplace(new_name, std::move(new_metadata));
1705  _params.erase(params_it);
1706 
1707  auto values_it = _values.find(old_name);
1708  auto new_value = std::move(values_it->second);
1709  _values.emplace(new_name, std::move(new_value));
1710  _values.erase(values_it);
1711 
1712  std::string deprecation_message;
1713  if (!removal_date.empty())
1714  deprecation_message = "'" + old_name + "' has been deprecated and will be removed on " +
1715  removal_date + ". Please use '" + new_name + "' instead.";
1716 
1717  _old_to_new_name_and_dep.emplace(old_name, std::make_pair(new_name, deprecation_message));
1718  _new_to_old_names.emplace(new_name, old_name);
1719 }
1720 
1721 void
1722 InputParameters::renameCoupledVarInternal(const std::string & old_name,
1723  const std::string & new_name,
1724  const std::string & docstring,
1725  const std::string & removal_date)
1726 {
1727  auto coupled_vars_it = _coupled_vars.find(old_name);
1728  if (coupled_vars_it == _coupled_vars.end())
1729  mooseError("Requested to rename coupled variable '",
1730  old_name,
1731  "' but that coupled variable name doesn't exist in the parameters object.");
1732 
1733  _coupled_vars.insert(new_name);
1734  _coupled_vars.erase(coupled_vars_it);
1735 
1736  renameParamInternal(old_name, new_name, docstring, removal_date);
1737 }
1738 
1739 void
1740 InputParameters::renameParam(const std::string & old_name,
1741  const std::string & new_name,
1742  const std::string & new_docstring)
1743 {
1744  renameParamInternal(old_name, new_name, new_docstring, "");
1745 }
1746 
1747 void
1748 InputParameters::renameCoupledVar(const std::string & old_name,
1749  const std::string & new_name,
1750  const std::string & new_docstring)
1751 {
1752  renameCoupledVarInternal(old_name, new_name, new_docstring, "");
1753 }
1754 
1755 void
1756 InputParameters::deprecateParam(const std::string & old_name,
1757  const std::string & new_name,
1758  const std::string & removal_date)
1759 {
1760  renameParamInternal(old_name, new_name, "", removal_date);
1761 }
1762 
1763 void
1764 InputParameters::deprecateCoupledVar(const std::string & old_name,
1765  const std::string & new_name,
1766  const std::string & removal_date)
1767 {
1768  renameCoupledVarInternal(old_name, new_name, "", removal_date);
1769 }
1770 
1771 std::string
1772 InputParameters::checkForRename(const std::string & name) const
1773 {
1774  if (auto it = _old_to_new_name_and_dep.find(name); it != _old_to_new_name_and_dep.end())
1775  return it->second.first;
1776  else
1777  return name;
1778 }
1779 
1780 std::vector<std::string>
1781 InputParameters::paramAliases(const std::string & param_name) const
1782 {
1783  mooseAssert(_values.find(param_name) != _values.end(),
1784  "The parameter we are searching for aliases for should exist in our parameter map");
1785  std::vector<std::string> aliases = {param_name};
1786 
1787  for (const auto & pr : as_range(_new_to_old_names.equal_range(param_name)))
1788  aliases.push_back(pr.second);
1789 
1790  return aliases;
1791 }
1792 
1793 std::optional<Moose::DataFileUtils::Path>
1794 InputParameters::queryDataFileNamePath(const std::string & name) const
1795 {
1797 }
1798 
1799 std::optional<std::string>
1800 InputParameters::setupVariableNames(std::vector<VariableName> & names,
1801  const hit::Node & node,
1803 {
1804  // Whether or not a name was found
1805  bool has_name = false;
1806  // Whether or not a default value (real) was found
1807  bool has_default = false;
1808 
1809  // Search through the names for values that convert to Real values,
1810  // which are default values. If defaults are found, set appropriately
1811  // in the InputParameters object. Keep track of if names or defaults
1812  // were found because we don't allow having both
1813  for (const auto i : index_range(names))
1814  {
1815  auto & name = names[i];
1816  Real real_value;
1817  if (MooseUtils::convert<Real>(name, real_value, false))
1818  {
1819  has_default = true;
1820  defaultCoupledValue(node.path(), real_value, i);
1821  }
1822  else
1823  has_name = true;
1824  }
1825 
1826  if (has_default)
1827  {
1828  if (has_name)
1829  return {"invalid value for '" + node.fullpath() +
1830  "': coupled vectors where some parameters are reals and others are variables are not "
1831  "supported"};
1832 
1833  // Don't actually use the names if these don't represent names
1834  names.clear();
1835  }
1836 
1837  return {};
1838 }
1839 
1840 std::pair<std::string, const hit::Node *>
1841 InputParameters::paramMessageContext(const std::string & param) const
1842 {
1843  const hit::Node * node = nullptr;
1844 
1845  std::string fullpath;
1846  // First try to find the parameter
1847  if (const hit::Node * param_node = getHitNode(param))
1848  {
1849  fullpath = param_node->fullpath();
1850  node = param_node;
1851  }
1852  // If no parameter node, hope for a block node
1853  else if (const hit::Node * block_node = getHitNode())
1854  {
1855  node = block_node;
1856  fullpath = block_node->fullpath() + "/" + param;
1857  }
1858  // Didn't find anything, at least use the parameter
1859  else
1860  fullpath = param;
1861 
1862  return {fullpath + ": ", node};
1863 }
1864 
1865 std::string
1866 InputParameters::paramMessagePrefix(const std::string & param) const
1867 {
1868  auto [prefix, node] = paramMessageContext(param);
1869  if (node)
1870  prefix = Moose::hitMessagePrefix(*node) + prefix;
1871  return prefix;
1872 }
1873 
1874 [[noreturn]] void
1876  const bool with_prefix /* = true */,
1877  const hit::Node * node /* = nullptr */) const
1878 {
1879  // Find the context of the app if we can. This will let our errors be
1880  // prefixed by the multiapp name (if applicable) and will flush the
1881  // console before outputting an error
1882  MooseApp * app = nullptr;
1883  if (isMooseBaseObject() && have_parameter<MooseApp *>(MooseBase::app_param))
1884  app = get<MooseApp *>(MooseBase::app_param);
1885 
1886  MooseBase::callMooseError(app, *this, msg, with_prefix, node);
1887 }
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
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:287
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 ...
void callMooseError(std::string msg, const bool with_prefix, const hit::Node *node=nullptr) const
External method for calling moose error with added object context.
Definition: MooseBase.C:102
RelationshipManagerType
Main types of Relationship Managers.
Definition: MooseTypes.h:964
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:323
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)
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:96
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 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.
void callMooseError(std::string msg, const bool with_prefix=true, const hit::Node *node=nullptr) const
Internal helper for calling back to mooseError(), ideally from the underlying MooseBase object if it ...
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...
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.
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:990
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:77
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
Definition: MooseEnum.h:33
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:374
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
bool isMooseBaseObject() const
Representation of a data file path.
Definition: DataFileUtils.h:36
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:46
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.
Path getPath(std::string path, const std::optional< std::string > &base=std::optional< std::string >())
Get the data path for a given path, searching the registered data.
Definition: DataFileUtils.C:22
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:294
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...
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.
void applyParameter(const InputParameters &common, const std::string &common_name, bool allow_private=false, bool override_default=false)
Apply values from a single parameter in common, to a single parameter stored in this object...
std::optional< Moose::DataFileUtils::Path > queryDataFileNamePath(const std::string &name) const
std::vector< ElemQuality > valid(const ElemType t)
std::string hitMessagePrefix(const hit::Node &node)
Get the prefix to be associated with a hit node for a message.
Definition: Moose.C:778
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.
Definition: MooseUtils.C:951
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...
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.