Gromacs  2022.2
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
List of all members | Public Types | Public Member Functions | Friends
gmx::StringOption Class Reference

#include <gromacs/options/basicoptions.h>

+ Inheritance diagram for gmx::StringOption:
+ Collaboration diagram for gmx::StringOption:

Description

Specifies an option that provides string values.

Examples:

// Simple option
std::string str;
options.addOption(StringOption("str").store(&str));
// Option that only accepts predefined values
const char * const allowed[] = { "atom", "residue", "molecule" };
std::string str;
options.addOption(StringOption("type").enumValue(allowed).store(&str));
*

Public methods in this class do not throw.

Public Types

typedef StringOptionInfo InfoType
 OptionInfo subclass corresponding to this option type.
 
- Public Types inherited from gmx::OptionTemplate< std::string, StringOption >
typedef std::string ValueType
 Type that stores a single option value.
 
typedef StringOption MyClass
 Alias for the derived class type.
 

Public Member Functions

 StringOption (const char *name)
 Initializes an option with the given name.
 
template<size_t count>
MyClassenumValue (const char *const (&values)[count])
 Sets the option to only accept one of a fixed set of strings. More...
 
MyClassenumValueFromNullTerminatedArray (const char *const *values)
 Sets the option to only accept one of a fixed set of strings. More...
 
MyClassdefaultEnumIndex (int index)
 Sets the default value using an index into the enumeration table. More...
 
- Public Member Functions inherited from gmx::OptionTemplate< std::string, StringOption >
MyClassdescription (const char *descr)
 Sets a description for the option. More...
 
MyClasshidden (bool bHidden=true)
 Hides the option from normal help output.
 
MyClassrequired (bool bRequired=true)
 Requires the option to be specified explicitly. More...
 
MyClassallowMultiple (bool bMulti=true)
 Allows the option to be specified multiple times.
 
MyClassvalueCount (int count)
 Requires exactly count values for the option.
 
MyClassmultiValue (bool bMulti=true)
 Allows any number of values for the option.
 
MyClassdefaultValue (const std::string &defaultValue)
 Sets a default value for the option. More...
 
MyClassdefaultValueIfSet (const std::string &defaultValue)
 Sets a default value for the option when it is set. More...
 
MyClassstore (std::string *store)
 Stores value(s) in memory pointed by store. More...
 
MyClassstoreCount (int *countptr)
 Stores number of values in the value pointed by countptr. More...
 
MyClassstoreVector (std::vector< std::string > *store)
 Stores option values in the provided vector. More...
 
MyClassstoreIsSet (bool *store)
 Stores whether the option was explicitly set. More...
 

Friends

class StringOptionStorage
 Needed to initialize StringOptionStorage from this class without otherwise unnecessary accessors.
 

Additional Inherited Members

- Protected Types inherited from gmx::OptionTemplate< std::string, StringOption >
typedef OptionTemplate
< std::string, StringOption
MyBase
 Alias for the template class for use in base classes.
 
- Protected Member Functions inherited from gmx::OptionTemplate< std::string, StringOption >
const std::string * defaultValue () const
 Returns a pointer to user-specified default value, or NULL if there is none.
 
const std::string * defaultValueIfSet () const
 Returns a pointer to user-specified default value, or NULL if there is none.
 
std::string * store () const
 Returns a pointer to the storage location, or NULL if none specified.
 
std::vector< std::string > * storeVector () const
 Returns a pointer to the storage vector, or NULL if none specified.
 
 OptionTemplate (const char *name)
 Initializes the name and default values for an option.
 
MyClassme ()
 Returns *this casted into MyClass to reduce typing.
 
- Protected Member Functions inherited from gmx::AbstractOption
 AbstractOption (const char *name)
 Initializes the name and default values for an option.
 
void setDescription (const char *descr)
 Sets the description for the option.
 
void setStoreIsSet (bool *store)
 Sets the storage location for whether the option is set.
 
void setFlag (OptionFlag flag)
 Sets a flag for the option.
 
void clearFlag (OptionFlag flag)
 Clears a flag for the option.
 
void setFlag (OptionFlag flag, bool bSet)
 Sets or clears a flag for the option.
 
bool isVector () const
 Returns true if the option is vector-valued.
 
void setVector ()
 Sets the option to be vector-valued. More...
 
void setValueCount (int count)
 Sets the required number of values for the option.
 
- Protected Attributes inherited from gmx::AbstractOption
int minValueCount_
 Minimum number of values required for the option.
 
int maxValueCount_
 Maximum number of values allowed for the option.
 

Member Function Documentation

MyClass& gmx::StringOption::defaultEnumIndex ( int  index)
inline

Sets the default value using an index into the enumeration table.

Cannot be specified without enumValue().

template<size_t count>
MyClass& gmx::StringOption::enumValue ( const char *const (&)  values[count])
inline

Sets the option to only accept one of a fixed set of strings.

Parameters
[in]valuesArray of strings to accept.

Also accepts prefixes of the strings; if a prefix matches more than one of the possible strings, the shortest one is used (in a tie, the first one is).

The strings are copied once the option is created.

MyClass& gmx::StringOption::enumValueFromNullTerminatedArray ( const char *const *  values)
inline

Sets the option to only accept one of a fixed set of strings.

Parameters
[in]valuesArray of strings to accept, with a NULL pointer following the last string.

Works otherwise as the array version, but accepts a pointer to an array of undetermined length. The end of the array is indicated by a NULL pointer in the array.

See Also
enumValue()

The documentation for this class was generated from the following files: