Map.h

Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2005 X-Way Rights BV
00003  *
00004  * This library is free software; you can redistribute it and/or
00005  * modify it under the terms of the GNU Lesser General Public
00006  * License as published by the Free Software Foundation; either
00007  * version 2.1 of the License, or (at your option) any later version.
00008  *
00009  * This library is distributed in the hope that it will be useful,
00010  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00011  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012  * Lesser General Public License for more details.
00013  *
00014  * You should have received a copy of the GNU Lesser General Public
00015  * License along with this library; if not, write to the Free Software
00016  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
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

Generated on Fri Jun 19 13:39:40 2009 for BeeCrypt C++ by  doxygen 1.5.8