00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00027 #ifndef SH_METAIMPL_HPP
00028 #define SH_METAIMPL_HPP
00029
00030 #include "ShMeta.hpp"
00031
00032 namespace SH {
00033
00034 inline ShMeta::~ShMeta()
00035 {
00036 }
00037
00038 inline std::string ShMeta::name() const
00039 {
00040 return meta("n");
00041 }
00042
00043 inline void ShMeta::name(const std::string& n)
00044 {
00045 meta("n", n);
00046 }
00047
00048 inline bool ShMeta::has_name() const
00049 {
00050 return !meta("n").empty();
00051 }
00052
00053 inline bool ShMeta::internal() const
00054 {
00055 return !meta("i").empty();
00056 }
00057
00058 inline void ShMeta::internal(bool i)
00059 {
00060 meta("i", i ? "1" : "");
00061 }
00062
00063 inline std::string ShMeta::title() const
00064 {
00065 return meta("t");
00066 }
00067
00068 inline void ShMeta::title(const std::string& t)
00069 {
00070 meta("t", t);
00071 }
00072
00073 inline std::string ShMeta::description() const
00074 {
00075 return meta("d");
00076 }
00077
00078 inline void ShMeta::description(const std::string& d)
00079 {
00080 meta("d", d);
00081 }
00082
00083 inline std::string ShMeta::meta(const std::string& key) const
00084 {
00085 if(!m_meta) return std::string();
00086
00087 MetaMap::const_iterator I = m_meta->find(key);
00088 if (I == m_meta->end()) return std::string();
00089 return I->second;
00090 }
00091
00092 inline void ShMeta::meta(const std::string& key, const std::string& value)
00093 {
00094 if(!m_meta) m_meta = new MetaMap();
00095 (*m_meta)[key] = value;
00096 }
00097
00098 }
00099
00100 #endif
00101