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

Set.h

Go to the documentation of this file.
00001 /*
00002  * Set.h
00003  *
00004  * Smalltalk like class library for C++
00005  * Growable collection, 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 __SET_H
00025 #define __SET_H
00026 
00027 #include <stlib/Collection.h>
00028 
00029 namespace Core {
00030 
00031 class Array;
00032 class CollectionIterator;
00033 class String;
00034 
00035 class Set : public Collection
00036 {
00037   protected:
00038     Array *content;
00039     int tally;
00040 
00041   public:
00042     Set(int length = 2);
00043     virtual ~Set(void);
00044 
00045     /* Copying protocol */
00046     Set(Set &origin);
00047 
00048     /* Class-accessing protocol */
00049     virtual String *className(void) const;
00050 
00051     /* Accessing protocol */
00052     virtual long capacity(void) const;
00053     virtual long size(void) const;
00054     virtual Object *any(void);
00055 
00056     /* Adding protocol */
00057     virtual void add(Object *obj);
00058 
00059     /* Converting protocol */
00060     virtual Set *asSet(void);
00061 
00062     /* Copying protocol */
00063     virtual Object *copy(void);
00064     virtual Object *copyEmpty(long size);
00065 
00066     /* Removing protocol */
00067     virtual Object *remove(Object *obj);
00068 
00069     /* Testing protocol */
00070     virtual bool includes(Object *obj);
00071 
00072     /* Private protocol */
00073     virtual void atNewIndexPut(int index, Object *obj);
00074     virtual int findElementOrNil(Object *obj);
00075     virtual bool isEmptyAt(int index);
00076     virtual Object *privAtIndex(int index);
00077 
00078   protected:
00079     /* Enumeration protocol */
00080     virtual Object *privNextForIterator(CollectionIterator *iter) const;
00081 
00082     /* Private protocol */
00083     virtual void changeCapacity(long newCapacity);
00084     virtual void fixCollisionsFrom(int index);
00085     virtual void fullCheck(void);
00086     virtual void grow(void);
00087 };
00088 
00089 };
00090 
00091 #endif /* __SET_H */

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