98#include "AMReX_ParmParse.H"
101#define pp_query_required(...) pp.query_required(__VA_ARGS__)
102#define pp_query_default(...) pp.query_default(__VA_ARGS__)
103#define pp_query_validate(...) pp.query_validate(__VA_ARGS__)
104#define pp_query_file(...) pp.query_file(__VA_ARGS__)
105#define pp_queryarr(...) pp.queryarr(__VA_ARGS__)
106#define pp_queryarr_required(...) pp.queryarr_required(__VA_ARGS__)
107#define pp_queryarr_default(...) pp.queryarr_default(__VA_ARGS__)
108#define pp_query(...) pp.query(__VA_ARGS__)
109#define pp_queryclass(...) pp.queryclass(__VA_ARGS__)
110#define pp_forbid(...) pp.forbid(__VA_ARGS__)
122 std::string inputfile =
"";
123 while (this->querykth(
"input",k,inputfile))
126 this->addfile(inputfile);
139 (void)amrex::ParmParse::contains(name.c_str());
144 if (m_prefix.length())
145 m_prefix = m_prefix +
"." +
prefix;
152 size_t pos = m_prefix.rfind(
'.');
153 if (pos == std::string::npos)
156 m_prefix = m_prefix.substr(0, pos);
160 void forbid(std::string name, std::string explanation)
162 if (amrex::ParmParse::contains(
full(name).c_str()))
166 std::set<std::string> subs = amrex::ParmParse::getEntries(
full(name));
175 if (amrex::ParmParse::contains(name.c_str()))
177 if (amrex::ParmParse::contains(
full(name).c_str()))
180 std::set<std::string> subs = amrex::ParmParse::getEntries(name.c_str());
185 std::set<std::string> subs = amrex::ParmParse::getEntries(
full(name).c_str());
196 std::string strvalue;
197 int retval = amrex::ParmParse::query(name.c_str(),strvalue);
202 catch (std::runtime_error & e)
241 catch (std::runtime_error &e)
257 return query(name.c_str(),value);
259 catch (std::runtime_error & e)
279 return queryunit(name.c_str(), value, type);
281 catch (std::runtime_error & e)
299 add(name.c_str(),defaultvalue);
301 return query(name.c_str(),value);
303 catch (std::runtime_error & e)
321 add(name.c_str(),defaultvalue);
323 return queryunit(name.c_str(),value,type);
325 catch (std::runtime_error & e)
336 int query_validate( std::string name,
int & value, std::vector<int> possibleintvals)
343 value = possibleintvals[0];
346 int retval = query(name.c_str(),value);
350 for (
unsigned int i = 0; i < possibleintvals.size(); i++)
352 if (value == possibleintvals[i]) ok =
true;
355 if (ok)
return retval;
357 std::stringstream ss;
358 ss << possibleintvals[0];
359 for (
unsigned int i = 1; i < possibleintvals.size(); i++)
360 ss <<
"," << possibleintvals[i];
364 catch (std::runtime_error & e)
376 int query_validate( std::string name, std::string & value, std::vector<const char *> possiblecharvals,
bool firstbydefault)
390 value = std::string(possiblecharvals[0]);
393 int retval = amrex::ParmParse::query(name.c_str(),value);
397 for (
unsigned int i = 0; i < possiblecharvals.size(); i++)
399 if (value == std::string(possiblecharvals[i])) ok =
true;
402 if (ok)
return retval;
404 std::stringstream ss;
405 ss << possiblecharvals[0];
406 for (
unsigned int i = 1; i < possiblecharvals.size(); i++)
407 ss <<
"," << possiblecharvals[i];
411 catch (std::runtime_error & e)
423 int query_validate( std::string name, std::string & value, std::vector<const char *> possiblecharvals)
429 catch (std::runtime_error & e)
442 int query_default( std::string name, std::string & value,
const char *defaultvalue)
446 return query_default(name, value, std::string(defaultvalue));
448 catch (std::runtime_error & e)
464 if (defaultvalue) defaultint = 1;
467 catch (std::runtime_error & e)
480 int query_file( std::string name, std::string & value,
bool copyfile,
bool checkfile)
489 int retval = query(name.c_str(),value);
491 if (amrex::ParallelDescriptor::IOProcessor())
493 if ( checkfile && ! std::filesystem::exists(value))
497 if ( checkfile && !std::filesystem::is_regular_file(value))
508 catch (std::runtime_error & e)
518 int query_file( std::string name, std::string & value,
bool copyfile)
529 int queryarr( std::string name, std::vector<T> & value)
533 return amrex::ParmParse::queryarr(name.c_str(),value);
547 return amrex::ParmParse::queryarr(name.c_str(),value);
552 std::vector<std::string> valstrings;
553 int retval = amrex::ParmParse::queryarr(name.c_str(), valstrings);
554 for (
unsigned int i = 0; i < valstrings.size(); i++)
568 catch (std::runtime_error &e)
582 std::vector<Set::Scalar> vals;
584 if (vals.size() < AMREX_SPACEDIM)
587 " requires at least ", AMREX_SPACEDIM,
588 " arguments, got ",vals.size());
590 for (
int i = 0; i < AMREX_SPACEDIM; i++) value(i) = vals[i];
601 std::vector<Set::Scalar> vals;
603 if (vals.size() == 9)
606 Util::Warning(
INFO,
"Reading a 3D matrix (",
full(name),
")into a 2D code - some values will be ignored.");
607 value(0,0) = vals[0]; value(0,1)= vals[1];
608 value(1,0) = vals[3]; value(1,1)= vals[4];
611 value(0,0) = vals[0]; value(0,1)= vals[1]; value(0,2)= vals[2];
612 value(1,0) = vals[3]; value(1,1)= vals[4]; value(1,2)= vals[5];
613 value(2,0) = vals[6]; value(2,1)= vals[7]; value(2,2)= vals[8];
616 else if (vals.size() == 4)
619 value(0,0) = vals[0]; value(0,1)= vals[1];
620 value(1,0) = vals[2]; value(1,1)= vals[3];
623 Util::Warning(
INFO,
"Reading a 2D matrix (",
full(name),
")into a 3D code - remaining values will be set to zero.");
624 value(0,0) = vals[0]; value(0,1)= vals[1]; value(0,2)= 0.0;
625 value(1,0) = vals[2]; value(1,1)= vals[3]; value(1,2)= 0.0;
626 value(2,0) = 0.0; value(2,1)= 0.0; value(2,2)= 0.0;
643 return queryarr<T>(name,value);
654 int queryarr_default( std::string name, std::vector<std::string> & value, std::vector<std::string> defaultvalue)
658 addarr(name.c_str(),defaultvalue);
660 return amrex::ParmParse::queryarr(name.c_str(),value);
670 value = defaultvalue;
673 return queryarr(name.c_str(),value);
689 value = defaultvalue;
692 return queryarr(name.c_str(),value);
701 int queryarr_default( std::string name, std::vector<double> & value, std::vector<double> defaultvalue)
707 addarr(name.c_str(),defaultvalue);
709 return queryarr(name.c_str(),value);
718 int queryarr_default( std::string name, std::vector<double> & value, std::vector<std::string> defaultvalue,
Unit unit)
724 addarr(name.c_str(),defaultvalue);
736 template <
typename T>
746 std::string name = a_name;
749 for (
int n = 0; n < number; n++)
752 this->queryclass<T>(name, tmp);
753 value.push_back(tmp);
766 std::string name0 = a_name + std::to_string(0);
767 std::string name1 = a_name + std::to_string(1);
773 else if (this->
contains(name1.c_str()))
787 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
792 this->queryclass<T>(name, tmp);
793 value.push_back(tmp);
795 name = a_name + std::to_string(cntr+1);
802 template <
typename T>
812 std::string name = a_name;
815 for (
int n = 0; n < number; n++)
819 value.push_back(tmp);
832 std::string name0 = a_name + std::to_string(0);
833 std::string name1 = a_name + std::to_string(1);
839 else if (this->
contains(name1.c_str()))
853 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
859 value.push_back(tmp);
861 name = a_name + std::to_string(cntr+1);
872 for (
auto li = m_table->begin(), End = m_table->end(); li != End; ++li)
874 if (!li->second.m_count)
878 if (li->first.rfind(
getPrefix()+
".",0) != std::string::npos)
896 std::vector<std::string> ret;
897 for (
auto li = m_table->begin(), End = m_table->end(); li != End; ++li)
899 if (!li->second.m_count && li->first.rfind(
getPrefix()+
".",0) != std::string::npos)
901 ret.push_back(li->first);
911 for (
auto li = pp.m_table->begin(), End = pp.m_table->end(); li != End; ++li)
913 if (!li->second.m_count)
925 std::string
full (std::string name)
936 auto old_prefix = m_prefix;
939 if (old_prefix.empty()) m_prefix = name;
940 else m_prefix.append(
".").append(name);
941 T::Parse(*value, *
this);
943 if (unused_inputs.size())
945 std::stringstream ss;
946 for (
unsigned int i=0; i < unused_inputs.size(); i++)
947 ss <<
"\n\t" << unused_inputs[i];
953 m_prefix = old_prefix;
956 m_prefix = old_prefix;
961 auto old_prefix = m_prefix;
964 if (old_prefix.empty()) m_prefix = name;
965 else m_prefix.append(
".").append(name);
966 T::Parse(value, *
this);
968 if (unused_inputs.size())
970 std::stringstream ss;
971 for (
unsigned int i=0; i < unused_inputs.size(); i++)
972 ss <<
"\n\t" << unused_inputs[i];
976 catch (std::runtime_error &e)
982 m_prefix = old_prefix;
985 m_prefix = old_prefix;
993 T::Parse(*value, *
this);
995 catch (std::runtime_error &e)
1009 T::Parse(value, *
this);
1011 catch (std::runtime_error &e)
1029 template<
typename...
IC,
typename... Args,
typename PTRTYPE>
1030 void select (std::string name, PTRTYPE *& ic_eta, Args&&... args)
1036 if constexpr (
sizeof...(IC) == 0)
1038 using first_IC = std::tuple_element_t<0, std::tuple<
IC...>>;
1039 ic_eta =
new first_IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(first_IC::name));
1044 std::string type =
"";
1046 bool matched = (( type == IC::name
1047 ? (ic_eta =
new IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(IC::name))),
1054 catch (std::runtime_error &e)
1068 template<
typename FirstIC,
typename...
IC,
typename... Args,
typename PTRTYPE>
1071 std::string type =
"";
1076 (( type == FirstIC::name
1077 ? (ic_eta =
new FirstIC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(FirstIC::name))),
1081 ? (ic_eta =
new IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(IC::name))),
1082 true :
false) || ...);
1092 template<
typename...
IC,
typename... Args,
typename PTRTYPE>
1102 std::string name = a_name;
1106 this->
select<
IC...>(a_name, tmp, args...);
1107 value.push_back(tmp);
1119 std::string name0 = a_name + std::to_string(0);
1120 std::string name1 = a_name + std::to_string(1);
1126 else if (this->
contains(name1.c_str()))
1140 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
1145 this->
select<
IC...>(name, tmp, args...);
1146 value.push_back(tmp);
1148 name = a_name + std::to_string(cntr+1);
1157 template<
typename... INTEGRATOR,
typename... Args,
typename PTRTYPE>
1160 std::string type =
"";
1164 bool matched = ((type == INTEGRATOR::name
1165 ? (ic_eta =
new INTEGRATOR(std::forward<Args>(args)..., (*
this))),
1178 template<
typename INTEGRATOR,
typename Args,
typename PTRTYPE>
1181 ic_eta =
new INTEGRATOR(std::forward<Args>(args), (*
this));
1184 template<
typename INTEGRATOR,
typename PTRTYPE>
1187 ic_eta =
new INTEGRATOR((*
this));
1196 template <
typename... OBJ,
typename CLASS>
1215 template <
typename CLASS,
int N,
typename... OBJ>
1218 if constexpr (N == 0)
1223 for (
unsigned int i = 0; i <
sizeof...(OBJ); i++)
1224 if (type == value.names[i])
1227 if (value.selected < 0)
1230 ", invalid type " + type);
1236 if constexpr (N <
sizeof...(OBJ))
1238 if (value.selected == N)
1240 std::get<N>(value.obj).Parse(std::get<N>(value.obj), *
this);
1253 void query_exactly( std::vector<std::string> names, std::pair<std::string, Set::Scalar> values[N],
1254 std::vector<Unit> units = std::vector<Unit>())
1259 "# of units must be 0, 1, or ", names.size(),
" but got ", units.size());
1262 std::vector<std::string> read;
1263 for (
unsigned int n = 0; n < names.size(); n++)
1265 if (amrex::ParmParse::contains(names[n].c_str()))
1267 read.push_back(names[n]);
1272 " Incorrect number of values specified: only ", N,
1273 " values are allowed, but received ",
1278 for (
unsigned int n = 0; n < names.size(); n++)
1280 if (amrex::ParmParse::contains(names[n].c_str()))
1282 values[cnt].first = names[n];
1284 if (units.size() == 0)
1286 else if (units.size() == 1)
1296 std::string names_str =
"[";
1297 for (
unsigned int i = 0; i < names.size(); i++)
1299 names_str +=
full(names[i]);
1300 if (i < names.size()-1) names_str +=
", ";
int queryarr_default(std::string name, std::vector< double > &value, std::vector< std::string > defaultvalue, Unit unit)
bool contains(std::string name)
int queryunit(std::string name, Unit &value)
int queryarr_default(std::string name, std::vector< std::string > &value, std::vector< std::string > defaultvalue)
int queryarr_required(std::string name, std::vector< Set::Scalar > &value, Unit unit=Unit::Less())
int queryarr(std::string name, std::vector< T > &value)
void forbid(std::string name, std::string explanation)
void select(std::string name, CLASS &value)
int query_enumerate(std::string a_name, std::vector< T > &value, int number=1)
int queryarr(std::string name, std::vector< Set::Scalar > &value, Unit unit=Unit::Less())
void pushPrefix(const std::string prefix)
int query_validate(std::string name, std::string &value, std::vector< const char * > possiblecharvals, bool firstbydefault)
int query_file(std::string name, std::string &value)
int queryarr(std::string name, Set::Vector &value, Unit unit=Unit::Less())
int query_file(std::string name, std::string &value, bool copyfile, bool checkfile)
int AnyUnusedInputs(bool inscopeonly=true, bool verbose=false)
int queryarr(std::string name, Set::Matrix &value, Unit unit=Unit::Less())
std::vector< std::string > GetUnusedInputs()
void queryclass(std::string name, T &value)
std::string getPrefix() const
static bool checked_for_input_files
void select(std::string name, PTRTYPE *&ic_eta, Args &&... args)
void queryclass(std::string name, T *value)
int queryclass_enumerate(std::string a_name, std::vector< T > &value, int number=1)
int query_required(std::string name, T &value)
int queryarr_default(std::string name, Set::Matrix &value, Set::Matrix defaultvalue)
int query_default(std::string name, T &value, std::string defaultvalue, const Unit type)
void select_default(std::string name, PTRTYPE *&ic_eta, Args &&... args)
int queryarr_default(std::string name, Set::Vector &value, Set::Vector defaultvalue)
int queryunit(std::string name, Unit &value, const Unit type)
int query_default(std::string name, int &value, bool defaultvalue)
int query_file(std::string name, std::string &value, bool copyfile)
void select_enumerate(std::string a_name, std::vector< PTRTYPE * > &value, Args &&... args)
void queryclass(T &value)
static int AllUnusedInputs()
int query_validate(std::string name, std::string &value, std::vector< const char * > possiblecharvals)
void queryclass(T *value)
int queryarr_required(std::string name, std::vector< T > &value)
int query_required(std::string name, T &value, const Unit type)
void static_polymorphism_parser(CLASS &value)
void select_only(PTRTYPE *&ic_eta, Args &&args)
void select_main(PTRTYPE *&ic_eta, Args &&... args)
int queryunit(std::string name, Set::Scalar &value, const Unit type)
int query_default(std::string name, T &value, T defaultvalue)
void select_only(PTRTYPE *&ic_eta)
void ignore(std::string name)
std::string full(std::string name)
int query_validate(std::string name, int &value, std::vector< int > possibleintvals)
int queryarr_default(std::string name, std::vector< double > &value, std::vector< double > defaultvalue)
void query_exactly(std::vector< std::string > names, std::pair< std::string, Set::Scalar > values[N], std::vector< Unit > units=std::vector< Unit >())
int query_default(std::string name, std::string &value, const char *defaultvalue)
ParmParse(std::string arg)
Initialize a spherical inclusion.
Eigen::Matrix< amrex::Real, AMREX_SPACEDIM, 1 > Vector
Eigen::Matrix< amrex::Real, AMREX_SPACEDIM, AMREX_SPACEDIM > Matrix
AMREX_FORCE_INLINE std::string Join(const std::vector< std::string > &vec, std::string separator="_")
void DebugMessage(std::string, std::string, int, Args const &...)
AMREX_FORCE_INLINE void AssertException(std::string file, std::string func, int line, std::string smt, bool pass, Args const &... args)
void Abort(const char *msg)
void CopyFileToOutputDir(std::string a_path, bool fullpath, std::string prefix)
void Warning(std::string file, std::string func, int line, Args const &... args)
void Message(std::string file, std::string func, int line, Args const &... args)
void ParmParseException(std::string file, std::string func, int line, std::string fullname, Args const &... args)
void Exception(std::string file, std::string func, int line, Args const &... args)
bool isType(const Unit &test) const
std::string normalized_unitstring() const
double normalized_value() const
static Unit Parse(double val, std::string unitstring)