0.6.0
C++ to UML diagram generator based on Clang
Loading...
Searching...
No Matches
Public Member Functions | Public Attributes | List of all members
clanguml::config::option< T > Struct Template Reference

Generic configuration option type. More...

Detailed Description

template<typename T>
struct clanguml::config::option< T >

Generic configuration option type.

This class template represents a single configuration option, which can be either a simple type such as bool or std::string or can be a list or dictionary.

If the option is constructed only from default value, it's is_declared member is false, so we can deduce whether user provided the option or not.

For each option type, there has to be defined a YAML decoder and emitter.

Template Parameters
TThe type of the configuration option

Definition at line 70 of file option.h.

#include <option.h>

Public Member Functions

 option (std::string name_, option_inherit_mode im=option_inherit_mode::kOverride)
 
 option (std::string name_, T initial_value, option_inherit_mode im=option_inherit_mode::kOverride)
 
 option (option_with_alt_names_tag, std::string name_, std::vector< std::string > alternate_names_, option_inherit_mode im=option_inherit_mode::kOverride)
 
void set (const T &v)
 Set the option value.
 
void override (const option< T > &o)
 Override option value.
 
void operator() (const T &v)
 
T & operator() ()
 
const T & operator() () const
 
 operator bool () const
 

Public Attributes

std::string name
 
std::vector< std::string > alternate_names
 
value
 
bool is_declared {false}
 
bool has_value {false}
 
option_inherit_mode inheritance_mode
 

Constructor & Destructor Documentation

◆ option() [1/3]

template<typename T >
clanguml::config::option< T >::option ( std::string  name_,
option_inherit_mode  im = option_inherit_mode::kOverride 
)
inline

Definition at line 71 of file option.h.

73 : name{std::move(name_)}
74 , value{}
76 {
77 }

◆ option() [2/3]

template<typename T >
clanguml::config::option< T >::option ( std::string  name_,
initial_value,
option_inherit_mode  im = option_inherit_mode::kOverride 
)
inline

Definition at line 78 of file option.h.

80 : name{std::move(name_)}
81 , value{std::move(initial_value)}
82 , has_value{true}
84 {
85 }

◆ option() [3/3]

template<typename T >
clanguml::config::option< T >::option ( option_with_alt_names_tag  ,
std::string  name_,
std::vector< std::string >  alternate_names_,
option_inherit_mode  im = option_inherit_mode::kOverride 
)
inline

Definition at line 86 of file option.h.

89 : name{std::move(name_)}
90 , alternate_names{std::move(alternate_names_)}
91 , value{}
93 {
94 }

Member Function Documentation

◆ operator bool()

template<typename T >
clanguml::config::option< T >::operator bool ( ) const
inline

Definition at line 133 of file option.h.

133{ return has_value; }

◆ operator()() [1/3]

template<typename T >
T & clanguml::config::option< T >::operator() ( )
inline

Definition at line 129 of file option.h.

129{ return value; }

◆ operator()() [2/3]

template<typename T >
const T & clanguml::config::option< T >::operator() ( ) const
inline

Definition at line 131 of file option.h.

131{ return value; }

◆ operator()() [3/3]

template<typename T >
void clanguml::config::option< T >::operator() ( const T &  v)
inline

Definition at line 127 of file option.h.

127{ set(v); }

◆ override()

template<typename T >
void clanguml::config::option< T >::override ( const option< T > &  o)
inline

Override option value.

This method overrides the option depending on it's inheritance type.

Parameters
oNew option value

Definition at line 115 of file option.h.

116 {
117 if (o.is_declared && inheritance_mode == option_inherit_mode::kAppend) {
118 append_value(value, o.value);
119 is_declared = true;
120 has_value = true;
121 }
122 else if (!is_declared && o.is_declared) {
123 set(o.value);
124 }
125 }

◆ set()

template<typename T >
void clanguml::config::option< T >::set ( const T &  v)
inline

Set the option value.

Parameters
vOption value

Definition at line 101 of file option.h.

102 {
103 value = v;
104 is_declared = true;
105 has_value = true;
106 }

Member Data Documentation

◆ alternate_names

template<typename T >
std::vector<std::string> clanguml::config::option< T >::alternate_names

Alternate option names

Definition at line 139 of file option.h.

◆ has_value

template<typename T >
bool clanguml::config::option< T >::has_value {false}

Whether the option has value, if the option has no default value and wasn't provided in the config this is set to false.

Definition at line 151 of file option.h.

◆ inheritance_mode

template<typename T >
option_inherit_mode clanguml::config::option< T >::inheritance_mode

The inheritance mode for this option

Definition at line 154 of file option.h.

◆ is_declared

template<typename T >
bool clanguml::config::option< T >::is_declared {false}

Whether or not the value was provided by the user or default

Definition at line 145 of file option.h.

◆ name

template<typename T >
std::string clanguml::config::option< T >::name

Option name, it is also the YAML key in the configuration file

Definition at line 136 of file option.h.

◆ value

template<typename T >
T clanguml::config::option< T >::value

Option value

Definition at line 142 of file option.h.


The documentation for this struct was generated from the following file: