Commit cc08872c authored by Vicențiu Ciorbaru's avatar Vicențiu Ciorbaru

Initialize the Hash_set during creation

If the Hash_set is not initialized, one can not call find() on it before
at least one element has been inserted into it.
parent b482e87f
...@@ -28,17 +28,15 @@ class Hash_set ...@@ -28,17 +28,15 @@ class Hash_set
public: public:
enum { START_SIZE= 8 }; enum { START_SIZE= 8 };
/** /**
Constructs an empty hash. Does not allocate memory, it is done upon Constructs an empty unique hash.
the first insert. Thus does not cause or return errors.
*/ */
Hash_set(PSI_memory_key psi_key, uchar *(*K)(const T *, size_t *, my_bool), Hash_set(PSI_memory_key psi_key, uchar *(*K)(const T *, size_t *, my_bool),
CHARSET_INFO *cs= &my_charset_bin) CHARSET_INFO *cs= &my_charset_bin)
{ {
my_hash_clear(&m_hash); my_hash_init(psi_key, &m_hash, cs, START_SIZE, 0, 0, (my_hash_get_key)K, 0,
m_hash.get_key= (my_hash_get_key)K; HASH_UNIQUE);
m_hash.charset= cs;
m_hash.array.m_psi_key= psi_key;
} }
Hash_set(PSI_memory_key psi_key, CHARSET_INFO *charset, ulong default_array_elements, Hash_set(PSI_memory_key psi_key, CHARSET_INFO *charset, ulong default_array_elements,
size_t key_offset, size_t key_length, my_hash_get_key get_key, size_t key_offset, size_t key_length, my_hash_get_key get_key,
void (*free_element)(void*), uint flags) void (*free_element)(void*), uint flags)
...@@ -65,8 +63,6 @@ class Hash_set ...@@ -65,8 +63,6 @@ class Hash_set
*/ */
bool insert(T *value) bool insert(T *value)
{ {
my_hash_init_opt(m_hash.array.m_psi_key, &m_hash, m_hash.charset,
START_SIZE, 0, 0, m_hash.get_key, 0, HASH_UNIQUE);
return my_hash_insert(&m_hash, reinterpret_cast<const uchar*>(value)); return my_hash_insert(&m_hash, reinterpret_cast<const uchar*>(value));
} }
bool remove(T *value) bool remove(T *value)
......
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