00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef PALUDIS_GUARD_PALUDIS_UTIL_NAMED_VALUE_HH
00021 #define PALUDIS_GUARD_PALUDIS_UTIL_NAMED_VALUE_HH 1
00022
00023 #include <paludis/util/named_value-fwd.hh>
00024 #include <paludis/util/tribool.hh>
00025
00026 namespace paludis
00027 {
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046 template <typename K_, typename V_>
00047 class NamedValue
00048 {
00049 private:
00050 V_ _value;
00051
00052 public:
00053 typedef K_ KeyType;
00054 typedef V_ ValueType;
00055
00056 template <typename T_>
00057 NamedValue(const NamedValue<K_, T_> & v) :
00058 _value(v())
00059 {
00060 }
00061
00062 explicit NamedValue(const V_ & v) :
00063 _value(v)
00064 {
00065 }
00066
00067 NamedValue(const NamedValue & v) :
00068 _value(v._value)
00069 {
00070 }
00071
00072 V_ & operator() ()
00073 {
00074 return _value;
00075 }
00076
00077 const V_ & operator() () const
00078 {
00079 return _value;
00080 }
00081 };
00082
00083 template <typename K_, typename V_>
00084 NamedValue<K_, V_>
00085 value_for(const V_ & v)
00086 {
00087 return NamedValue<K_, V_>(v);
00088 }
00089
00090 template <typename K_>
00091 NamedValue<K_, std::string>
00092 value_for(const char * const v)
00093 {
00094 return NamedValue<K_, std::string>(v);
00095 }
00096
00097 template <typename K_>
00098 NamedValue<K_, Tribool>
00099 value_for(TriboolIndeterminateValueType v)
00100 {
00101 return NamedValue<K_, Tribool>(v);
00102 }
00103 }
00104
00105 #endif