// Copyright (C) 2003 Davis E. King (davis@dlib.net) // License: Boost Software License See LICENSE.txt for the full license. #ifndef DLIB_HASH_SET_KERNEl_1_ #define DLIB_HASH_SET_KERNEl_1_ #include "hash_set_kernel_abstract.h" #include "../algs.h" #include "../general_hash/general_hash.h" #include "../interfaces/enumerable.h" #include "../interfaces/remover.h" #include "../assert.h" #include "../serialize.h" namespace dlib { template < typename T, unsigned long expnum, typename hash_table, typename mem_manager = default_memory_manager > class hash_set_kernel_1 : public enumerable, public remover { /*! REQUIREMENTS ON hash_table hash_table is instantiated with and T_is_POD must be set to false and is an implementation of hash_table/hash_table_kernel_abstract.h INITIAL VALUE table.size() == 0 CONVENTION table.size() = size() == the number of elements in the set and the elements in this hash_set are stored in table !*/ public: typedef T type; typedef typename hash_table::compare_type compare_type; typedef mem_manager mem_manager_type; hash_set_kernel_1( ) : table(expnum) { COMPILE_TIME_ASSERT(expnum < 32); } virtual ~hash_set_kernel_1( ) {} inline void clear( ); inline void add ( T& item ); inline bool is_member ( const T& item ) const; inline void remove ( const T& item, T& item_copy ); inline void destroy ( const T& item ); inline void swap ( hash_set_kernel_1& item ); // functions from the remover interface inline void remove_any ( T& item ); // functions from the enumerable interface inline size_t size ( ) const; inline bool at_start ( ) const; inline void reset ( ) const; inline bool current_element_valid ( ) const; inline const T& element ( ) const; inline const T& element ( ); inline bool move_next ( ) const; private: hash_table table; char junk; // restricted functions hash_set_kernel_1(hash_set_kernel_1&); hash_set_kernel_1& operator= ( hash_set_kernel_1&); }; template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > inline void swap ( hash_set_kernel_1& a, hash_set_kernel_1& b ) { a.swap(b); } template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void deserialize ( hash_set_kernel_1& item, std::istream& in ) { try { item.clear(); unsigned long size; deserialize(size,in); T temp; for (unsigned long i = 0; i < size; ++i) { deserialize(temp,in); item.add(temp); } } catch (serialization_error& e) { item.clear(); throw serialization_error(e.info + "\n while deserializing object of type hash_set_kernel_1"); } } // ---------------------------------------------------------------------------------------- // ---------------------------------------------------------------------------------------- // member function definitions // ---------------------------------------------------------------------------------------- // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void hash_set_kernel_1:: clear ( ) { table.clear(); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void hash_set_kernel_1:: add ( T& item ) { table.add(item,junk); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > bool hash_set_kernel_1:: is_member( const T& item ) const { return (table[item] != 0); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void hash_set_kernel_1:: remove_any ( T& item ) { table.remove_any(item,junk); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void hash_set_kernel_1:: remove( const T& item, T& item_copy ) { table.remove(item,item_copy,junk); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void hash_set_kernel_1:: destroy( const T& item ) { table.destroy(item); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > size_t hash_set_kernel_1:: size ( ) const { return table.size(); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void hash_set_kernel_1:: swap ( hash_set_kernel_1& item ) { table.swap(item.table); } // ---------------------------------------------------------------------------------------- // ---------------------------------------------------------------------------------------- // enumerable function definitions // ---------------------------------------------------------------------------------------- // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > bool hash_set_kernel_1:: at_start ( ) const { return table.at_start(); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > void hash_set_kernel_1:: reset ( ) const { table.reset(); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > bool hash_set_kernel_1:: current_element_valid ( ) const { return table.current_element_valid(); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > const T& hash_set_kernel_1:: element ( ) const { return table.element().key(); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > const T& hash_set_kernel_1:: element ( ) { return table.element().key(); } // ---------------------------------------------------------------------------------------- template < typename T, unsigned long expnum, typename hash_table, typename mem_manager > bool hash_set_kernel_1:: move_next ( ) const { return table.move_next(); } // ---------------------------------------------------------------------------------------- } #endif // DLIB_HASH_SET_KERNEl_1_