Partially maps names to constants. More...
#include <keyvalue/key/map/PartialMap.h>
| Public Types | |
| typedef OutputType | OutputType_ | 
| Public Member Functions | |
| OutputType | map (const value::Variant &variant) const | 
| Performs the mapping. | |
| virtual OutputType | get (const string &name) const =0 | 
| Performs the mapping from stringto OutputType. | |
| Private Types | |
| typedef ::boost::is_same < OutputType, double >::type | IsDouble_ | 
| typedef ::boost::is_same < OutputType, ptime >::type | IsPtime_ | 
| typedef ::boost::is_same < OutputType, unsigned int > ::type | IsUInt_ | 
| Private Member Functions | |
| virtual string | getName () const =0 | 
| Gets Key's name. | |
| BOOST_STATIC_ASSERT (IsDouble_::value||IsPtime_::value||IsUInt_::value) | |
Partially maps names to constants.
Use this map, when a special double, ptime or unsigned int value has a name.
For instance, when asked for the number of edges of a regular polygon, the answer must be an unsigned int greater than 2. For some special values (not all) there correspond a polygon name (e.g 'Triangle' for 3 or 'Square' for 4). There is no special name for a regular polygon with 1111 edges.
Traits derived classes which uses this map must implement a method to perform the mapping. This method has the following signature
 Output get(const string& name) const; 
| OutputType | : ( templateparameter) Output type. | 
| OutputType_ | : Same as OutputType. | 
| OutputType map | ( | const value::Variant & | variant | ) | const | 
Performs the mapping.
This method converts the input from value::Variant to string and calls get().
| variant | : A value::Variant containing the input stringto be mapped. | 
| virtual OutputType get | ( | const string & | name | ) | const  [pure virtual] | 
Performs the mapping from string to OutputType. 
Must be implemented by real keys which use this map.
| name | : The stringto be mapped. | 
 1.7.1
 1.7.1