+2015-11-24 Trevor Saunders <tbsaunde+gcc@tbsaunde.org>
+
+ * hash-map-traits.h (simple_hashmap_traits ::remove): call
+ destructors on values that are being removed.
+ * mem-stats.h (hash_map): Pass type of values to
+ simple_hashmap_traits.
+ * tree-sra.c (sra_deinitialize): Remove work around for hash
+ maps not destructing values.
+ * genmatch.c (sinfo_hashmap_traits): Adjust.
+ * tree-ssa-uncprop.c (val_ssa_equiv_hash_traits): Likewise.
+
2015-11-24 Richard Biener <rguenther@suse.de>
Kyrylo Tkachov <kyrylo.tkachov@arm.com>
/* Implement hash_map traits for a key with hash traits H. Empty and
deleted map entries are represented as empty and deleted keys. */
-template <typename H>
+template <typename H, typename Value>
struct simple_hashmap_traits
{
typedef typename H::value_type key_type;
template <typename T> static inline void mark_deleted (T &);
};
-template <typename H>
+template <typename H, typename Value>
inline hashval_t
-simple_hashmap_traits <H>::hash (const key_type &h)
+simple_hashmap_traits <H, Value>::hash (const key_type &h)
{
return H::hash (h);
}
-template <typename H>
+template <typename H, typename Value>
inline bool
-simple_hashmap_traits <H>::equal_keys (const key_type &k1, const key_type &k2)
+simple_hashmap_traits <H, Value>::equal_keys (const key_type &k1,
+ const key_type &k2)
{
return H::equal (k1, k2);
}
-template <typename H>
+template <typename H, typename Value>
template <typename T>
inline void
-simple_hashmap_traits <H>::remove (T &entry)
+simple_hashmap_traits <H, Value>::remove (T &entry)
{
H::remove (entry.m_key);
+ entry.m_value.~Value ();
}
-template <typename H>
+template <typename H, typename Value>
template <typename T>
inline bool
-simple_hashmap_traits <H>::is_empty (const T &entry)
+simple_hashmap_traits <H, Value>::is_empty (const T &entry)
{
return H::is_empty (entry.m_key);
}
-template <typename H>
+template <typename H, typename Value>
template <typename T>
inline bool
-simple_hashmap_traits <H>::is_deleted (const T &entry)
+simple_hashmap_traits <H, Value>::is_deleted (const T &entry)
{
return H::is_deleted (entry.m_key);
}
-template <typename H>
+template <typename H, typename Value>
template <typename T>
inline void
-simple_hashmap_traits <H>::mark_empty (T &entry)
+simple_hashmap_traits <H, Value>::mark_empty (T &entry)
{
H::mark_empty (entry.m_key);
}
-template <typename H>
+template <typename H, typename Value>
template <typename T>
inline void
-simple_hashmap_traits <H>::mark_deleted (T &entry)
+simple_hashmap_traits <H, Value>::mark_deleted (T &entry)
{
H::mark_deleted (entry.m_key);
}
assign_link_pool.release ();
obstack_free (&name_obstack, NULL);
- /* TODO: hash_map does not support traits that can release
- value type of the hash_map. */
- for (hash_map<tree, auto_vec<access_p> >::iterator it =
- base_access_vec->begin (); it != base_access_vec->end (); ++it)
- (*it).second.release ();
-
delete base_access_vec;
}