Map.h
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00023 #ifndef _INTERFACE_BEE_UTIL_MAP_H
00024 #define _INTERFACE_BEE_UTIL_MAP_H
00025
00026 #ifdef __cplusplus
00027
00028 #include "beecrypt/c++/util/Set.h"
00029 using beecrypt::util::Set;
00030
00031 namespace beecrypt {
00032 namespace util {
00035 template<class K, class V> class Map
00036 {
00037 public:
00038 class Entry
00039 {
00040 public:
00041 virtual ~Entry() {}
00042
00043 virtual bool equals(const Entry* e) const throw () = 0;
00044 virtual bool equals(const Object* obj) const throw () = 0;
00045 virtual K* getKey() const = 0;
00046 virtual V* getValue() const = 0;
00047 virtual jint hashCode() const throw () = 0;
00048 virtual V* setValue(V*) = 0;
00049 };
00050
00051 public:
00052 virtual ~Map() {}
00053
00054 virtual void clear() = 0;
00055 virtual bool containsKey(const K* key) const = 0;
00056 virtual bool containsValue(const V* value) const = 0;
00057 virtual Set<class Entry>& entrySet() = 0;
00058 virtual const Set<class Entry>& entrySet() const = 0;
00059 virtual Set<K>& keySet() = 0;
00060 virtual const Set<K>& keySet() const = 0;
00061 virtual bool equals(const Object* obj) const throw () = 0;
00062 virtual V* get(const K* key) const = 0;
00063 virtual jint hashCode() const throw () = 0;
00064 virtual bool isEmpty() const = 0;
00065 virtual V* put(K* key, V* value) = 0;
00066 virtual void putAll(const Map<K,V>& m) = 0;
00067 virtual V* remove(const K* key) = 0;
00068 virtual jint size() const throw () = 0;
00069 virtual Collection<V>& values() = 0;
00070 virtual const Collection<V>& values() const = 0;
00071 };
00072 }
00073 }
00074
00075 #endif
00076
00077 #endif