X-Git-Url: https://git.teslayout.com/public/public/public/?p=anna.git;a=blobdiff_plain;f=include%2Fanna%2Fcore%2Futil%2FMultiMap.hpp;fp=include%2Fanna%2Fcore%2Futil%2FMultiMap.hpp;h=5fbd80e102d5b2244a9d4427191e2e087758920b;hp=a480ee277f421e2b76558435078bc40567615b30;hb=5a6cba5fde2b2f538a7515f8293cc0a8d9589dfa;hpb=af9c86ffb0e28d35ad94d99c5f77e41578c972b4 diff --git a/include/anna/core/util/MultiMap.hpp b/include/anna/core/util/MultiMap.hpp index a480ee2..5fbd80e 100644 --- a/include/anna/core/util/MultiMap.hpp +++ b/include/anna/core/util/MultiMap.hpp @@ -32,14 +32,14 @@ namespace anna { */ template < typename T, typename SortBy, typename TKey = int > class MultiMap : public std::vector { struct LessT : public std::binary_function { - bool operator()(const T* first, const T* second) const throw() { + bool operator()(const T* first, const T* second) const { return SortBy::value(first) < SortBy::value(second); } }; // El orden de los operandos está impuesto por cómo se invoca al operator() desde stl_algo.h (2685). struct LessKey : public std::binary_function { - bool operator()(const T* _vv, const TKey& searched) const throw() { + bool operator()(const T* _vv, const TKey& searched) const { return SortBy::value(_vv) < searched; } }; @@ -72,7 +72,7 @@ public: \return \em true si ha registrado la nueva instancia o \em false en otro caso. */ bool add(T* _vv) - throw(RuntimeException) { + noexcept(false) { if(_vv == NULL) return false; @@ -94,12 +94,12 @@ public: \return \em true si la instancia recibida como parametro esta contenido en el map o \em en otro caso. */ - bool contains(const T* _vv) const throw() { return (_vv == NULL) ? false : (find(SortBy::value(_vv)) != NULL); } + bool contains(const T* _vv) const { return (_vv == NULL) ? false : (find(SortBy::value(_vv)) != NULL); } /** * Borra las entradas contenidas en el vector ordenado y libera la memoria asociada a las mismas. */ - void clearAndDestroy() throw() { + void clearAndDestroy() { for(iterator ii = this->begin(), maxii = this->end(); ii != maxii; ii ++) delete data(ii); @@ -112,7 +112,7 @@ public: \return La instancia correspondiente a la entrada borrada o NULL si no se encontró ninguna entrada válida. */ T* erase(const T* _vv) - throw(RuntimeException) { + noexcept(false) { if(_vv == NULL) return NULL; @@ -137,7 +137,7 @@ public: * \return La nueva posición a la que debería pasar el iterador una vez borrada la entrada. * */ - iterator erase_iterator(iterator ii) throw() { return container::erase(ii); } + iterator erase_iterator(iterator ii) { return container::erase(ii); } /** Devuelve la instancia asociada a la clave recibida como parametro o NULL si no existe. @@ -145,7 +145,7 @@ public: \return la instancia asociada a la clave recibida como parametro o NULL si no existe. */ T* find(const TKey& key) - throw() { + { iterator maxii = this->end(); iterator ii = lower_bound(this->begin(), maxii, key, a_lessKey); @@ -161,7 +161,7 @@ public: * \return el iterador a la instancia asociada a la clave recibida. */ iterator find_iterator(const TKey& key) - throw() { + { return lower_bound(this->begin(), this->end(), key, a_lessKey); } @@ -170,7 +170,7 @@ public: \param key Clave a buscar en el map. \return la instancia asociada a la clave recibida como parametro o NULL si no existe. */ - const T* find(const TKey& key) const throw() { + const T* find(const TKey& key) const { return const_cast *>(this)->find(key); } @@ -178,13 +178,13 @@ public: Devuelve el objeto referenciado por el iterador. \return El objeto referenciado por el iterador. */ - static T* data(iterator ii) throw() { return *ii; } + static T* data(iterator ii) { return *ii; } /** Devuelve el objeto referenciado por el iterador. \return El objeto referenciado por el iterador. */ - static const T* data(const_iterator ii) throw() { return *ii; } + static const T* data(const_iterator ii) { return *ii; } private: LessT a_lessT;