Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members

Dictionary.h

Go to the documentation of this file.
00001 /*
00002  * Dictionary.h
00003  *
00004  * Smalltalk like class library for C++
00005  * Growable collection of key-value pairs, not index-accessible. Header.
00006  *
00007  * Copyright (c) 2003 Milan Cermak
00008  */
00009 /*
00010  * This library is free software; you can redistribute it and/or
00011  * modify it under the terms of the GNU Lesser General Public
00012  * License as published by the Free Software Foundation; either
00013  * version 2.1 of the License, or (at your option) any later version.
00014  *
00015  * This library is distributed in the hope that it will be useful,
00016  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00017  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00018  * Lesser General Public License for more details.
00019  *
00020  * You should have received a copy of the GNU Lesser General Public
00021  * License along with this library; if not, write to the Free Software
00022  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00023  */
00024 #ifndef __DICTIONARY_H
00025 #define __DICTIONARY_H
00026 
00027 #include <stlib/Set.h>
00028 
00029 namespace Core {
00030 
00031 class Association;
00032 class KeysAndValuesIterator;
00033 class String;
00034 class Visitor;
00035 
00036 class Dictionary : public Set
00037 {
00038   public:
00039     Dictionary(int length = 2);
00040 
00041     /* Class-accessing protocol */
00042     virtual String *className(void) const;
00043 
00044     /* Accessing protocol */
00045     virtual Object *at(Object *key);
00046     virtual Object *at(Object *key, Object *ifAbsentValue);
00047     virtual Object *at(const char* key);
00048     virtual Object *at(const char* key, const char *ifAbsentValue);
00049     virtual void put(Object *key, Object *value);
00050     virtual void put(const char* key, Object* value);
00051     virtual void put(const char* key, const char* value);
00052     virtual Object *keyAtValue(Object *value);
00053     virtual Object *keyAtValue(Object *value, Object *ifAbsentKey);
00054 
00055     /* Adding protocol */
00056     virtual void add(Object *obj);
00057 
00058     /* Copying protocol */
00059     virtual Object *copy(void);
00060     virtual Object *copyEmpty(long size);
00061 
00062     /* Enumeration protocol */
00063     virtual KeysAndValuesIterator *keysAndValuesIterator(void) const;
00064 
00065     /* Removing protocol */
00066     virtual Object *remove(Object *);
00067     virtual Object *removeKey(Object *key);
00068 
00069     /* Testing protocol */
00070     virtual bool includes(Object *obj);
00071     virtual bool includesKey(Object *key);
00072 
00073     /* Visiting protocol */
00074     virtual void visitBy(Visitor *visitor);
00075 
00076     /* Private protocol */
00077     virtual int findKey(Object *key);
00078     virtual int findKeyOrNil(Object *key);
00079 
00080   protected:
00081     virtual void changeCapacity(long newCapacity);
00082     virtual void fixCollisionsFrom(int index);
00083     virtual void noCheckAdd(Association *object);
00084 };
00085 
00086 };
00087 
00088 #endif /* __DICTIONARY_H */

Generated on Mon Nov 27 09:47:55 2006 for Smalltalk like C++ Class Library by  doxygen 1.4.2