Commit 18048e65 by Paolo Carlini Committed by Paolo Carlini

re PR libstdc++/24064 (tr1::unordered_map seems to seg-fault when caching hash values)

2005-09-30  Paolo Carlini  <pcarlini@suse.de>

	PR libstdc++/24064
	* include/tr1/hashtable (hash_code_base<>::store_code): Add.
	(hashtable<>::insert(const value_type&)): Use it.
	* testsuite/tr1/6_containers/unordered/hashtable/24064.cc: New.

From-SVN: r104823
parent 72a7ab82
2005-09-30 Paolo Carlini <pcarlini@suse.de> 2005-09-30 Paolo Carlini <pcarlini@suse.de>
PR libstdc++/24064
* include/tr1/hashtable (hash_code_base<>::store_code): Add.
(hashtable<>::insert(const value_type&)): Use it.
* testsuite/tr1/6_containers/unordered/hashtable/24064.cc: New.
2005-09-30 Paolo Carlini <pcarlini@suse.de>
PR libstdc++/23953 PR libstdc++/23953
* include/bits/locale_facets.tcc (__numpunct_cache<>::_M_cache, * include/bits/locale_facets.tcc (__numpunct_cache<>::_M_cache,
__moneypunct_cache<>::_M_cache): Check that grouping()[0] > 0. __moneypunct_cache<>::_M_cache): Check that grouping()[0] > 0.
......
...@@ -627,6 +627,10 @@ namespace Internal ...@@ -627,6 +627,10 @@ namespace Internal
{ return m_eq (k, m_extract(n->m_v)); } { return m_eq (k, m_extract(n->m_v)); }
void void
store_code(hash_node<Value, false>*, hash_code_t) const
{ }
void
copy_code(hash_node<Value, false>*, const hash_node<Value, false>*) const copy_code(hash_node<Value, false>*, const hash_node<Value, false>*) const
{ } { }
...@@ -699,6 +703,10 @@ namespace Internal ...@@ -699,6 +703,10 @@ namespace Internal
{ return m_eq (k, m_extract(n->m_v)); } { return m_eq (k, m_extract(n->m_v)); }
void void
store_code(hash_node<Value, false>*, hash_code_t) const
{ }
void
copy_code(hash_node<Value, false>*, const hash_node<Value, false>*) const copy_code(hash_node<Value, false>*, const hash_node<Value, false>*) const
{ } { }
...@@ -757,6 +765,10 @@ namespace Internal ...@@ -757,6 +765,10 @@ namespace Internal
{ return c == n->hash_code && m_eq(k, m_extract(n->m_v)); } { return c == n->hash_code && m_eq(k, m_extract(n->m_v)); }
void void
store_code(hash_node<Value, true>* n, hash_code_t c) const
{ n->hash_code = c; }
void
copy_code(hash_node<Value, true>* to, copy_code(hash_node<Value, true>* to,
const hash_node<Value, true>* from) const const hash_node<Value, true>* from) const
{ to->hash_code = from->hash_code; } { to->hash_code = from->hash_code; }
...@@ -1508,6 +1520,7 @@ namespace tr1 ...@@ -1508,6 +1520,7 @@ namespace tr1
} }
new_node->m_next = m_buckets[n]; new_node->m_next = m_buckets[n];
this->store_code(new_node, code);
m_buckets[n] = new_node; m_buckets[n] = new_node;
++m_element_count; ++m_element_count;
return std::make_pair(iterator(new_node, m_buckets + n), true); return std::make_pair(iterator(new_node, m_buckets + n), true);
...@@ -1549,6 +1562,7 @@ namespace tr1 ...@@ -1549,6 +1562,7 @@ namespace tr1
new_node->m_next = m_buckets[n]; new_node->m_next = m_buckets[n];
m_buckets[n] = new_node; m_buckets[n] = new_node;
} }
this->store_code(new_node, code);
++m_element_count; ++m_element_count;
return iterator(new_node, m_buckets + n); return iterator(new_node, m_buckets + n);
......
// Copyright (C) 2005 Free Software Foundation, Inc.
//
// This file is part of the GNU ISO C++ Library. This library is free
// software; you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the
// Free Software Foundation; either version 2, or (at your option)
// any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this library; see the file COPYING. If not, write to the Free
// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
// USA.
// 6.3 Unordered associative containers
#include <tr1/unordered_map>
#include <testsuite_hooks.h>
// libstdc++/24064
void test01()
{
bool test __attribute__((unused)) = true;
using namespace std;
using namespace tr1;
unordered_map<int, char, hash<int>, equal_to<int>,
allocator<pair<const int, char> >, true> m;
for (int i = 0; i < 1000; ++i)
m[i] = '0' + i % 9;
for (int i = 0; i < 1000; ++i)
VERIFY( ++m.find(i)->second == '1' + i % 9 );
}
int main()
{
test01();
return 0;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment