* Added copyless direct value accessors (via Iterator::NextValue(), and

Get()).


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@32154 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2009-08-06 09:42:34 +00:00
parent 696b8f43fb
commit 5174cb1f74

View File

@ -28,12 +28,13 @@
#ifndef HASH_MAP_H #ifndef HASH_MAP_H
#define HASH_MAP_H #define HASH_MAP_H
//#include <Debug.h>
#include <Locker.h> #include <Locker.h>
#include "AutoLocker.h" #include "AutoLocker.h"
#include "OpenHashTable.h" #include "OpenHashTable.h"
namespace BPrivate { namespace BPrivate {
// HashMapElement // HashMapElement
@ -107,7 +108,17 @@ public:
_FindNext(); _FindNext();
return result; return result;
} }
Value* NextValue()
{
if (fElement == NULL)
return NULL;
Value* value = &fElement->fValue;
_FindNext();
return value;
}
Entry Remove() Entry Remove()
{ {
if (!fLastElement) if (!fLastElement)
@ -169,6 +180,7 @@ public:
Value Remove(const Key& key); Value Remove(const Key& key);
void Clear(); void Clear();
Value Get(const Key& key) const; Value Get(const Key& key) const;
bool Get(const Key& key, Value*& _value) const;
bool ContainsKey(const Key& key) const; bool ContainsKey(const Key& key) const;
@ -404,6 +416,19 @@ HashMap<Key, Value>::Get(const Key& key) const
return Value(); return Value();
} }
// Get
template<typename Key, typename Value>
bool
HashMap<Key, Value>::Get(const Key& key, Value*& _value) const
{
if (Element* element = _FindElement(key)) {
_value = &element->fValue;
return true;
}
return false;
}
// ContainsKey // ContainsKey
template<typename Key, typename Value> template<typename Key, typename Value>
bool bool