Make array/map implementation more generic

This commit is contained in:
Behdad Esfahbod 2011-05-05 12:39:51 -04:00
parent b81bd42951
commit 478a42536f
2 changed files with 9 additions and 6 deletions

View File

@ -125,6 +125,8 @@ struct hb_user_data_array_t {
map.unset (key);
return true;
}
if (!key)
return false;
hb_user_data_t user_data = {data, destroy};
return map.set (key, user_data);
}

View File

@ -300,20 +300,20 @@ struct hb_map_t
private:
inline item_t *find (Key key) {
if (unlikely (!key)) return NULL;
template <typename T>
inline item_t *find (T key) {
for (unsigned int i = 0; i < items.len; i++)
if (key == items[i].key)
if (items[i].key == key)
return &items[i];
return NULL;
}
public:
inline bool set (Key key,
template <typename T>
inline bool set (T key,
Value &value)
{
if (unlikely (!key)) return NULL;
item_t *item;
item = find (key);
if (item)
@ -337,7 +337,8 @@ struct hb_map_t
items.pop ();
}
inline Value *get (Key key)
template <typename T>
inline Value *get (T key)
{
item_t *item = find (key);
return item ? &item->value : NULL;