poco/Foundation/include/Poco/HashSet.h

178 lines
3.4 KiB
C
Raw Normal View History

2012-04-29 20:52:25 +02:00
//
// HashSet.h
//
// Library: Foundation
// Package: Hashing
// Module: HashSet
//
// Definition of the HashSet class.
//
// Copyright (c) 2006, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// SPDX-License-Identifier: BSL-1.0
2012-04-29 20:52:25 +02:00
//
#ifndef Foundation_HashSet_INCLUDED
#define Foundation_HashSet_INCLUDED
#include "Poco/Foundation.h"
#include "Poco/LinearHashTable.h"
namespace Poco {
template <class Value, class HashFunc = Hash<Value>>
2012-04-29 20:52:25 +02:00
class HashSet
/// This class implements a set using a LinearHashTable.
///
/// A HashSet can be used just like a std::set.
{
public:
typedef Value ValueType;
typedef Value& Reference;
typedef const Value& ConstReference;
typedef Value* Pointer;
typedef const Value* ConstPointer;
typedef HashFunc Hash;
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
typedef LinearHashTable<ValueType, Hash> HashTable;
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
typedef typename HashTable::Iterator Iterator;
typedef typename HashTable::ConstIterator ConstIterator;
HashSet()
/// Creates an empty HashSet.
{
}
2022-07-07 11:18:20 +02:00
HashSet(std::size_t initialReserve):
2012-04-29 20:52:25 +02:00
_table(initialReserve)
/// Creates the HashSet, using the given initialReserve.
{
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
HashSet(const HashSet& set):
_table(set._table)
/// Creates the HashSet by copying another one.
{
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
~HashSet()
/// Destroys the HashSet.
{
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
HashSet& operator = (const HashSet& table)
/// Assigns another HashSet.
{
HashSet tmp(table);
swap(tmp);
return *this;
}
2022-07-07 11:18:20 +02:00
void swap(HashSet& set) noexcept
2012-04-29 20:52:25 +02:00
/// Swaps the HashSet with another one.
{
_table.swap(set._table);
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
ConstIterator begin() const
/// Returns an iterator pointing to the first entry, if one exists.
{
return _table.begin();
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
ConstIterator end() const
/// Returns an iterator pointing to the end of the table.
{
return _table.end();
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
Iterator begin()
/// Returns an iterator pointing to the first entry, if one exists.
{
return _table.begin();
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
Iterator end()
/// Returns an iterator pointing to the end of the table.
{
return _table.end();
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
ConstIterator find(const ValueType& value) const
/// Finds an entry in the table.
{
return _table.find(value);
}
Iterator find(const ValueType& value)
/// Finds an entry in the table.
{
return _table.find(value);
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
std::size_t count(const ValueType& value) const
/// Returns the number of elements with the given
/// value, with is either 1 or 0.
{
return _table.count(value);
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
std::pair<Iterator, bool> insert(const ValueType& value)
/// Inserts an element into the set.
///
/// If the element already exists in the set,
2022-07-07 11:18:20 +02:00
/// a pair(iterator, false) with iterator pointing to the
2012-04-29 20:52:25 +02:00
/// existing element is returned.
2022-07-07 11:18:20 +02:00
/// Otherwise, the element is inserted an a
2012-04-29 20:52:25 +02:00
/// pair(iterator, true) with iterator
/// pointing to the new element is returned.
{
return _table.insert(value);
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
void erase(Iterator it)
/// Erases the element pointed to by it.
{
_table.erase(it);
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
void erase(const ValueType& value)
/// Erases the element with the given value, if it exists.
{
_table.erase(value);
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
void clear()
/// Erases all elements.
{
_table.clear();
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
std::size_t size() const
/// Returns the number of elements in the table.
{
return _table.size();
}
2022-07-07 11:18:20 +02:00
2012-04-29 20:52:25 +02:00
bool empty() const
/// Returns true iff the table is empty.
{
return _table.empty();
}
private:
HashTable _table;
};
} // namespace Poco
#endif // Foundation_HashSet_INCLUDED