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

SearchTreeNode.h

Go to the documentation of this file.
00001 /*
00002  * SearchTreeNode.h
00003  *
00004  * Smalltalk like class library for C++
00005  * Node of tree. Header.
00006  *
00007  * Copyright (c) 2004 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 __SEARCHTREENODE_H
00025 #define __SEARCHTREENODE_H
00026 
00027 #include <stlib/Object.h>
00028 
00029 namespace Core {
00030 
00031 class Dictionary;
00032 class SequenceableCollection;
00033 class String;
00034 
00035 class SearchTreeNode : public Object
00036 {
00037   protected:
00038     Dictionary *branches;
00039     Object *_value;
00040 
00041   public:
00042     SearchTreeNode(void);
00043 
00044     /* Class-accessing protocol */
00045     virtual String *className(void) const;
00046     virtual SearchTreeNode *createNewNode(void);
00047 
00048     /* Accessing protocol */
00049     virtual Object *at(SequenceableCollection *key);
00050     virtual Object *at(SequenceableCollection *key, Object *ifAbsentValue);
00051     virtual void put(SequenceableCollection *key, Object *value);
00052 
00053     virtual Object *atLongestPrefixOf(SequenceableCollection *key);
00054 
00055     /* Testing protocol */
00056     virtual bool includesKey(SequenceableCollection *key);
00057 
00058     /* Private protocol */
00059     virtual Object *valueAt(SequenceableCollection *key, int depth, bool prefix);
00060     virtual void putValueAt(SequenceableCollection *key, Object *value, int depth);
00061 
00062     virtual Object *privDeeperValueAt(SequenceableCollection *key,
00063                                       int depth, bool prefix);
00064 };
00065 
00066 };
00067 
00068 #endif /* __SEARCHTREENODE_H */

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