AXOM
Axom provides a robust, flexible software infrastructure for the development of multi-physics applications and computational tools.
|
Provides functions to help define how individual field variables in an input file are expected to behave. It also holds the Sidre Group to the individual field. More...
#include </home/docs/checkouts/readthedocs.org/user_builds/axom/checkouts/v0.5.0/src/axom/inlet/Field.hpp>
Public Member Functions | |
Field (axom::sidre::Group *sidreGroup, axom::sidre::Group *root, axom::sidre::DataTypeId type=axom::sidre::DataTypeId::NO_TYPE_ID, bool docEnabled=true) | |
Constructor for the Field class. More... | |
virtual | ~Field ()=default |
const axom::sidre::Group * | sidreGroup () const |
Returns pointer to the Sidre Group class for this Field. More... | |
Field & | required (bool isRequired=true) |
Set the required status of this Field. More... | |
bool | isRequired () const |
Return the required status of this Field. More... | |
Field & | defaultValue (const std::string &value) |
Set the default value of this Field. More... | |
Field & | defaultValue (const char *value) |
Set the default value of this Field. More... | |
Field & | defaultValue (bool value) |
Set the default value of this Field. More... | |
Field & | defaultValue (int value) |
Set the default value of this Field. More... | |
Field & | defaultValue (double value) |
Set the default value of this Field. More... | |
Field & | range (double startVal, double endVal) |
Set the range of this Field. More... | |
Field & | range (int startVal, int endVal) |
Set the range of this Field. More... | |
Field & | validValues (const std::vector< int > &set) |
Set the valid values for this Field. More... | |
Field & | validValues (const std::vector< double > &set) |
Set the valid values for this Field. More... | |
Field & | validValues (const std::vector< std::string > &set) |
Set the valid values for this Field. More... | |
Field & | validValues (const std::initializer_list< const char *> &set) |
Set the valid values for this Field. More... | |
Field & | validValues (const std::initializer_list< int > &set) |
Set the valid values for this Field. More... | |
Field & | validValues (const std::initializer_list< double > &set) |
Set the valid values for this Field. More... | |
Field & | registerVerifier (std::function< bool(const Field &)> lambda) |
Registers the function object that will verify this Field's contents during the verification stage. More... | |
bool | verify () const |
Called by Inlet::verify to verify the contents of this Field. More... | |
std::string | name () const |
template<typename T > | |
T | get () const |
Returns a value of primitive type. More... | |
InletType | type () const |
Returns the type of the stored value. More... | |
bool | exists () const |
Returns whether a value for the Field exists, i.e., if a value was provided in the input file or if a default was provided. More... | |
bool | isUserProvided () const |
Returns whether a value was provided in the input file. More... | |
template<> | |
bool | get () const |
template<> | |
int | get () const |
template<> | |
double | get () const |
virtual VerifiableScalar & | registerVerifier (std::function< bool(const axom::inlet::Field &)> lambda)=0 |
Registers the function object that will verify this object's contents during the verification stage. More... | |
Provides functions to help define how individual field variables in an input file are expected to behave. It also holds the Sidre Group to the individual field.
|
inline |
Constructor for the Field class.
This class provides functions to define the behavior of the Field data already read and stored in the given Sidre Group.
[in] | sidreGroup | Pointer to the already created Sidre Group. |
[in] | root | Pointer to the sidreRootGroup containing this Field |
[in] | type | FieldType specifying the data type of this Field instance. Default is FieldType::UNSPECIFIED. |
[in] | docEnabled | Boolean indicating whether or not documentation generation is enabled for Input file this Field instance belongs to. |
References ~Field().
|
virtualdefault |
Referenced by Field().
|
inline |
Returns pointer to the Sidre Group class for this Field.
Provides access to the Sidre Group class that holds all the stored information for this Field class.
References defaultValue(), exists(), isRequired(), isUserProvided(), name(), axom::sidre::NO_TYPE_ID, range(), registerVerifier(), required(), type(), validValues(), and verify().
|
virtual |
Set the required status of this Field.
Set whether this Field is required, or not, to be in the input file. The default behavior is to not be required.
[in] | isRequired | Boolean value of whether Field is required |
Implements axom::inlet::VerifiableScalar.
Referenced by axom::inlet::AggregateField::AggregateField(), and sidreGroup().
|
virtual |
Return the required status of this Field.
Return that this Field is required, or not, to be in the input file. The default behavior is to not be required.
Implements axom::inlet::VerifiableScalar.
Referenced by axom::inlet::AggregateField::AggregateField(), and sidreGroup().
|
virtual |
Set the default value of this Field.
Set the default value for the Field in the input file.
[in] | value | The default string value |
Implements axom::inlet::VerifiableScalar.
Referenced by axom::inlet::AggregateField::AggregateField(), and sidreGroup().
|
virtual |
Set the default value of this Field.
Set the default value for the Field in the input file.
[in] | value | The default string value |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the default value of this Field.
Set the default value for the Field in the input file.
[in] | value | The default boolean value |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the default value of this Field.
Set the default value for the Field in the input file.
[in] | value | The default integer value |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the default value of this Field.
Set the default value for the Field in the input file.
[in] | value | The default double value |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the range of this Field.
Set the continuous range for the Field in the input file.
[in] | startVal | The start of the range |
[in] | endVal | The end of the range |
Implements axom::inlet::VerifiableScalar.
Referenced by axom::inlet::AggregateField::AggregateField(), and sidreGroup().
|
virtual |
Set the range of this Field.
Set the continuous range for the Field in the input file.
[in] | startVal | The start of the range |
[in] | endVal | The end of the range |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the valid values for this Field.
[in] | set | An vector containing the set of allowed integer values |
Implements axom::inlet::VerifiableScalar.
Referenced by axom::inlet::AggregateField::AggregateField(), and sidreGroup().
|
virtual |
Set the valid values for this Field.
[in] | set | An vector containing the set of allowed double values |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the valid values for this Field.
[in] | set | A vector containing the set of allowed string values |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the valid values for this Field.
[in] | set | An initializer list containing the set of allowed C-string values |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the valid values for this Field.
[in] | set | An initializer list containing the valid integer values |
Implements axom::inlet::VerifiableScalar.
|
virtual |
Set the valid values for this Field.
[in] | set | An initializer list containing the valid double values |
Implements axom::inlet::VerifiableScalar.
Registers the function object that will verify this Field's contents during the verification stage.
[in] | The | function object that will be called by Field::verify(). |
Referenced by axom::inlet::AggregateField::AggregateField(), and sidreGroup().
|
virtual |
Called by Inlet::verify to verify the contents of this Field.
Implements axom::inlet::VerifiableScalar.
Referenced by axom::inlet::AggregateField::AggregateField(), and sidreGroup().
std::string axom::inlet::Field::name | ( | ) | const |
Referenced by sidreGroup().
T axom::inlet::Field::get | ( | ) | const |
Returns a value of primitive type.
T | The type to retrieve |
Referenced by axom::inlet::Proxy::get().
InletType axom::inlet::Field::type | ( | ) | const |
bool axom::inlet::Field::exists | ( | ) | const |
Returns whether a value for the Field exists, i.e., if a value was provided in the input file or if a default was provided.
Referenced by sidreGroup().
bool axom::inlet::Field::isUserProvided | ( | ) | const |
Returns whether a value was provided in the input file.
Referenced by sidreGroup().
bool axom::inlet::Field::get | ( | ) | const |
int axom::inlet::Field::get | ( | ) | const |
double axom::inlet::Field::get | ( | ) | const |
|
pure virtualinherited |
Registers the function object that will verify this object's contents during the verification stage.
[in] | The | function object. |