diff options
author | Josh Stone <jistone@redhat.com> | 2009-09-09 16:13:16 -0700 |
---|---|---|
committer | Josh Stone <jistone@redhat.com> | 2009-09-10 13:20:36 -0700 |
commit | c9efa5c99498ccb3d2f0f87bc373da7dfd1cc067 (patch) | |
tree | 2d8cf0995d76421ac3fbc08f4ee2c43e0fae639f | |
parent | 9aa8ffcea9980d24cc9c9f13d9dd51e46e6283bf (diff) | |
download | systemtap-steved-c9efa5c99498ccb3d2f0f87bc373da7dfd1cc067.tar.gz systemtap-steved-c9efa5c99498ccb3d2f0f87bc373da7dfd1cc067.tar.xz systemtap-steved-c9efa5c99498ccb3d2f0f87bc373da7dfd1cc067.zip |
Simplify deleting all map values
* util.h (delete_map): New templated map deleter.
* dwflpp.cxx (dwflpp::~dwflpp): Use it.
* tapsets.cxx (symbol_table::~symbol_table): Use it.
-rw-r--r-- | dwflpp.cxx | 24 | ||||
-rw-r--r-- | tapsets.cxx | 3 | ||||
-rw-r--r-- | util.h | 12 |
3 files changed, 18 insertions, 21 deletions
@@ -98,25 +98,11 @@ dwflpp::~dwflpp() { free(cached_scopes); - for (module_cu_cache_t::iterator it = module_cu_cache.begin(); - it != module_cu_cache.end(); ++it) - delete it->second; - - for (mod_cu_function_cache_t::iterator it = cu_function_cache.begin(); - it != cu_function_cache.end(); ++it) - delete it->second; - - for (cu_inl_function_cache_t::iterator it = cu_inl_function_cache.begin(); - it != cu_inl_function_cache.end(); ++it) - delete it->second; - - for (mod_cu_type_cache_t::iterator it = global_alias_cache.begin(); - it != global_alias_cache.end(); ++it) - delete it->second; - - for (mod_cu_die_parent_cache_t::iterator it = cu_die_parent_cache.begin(); - it != cu_die_parent_cache.end(); ++it) - delete it->second; + delete_map(module_cu_cache); + delete_map(cu_function_cache); + delete_map(cu_inl_function_cache); + delete_map(global_alias_cache); + delete_map(cu_die_parent_cache); if (dwfl) dwfl_end(dwfl); diff --git a/tapsets.cxx b/tapsets.cxx index 346fa7f3..fc8cb88b 100644 --- a/tapsets.cxx +++ b/tapsets.cxx @@ -3820,8 +3820,7 @@ dwarf_builder::build(systemtap_session & sess, symbol_table::~symbol_table() { - for (iterator_t i = map_by_addr.begin(); i != map_by_addr.end(); ++i) - delete i->second; + delete_map(map_by_addr); } void @@ -97,4 +97,16 @@ lex_cast_qstring(std::string const & in) return out; } + +// Delete all values from a map-like container and clear it +// (The template is permissive -- be good!) +template <typename T> +void delete_map(T& t) +{ + for (typename T::iterator i = t.begin(); i != t.end(); ++i) + delete i->second; + t.clear(); +} + + /* vim: set sw=2 ts=8 cino=>4,n-2,{2,^-2,t0,(0,u0,w1,M1 : */ |