X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fcore%2Fmaputils.h;h=26b72cc29e7b1891e96e06552ebb67645f679ebb;hp=ecee0fbea45955dbf9bef8f8bf296bb387b3e414;hb=991fabc1956b73a4007859058fb44171000b452e;hpb=85c6b143c9b85ce09ee4f3cb842d3ae006b7a6fe diff --git a/source/core/maputils.h b/source/core/maputils.h index ecee0fb..26b72cc 100644 --- a/source/core/maputils.h +++ b/source/core/maputils.h @@ -28,7 +28,7 @@ static std::string stringify_key(const T &k) try { LexicalConverter conv((Fmt())); - conv< typename T::mapped_type &get_item(T &map, const typename T::key_type &key) { - typename T::iterator i = map.find(key); + auto i = map.find(key); if(i==map.end()) throw key_error(key); @@ -67,20 +67,26 @@ typename T::mapped_type &get_item(T &map, const typename T::key_type &key) template const typename T::mapped_type &get_item(const T &map, const typename T::key_type &key) { - typename T::const_iterator i = map.find(key); + auto i = map.find(key); if(i==map.end()) throw key_error(key); return i->second; } +template +D *get_item(const T &map, const typename T::key_type &key) +{ + return dynamic_cast(get_item(map, key)); +} + template -const typename T::iterator insert_unique(T &map, const typename T::key_type &key, const typename T::mapped_type &item) +typename T::iterator insert_unique(T &map, const typename T::key_type &key, const typename T::mapped_type &item) { if(map.count(key)) throw key_error(key); - return map.insert(typename T::value_type(key, item)).first; + return map.insert(std::make_pair(key, item)).first; } template