-
Notifications
You must be signed in to change notification settings - Fork 2
/
ndictionary.h
executable file
·109 lines (86 loc) · 3.7 KB
/
ndictionary.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
Copyright (C) 2010 Matthew Baranowski, Sander van Rossen & Raven software.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _NPDICTIONARY_H_
#define _NPDICTIONARY_H_
#include "nsequence.h"
typedef class NodeLocatorInfo * NodeLocator;
typedef class NodeDictionaryInfo * NodeDictionary;
typedef class KeyComparatorInfo * KeyComparator;
typedef class StrKeyComparatorInfo * StrKeyComparator;
typedef class IntKeyComparatorInfo * IntKeyComparator;
/********************************************************************
* CLASS NAME: KeyComparator
* abstract class defining the interface for KeyComparators
********************************************************************/
#ifndef BOOL
#define BOOL int
#endif
class KeyComparatorInfo
{
public:
virtual BOOL equal( Object key1, Object key2 )=0;
virtual char *printKey( Object key )=0;
};
/* integer comparator */
class IntKeyComparatorInfo: public KeyComparatorInfo
{
public:
virtual BOOL equal( Object key1, Object key2 ) { return ((int)key1 == (int)key2); }
virtual char *printKey( Object key ) { return NULL; }
};
/* string comparator */
class StrKeyComparatorInfo: public KeyComparatorInfo
{
public:
virtual BOOL equal( Object key1, Object key2 );
virtual char *printKey( Object key ) { return (char*)key; }
};
/********************************************************************
* CLASS NAME: NodeLocator
* extends NodePosition class to include a key for indexing
********************************************************************/
class NodeLocatorInfo: public NodePositionInfo {
private:
Object m_key;
public:
NodeLocatorInfo( NodeSequence container, Object element, Object key ):
NodePositionInfo( container, element)
{ m_key = key; };
void setKey( Object key ) { m_key = key; }
Object key() { return m_key; }
};
/********************************************************************
* CLASS NAME: NodeDictionary
* stores a series of locators that are acessed using their keys,
* a key comparator class defines how keys are used
********************************************************************/
class NodeDictionaryInfo: public NodeSequenceInfo {
private:
KeyComparator m_keyComp;
public:
NodeDictionaryInfo( KeyComparator kC ): NodeSequenceInfo() { m_keyComp = kC; };
/* appends the key, element pair to the end of the list */
void insert( Object element, Object key );
/* if the key already exists, replaces the returned element, otherwise inserts new pair */
Object insertReplace( Object element, Object key );
/* returns an object mapped to the key */
Object find( Object key );
/* removes the key, element pair and returns the element */
Object remove( Object key );
/* replaces the element mapped to the key */
Object replace( Object element, Object key );
/* debugging dump */
void dumpDictionary();
};
#endif