xref: /aoo4110/main/tools/source/memtools/table.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_tools.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #define _TOOLS_TABLE_CXX
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
30*b1cdbd2cSJim Jagielski #include <tools/debug.hxx>
31*b1cdbd2cSJim Jagielski #include <impcont.hxx>
32*b1cdbd2cSJim Jagielski #include <tools/table.hxx>
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski // =======================================================================
35*b1cdbd2cSJim Jagielski 
ImplGetIndex(sal_uIntPtr nKey,sal_uIntPtr * pIndex) const36*b1cdbd2cSJim Jagielski sal_uIntPtr Table::ImplGetIndex( sal_uIntPtr nKey, sal_uIntPtr* pIndex ) const
37*b1cdbd2cSJim Jagielski {
38*b1cdbd2cSJim Jagielski 	// Abpruefen, ob der erste Key groesser als der Vergleichskey ist
39*b1cdbd2cSJim Jagielski 	if ( !nCount || (nKey < (sal_uIntPtr)Container::ImpGetObject(0)) )
40*b1cdbd2cSJim Jagielski 		return TABLE_ENTRY_NOTFOUND;
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski 	sal_uIntPtr	nLow;
43*b1cdbd2cSJim Jagielski 	sal_uIntPtr	nHigh;
44*b1cdbd2cSJim Jagielski 	sal_uIntPtr	nMid;
45*b1cdbd2cSJim Jagielski 	sal_uIntPtr	nCompareKey;
46*b1cdbd2cSJim Jagielski 	void**	pNodes = Container::ImpGetOnlyNodes();
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski 	// Binaeres Suchen
49*b1cdbd2cSJim Jagielski 	nLow  = 0;
50*b1cdbd2cSJim Jagielski 	nHigh = nCount-1;
51*b1cdbd2cSJim Jagielski 	if ( pNodes )
52*b1cdbd2cSJim Jagielski 	{
53*b1cdbd2cSJim Jagielski 		do
54*b1cdbd2cSJim Jagielski 		{
55*b1cdbd2cSJim Jagielski 			nMid = (nLow + nHigh) / 2;
56*b1cdbd2cSJim Jagielski 			nCompareKey = (sal_uIntPtr)pNodes[nMid*2];
57*b1cdbd2cSJim Jagielski 			if ( nKey < nCompareKey )
58*b1cdbd2cSJim Jagielski 				nHigh = nMid-1;
59*b1cdbd2cSJim Jagielski 			else
60*b1cdbd2cSJim Jagielski 			{
61*b1cdbd2cSJim Jagielski 				if ( nKey > nCompareKey )
62*b1cdbd2cSJim Jagielski 					nLow = nMid + 1;
63*b1cdbd2cSJim Jagielski 				else
64*b1cdbd2cSJim Jagielski 					return nMid*2;
65*b1cdbd2cSJim Jagielski 			}
66*b1cdbd2cSJim Jagielski 		}
67*b1cdbd2cSJim Jagielski 		while ( nLow <= nHigh );
68*b1cdbd2cSJim Jagielski 	}
69*b1cdbd2cSJim Jagielski 	else
70*b1cdbd2cSJim Jagielski 	{
71*b1cdbd2cSJim Jagielski 		do
72*b1cdbd2cSJim Jagielski 		{
73*b1cdbd2cSJim Jagielski 			nMid = (nLow + nHigh) / 2;
74*b1cdbd2cSJim Jagielski 			nCompareKey = (sal_uIntPtr)Container::ImpGetObject( nMid*2 );
75*b1cdbd2cSJim Jagielski 			if ( nKey < nCompareKey )
76*b1cdbd2cSJim Jagielski 				nHigh = nMid-1;
77*b1cdbd2cSJim Jagielski 			else
78*b1cdbd2cSJim Jagielski 			{
79*b1cdbd2cSJim Jagielski 				if ( nKey > nCompareKey )
80*b1cdbd2cSJim Jagielski 					nLow = nMid + 1;
81*b1cdbd2cSJim Jagielski 				else
82*b1cdbd2cSJim Jagielski 					return nMid*2;
83*b1cdbd2cSJim Jagielski 			}
84*b1cdbd2cSJim Jagielski 		}
85*b1cdbd2cSJim Jagielski 		while ( nLow <= nHigh );
86*b1cdbd2cSJim Jagielski 	}
87*b1cdbd2cSJim Jagielski 
88*b1cdbd2cSJim Jagielski 	if ( pIndex )
89*b1cdbd2cSJim Jagielski 	{
90*b1cdbd2cSJim Jagielski 		if ( nKey > nCompareKey )
91*b1cdbd2cSJim Jagielski 			*pIndex = (nMid+1)*2;
92*b1cdbd2cSJim Jagielski 		else
93*b1cdbd2cSJim Jagielski 			*pIndex = nMid*2;
94*b1cdbd2cSJim Jagielski 	}
95*b1cdbd2cSJim Jagielski 
96*b1cdbd2cSJim Jagielski 	return TABLE_ENTRY_NOTFOUND;
97*b1cdbd2cSJim Jagielski }
98*b1cdbd2cSJim Jagielski 
99*b1cdbd2cSJim Jagielski // =======================================================================
100*b1cdbd2cSJim Jagielski 
Table(sal_uInt16 _nInitSize,sal_uInt16 _nReSize)101*b1cdbd2cSJim Jagielski Table::Table( sal_uInt16 _nInitSize, sal_uInt16 _nReSize ) :
102*b1cdbd2cSJim Jagielski 		   Container( CONTAINER_MAXBLOCKSIZE, _nInitSize*2, _nReSize*2 )
103*b1cdbd2cSJim Jagielski {
104*b1cdbd2cSJim Jagielski 	DBG_ASSERT( _nInitSize <= 32767, "Table::Table(): InitSize > 32767" );
105*b1cdbd2cSJim Jagielski 	DBG_ASSERT( _nReSize <= 32767, "Table::Table(): ReSize > 32767" );
106*b1cdbd2cSJim Jagielski 	nCount = 0;
107*b1cdbd2cSJim Jagielski }
108*b1cdbd2cSJim Jagielski 
109*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
110*b1cdbd2cSJim Jagielski 
Insert(sal_uIntPtr nKey,void * p)111*b1cdbd2cSJim Jagielski sal_Bool Table::Insert( sal_uIntPtr nKey, void* p )
112*b1cdbd2cSJim Jagielski {
113*b1cdbd2cSJim Jagielski 	// Tabellenelement einsortieren
114*b1cdbd2cSJim Jagielski 	sal_uIntPtr i;
115*b1cdbd2cSJim Jagielski 	if ( nCount )
116*b1cdbd2cSJim Jagielski 	{
117*b1cdbd2cSJim Jagielski 		if ( nCount <= 24 )
118*b1cdbd2cSJim Jagielski 		{
119*b1cdbd2cSJim Jagielski 			sal_uInt16 n = 0;
120*b1cdbd2cSJim Jagielski 			sal_uInt16 nTempCount = (sal_uInt16)nCount * 2;
121*b1cdbd2cSJim Jagielski 			//<!--Modified by PengYunQuan for resolving a NULL pointer access
122*b1cdbd2cSJim Jagielski 
123*b1cdbd2cSJim Jagielski 			if( void** pNodes = Container::ImpGetOnlyNodes() )
124*b1cdbd2cSJim Jagielski 			{
125*b1cdbd2cSJim Jagielski 				sal_uIntPtr  nCompareKey = (sal_uIntPtr)(*pNodes);
126*b1cdbd2cSJim Jagielski 				while ( nKey > nCompareKey )
127*b1cdbd2cSJim Jagielski 				{
128*b1cdbd2cSJim Jagielski 					n += 2;
129*b1cdbd2cSJim Jagielski 					pNodes += 2;
130*b1cdbd2cSJim Jagielski 					if ( n < nTempCount )
131*b1cdbd2cSJim Jagielski 						nCompareKey = (sal_uIntPtr)(*pNodes);
132*b1cdbd2cSJim Jagielski 					else
133*b1cdbd2cSJim Jagielski 					{
134*b1cdbd2cSJim Jagielski 						nCompareKey = 0;
135*b1cdbd2cSJim Jagielski 						break;
136*b1cdbd2cSJim Jagielski 					}
137*b1cdbd2cSJim Jagielski 				}
138*b1cdbd2cSJim Jagielski 
139*b1cdbd2cSJim Jagielski 				// Testen, ob sich der Key schon in der Tabelle befindet
140*b1cdbd2cSJim Jagielski 				if ( nKey == nCompareKey )
141*b1cdbd2cSJim Jagielski 					return sal_False;
142*b1cdbd2cSJim Jagielski 
143*b1cdbd2cSJim Jagielski 				i = n;
144*b1cdbd2cSJim Jagielski 			}
145*b1cdbd2cSJim Jagielski 			else
146*b1cdbd2cSJim Jagielski 			{
147*b1cdbd2cSJim Jagielski 				i = 0;
148*b1cdbd2cSJim Jagielski 				if ( ImplGetIndex( nKey, &i ) != TABLE_ENTRY_NOTFOUND )
149*b1cdbd2cSJim Jagielski 					return sal_False;
150*b1cdbd2cSJim Jagielski 			}
151*b1cdbd2cSJim Jagielski 			//-->Modified by PengYunQuan for resolving a NULL pointer access
152*b1cdbd2cSJim Jagielski 		}
153*b1cdbd2cSJim Jagielski 		else
154*b1cdbd2cSJim Jagielski 		{
155*b1cdbd2cSJim Jagielski 			i = 0;
156*b1cdbd2cSJim Jagielski 			if ( ImplGetIndex( nKey, &i ) != TABLE_ENTRY_NOTFOUND )
157*b1cdbd2cSJim Jagielski 				return sal_False;
158*b1cdbd2cSJim Jagielski 		}
159*b1cdbd2cSJim Jagielski 	}
160*b1cdbd2cSJim Jagielski 	else
161*b1cdbd2cSJim Jagielski 		i = 0;
162*b1cdbd2cSJim Jagielski 
163*b1cdbd2cSJim Jagielski 	// Eintrag einfuegen (Key vor Pointer)
164*b1cdbd2cSJim Jagielski 	Container::Insert( (void*)nKey, i );
165*b1cdbd2cSJim Jagielski 	Container::Insert( p, i+1 );
166*b1cdbd2cSJim Jagielski 
167*b1cdbd2cSJim Jagielski 	// Ein neuer Eintrag
168*b1cdbd2cSJim Jagielski 	nCount++;
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski 	return sal_True;
171*b1cdbd2cSJim Jagielski }
172*b1cdbd2cSJim Jagielski 
173*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
174*b1cdbd2cSJim Jagielski 
Remove(sal_uIntPtr nKey)175*b1cdbd2cSJim Jagielski void* Table::Remove( sal_uIntPtr nKey )
176*b1cdbd2cSJim Jagielski {
177*b1cdbd2cSJim Jagielski 	// Index besorgen
178*b1cdbd2cSJim Jagielski 	sal_uIntPtr nIndex = ImplGetIndex( nKey );
179*b1cdbd2cSJim Jagielski 
180*b1cdbd2cSJim Jagielski 	// Testen, ob sich der Key in der Tabelle befindet
181*b1cdbd2cSJim Jagielski 	if ( nIndex == TABLE_ENTRY_NOTFOUND )
182*b1cdbd2cSJim Jagielski 		return NULL;
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski 	// Itemanzahl erniedrigen
185*b1cdbd2cSJim Jagielski 	nCount--;
186*b1cdbd2cSJim Jagielski 
187*b1cdbd2cSJim Jagielski 	// Key entfernen
188*b1cdbd2cSJim Jagielski 	Container::Remove( nIndex );
189*b1cdbd2cSJim Jagielski 
190*b1cdbd2cSJim Jagielski 	// Pointer entfernen und zurueckgeben
191*b1cdbd2cSJim Jagielski 	return Container::Remove( nIndex );
192*b1cdbd2cSJim Jagielski }
193*b1cdbd2cSJim Jagielski 
194*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
195*b1cdbd2cSJim Jagielski 
Replace(sal_uIntPtr nKey,void * p)196*b1cdbd2cSJim Jagielski void* Table::Replace( sal_uIntPtr nKey, void* p )
197*b1cdbd2cSJim Jagielski {
198*b1cdbd2cSJim Jagielski 	// Index abfragen
199*b1cdbd2cSJim Jagielski 	sal_uIntPtr nIndex = ImplGetIndex( nKey );
200*b1cdbd2cSJim Jagielski 
201*b1cdbd2cSJim Jagielski 	// Existiert kein Eintrag mit dem Schluessel
202*b1cdbd2cSJim Jagielski 	if ( nIndex == TABLE_ENTRY_NOTFOUND )
203*b1cdbd2cSJim Jagielski 		return NULL;
204*b1cdbd2cSJim Jagielski 	else
205*b1cdbd2cSJim Jagielski 		return Container::Replace( p, nIndex+1 );
206*b1cdbd2cSJim Jagielski }
207*b1cdbd2cSJim Jagielski 
208*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
209*b1cdbd2cSJim Jagielski 
Get(sal_uIntPtr nKey) const210*b1cdbd2cSJim Jagielski void* Table::Get( sal_uIntPtr nKey ) const
211*b1cdbd2cSJim Jagielski {
212*b1cdbd2cSJim Jagielski 	// Index besorgen
213*b1cdbd2cSJim Jagielski 	sal_uIntPtr nIndex = ImplGetIndex( nKey );
214*b1cdbd2cSJim Jagielski 
215*b1cdbd2cSJim Jagielski 	// Testen, ob sich der Key in der Tabelle befindet
216*b1cdbd2cSJim Jagielski 	if ( nIndex == TABLE_ENTRY_NOTFOUND )
217*b1cdbd2cSJim Jagielski 		return NULL;
218*b1cdbd2cSJim Jagielski 	else
219*b1cdbd2cSJim Jagielski 		return Container::ImpGetObject( nIndex+1 );
220*b1cdbd2cSJim Jagielski }
221*b1cdbd2cSJim Jagielski 
222*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
223*b1cdbd2cSJim Jagielski 
GetCurObject() const224*b1cdbd2cSJim Jagielski void* Table::GetCurObject() const
225*b1cdbd2cSJim Jagielski {
226*b1cdbd2cSJim Jagielski 	return Container::ImpGetObject( Container::GetCurPos()+1 );
227*b1cdbd2cSJim Jagielski }
228*b1cdbd2cSJim Jagielski 
229*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
230*b1cdbd2cSJim Jagielski 
GetKey(const void * p) const231*b1cdbd2cSJim Jagielski sal_uIntPtr Table::GetKey( const void* p ) const
232*b1cdbd2cSJim Jagielski {
233*b1cdbd2cSJim Jagielski 	sal_uIntPtr nIndex = 0;
234*b1cdbd2cSJim Jagielski 
235*b1cdbd2cSJim Jagielski 	// Solange noch Eintraege Vorhanden sind
236*b1cdbd2cSJim Jagielski 	while ( nIndex < nCount )
237*b1cdbd2cSJim Jagielski 	{
238*b1cdbd2cSJim Jagielski 		// Stimmt der Pointer ueberein, wird der Key zurueckgegeben
239*b1cdbd2cSJim Jagielski 		if ( p == Container::ImpGetObject( (nIndex*2)+1 ) )
240*b1cdbd2cSJim Jagielski 			return (sal_uIntPtr)Container::ImpGetObject( nIndex*2 );
241*b1cdbd2cSJim Jagielski 
242*b1cdbd2cSJim Jagielski 		nIndex++;
243*b1cdbd2cSJim Jagielski 	}
244*b1cdbd2cSJim Jagielski 
245*b1cdbd2cSJim Jagielski 	return TABLE_ENTRY_NOTFOUND;
246*b1cdbd2cSJim Jagielski }
247*b1cdbd2cSJim Jagielski 
248*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
249*b1cdbd2cSJim Jagielski 
IsKeyValid(sal_uIntPtr nKey) const250*b1cdbd2cSJim Jagielski sal_Bool Table::IsKeyValid( sal_uIntPtr nKey ) const
251*b1cdbd2cSJim Jagielski {
252*b1cdbd2cSJim Jagielski 	return (ImplGetIndex( nKey ) != TABLE_ENTRY_NOTFOUND) ? sal_True : sal_False;
253*b1cdbd2cSJim Jagielski }
254*b1cdbd2cSJim Jagielski 
255*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
256*b1cdbd2cSJim Jagielski 
GetUniqueKey(sal_uIntPtr nStartKey) const257*b1cdbd2cSJim Jagielski sal_uIntPtr Table::GetUniqueKey( sal_uIntPtr nStartKey ) const
258*b1cdbd2cSJim Jagielski {
259*b1cdbd2cSJim Jagielski 	DBG_ASSERT( (nStartKey > 1) && (nStartKey < 0xFFFFFFFF),
260*b1cdbd2cSJim Jagielski 				"Table::GetUniqueKey() - nStartKey == 0 or nStartKey >= 0xFFFFFFFF" );
261*b1cdbd2cSJim Jagielski 
262*b1cdbd2cSJim Jagielski 	if ( !nCount )
263*b1cdbd2cSJim Jagielski 		return nStartKey;
264*b1cdbd2cSJim Jagielski 
265*b1cdbd2cSJim Jagielski 	sal_uIntPtr nLastKey = (sal_uIntPtr)Container::GetObject( (nCount*2)-2 );
266*b1cdbd2cSJim Jagielski 	if ( nLastKey < nStartKey )
267*b1cdbd2cSJim Jagielski 		return nStartKey;
268*b1cdbd2cSJim Jagielski 	else
269*b1cdbd2cSJim Jagielski 	{
270*b1cdbd2cSJim Jagielski 		if ( nLastKey < 0xFFFFFFFE )
271*b1cdbd2cSJim Jagielski 			return nLastKey+1;
272*b1cdbd2cSJim Jagielski 		else
273*b1cdbd2cSJim Jagielski 		{
274*b1cdbd2cSJim Jagielski 			sal_uIntPtr nPos;
275*b1cdbd2cSJim Jagielski 			sal_uIntPtr nTempPos = ImplGetIndex( nStartKey, &nPos );
276*b1cdbd2cSJim Jagielski 			if ( nTempPos != TABLE_ENTRY_NOTFOUND )
277*b1cdbd2cSJim Jagielski 				nPos = nTempPos;
278*b1cdbd2cSJim Jagielski 			nLastKey = (sal_uIntPtr)Container::GetObject( nPos );
279*b1cdbd2cSJim Jagielski 			if ( nStartKey < nLastKey )
280*b1cdbd2cSJim Jagielski 				return nStartKey;
281*b1cdbd2cSJim Jagielski 			while ( nLastKey < 0xFFFFFFFE )
282*b1cdbd2cSJim Jagielski 			{
283*b1cdbd2cSJim Jagielski 				nPos += 2;
284*b1cdbd2cSJim Jagielski 				nLastKey++;
285*b1cdbd2cSJim Jagielski 				if ( nLastKey != (sal_uIntPtr)Container::GetObject( nPos ) )
286*b1cdbd2cSJim Jagielski 					return nLastKey;
287*b1cdbd2cSJim Jagielski 			}
288*b1cdbd2cSJim Jagielski 		}
289*b1cdbd2cSJim Jagielski 	}
290*b1cdbd2cSJim Jagielski 
291*b1cdbd2cSJim Jagielski 	return 0;
292*b1cdbd2cSJim Jagielski }
293*b1cdbd2cSJim Jagielski 
294*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
295*b1cdbd2cSJim Jagielski 
SearchKey(sal_uIntPtr nKey,sal_uIntPtr * pPos) const296*b1cdbd2cSJim Jagielski sal_uIntPtr Table::SearchKey( sal_uIntPtr nKey, sal_uIntPtr* pPos ) const
297*b1cdbd2cSJim Jagielski {
298*b1cdbd2cSJim Jagielski 	*pPos = 0;
299*b1cdbd2cSJim Jagielski 	sal_uIntPtr nPos = ImplGetIndex( nKey, pPos );
300*b1cdbd2cSJim Jagielski 	if ( nPos != TABLE_ENTRY_NOTFOUND )
301*b1cdbd2cSJim Jagielski 	{
302*b1cdbd2cSJim Jagielski 		nPos /= 2;
303*b1cdbd2cSJim Jagielski 		*pPos = nPos;
304*b1cdbd2cSJim Jagielski 	}
305*b1cdbd2cSJim Jagielski 	else
306*b1cdbd2cSJim Jagielski 		*pPos /= 2;
307*b1cdbd2cSJim Jagielski 	return nPos;
308*b1cdbd2cSJim Jagielski }
309*b1cdbd2cSJim Jagielski 
310*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
311*b1cdbd2cSJim Jagielski 
Seek(sal_uIntPtr nKey)312*b1cdbd2cSJim Jagielski void* Table::Seek( sal_uIntPtr nKey )
313*b1cdbd2cSJim Jagielski {
314*b1cdbd2cSJim Jagielski 	// Testen, ob ein Eintrag vorhanden ist
315*b1cdbd2cSJim Jagielski 	if ( nCount )
316*b1cdbd2cSJim Jagielski 	{
317*b1cdbd2cSJim Jagielski 		sal_uIntPtr nIndex = ImplGetIndex( nKey );
318*b1cdbd2cSJim Jagielski 
319*b1cdbd2cSJim Jagielski 		// Ist Key nicht enthalten
320*b1cdbd2cSJim Jagielski 		if ( nIndex == TABLE_ENTRY_NOTFOUND )
321*b1cdbd2cSJim Jagielski 			return NULL;
322*b1cdbd2cSJim Jagielski 		else
323*b1cdbd2cSJim Jagielski 		{
324*b1cdbd2cSJim Jagielski 			// Index setzen
325*b1cdbd2cSJim Jagielski 			Container::Seek( nIndex );
326*b1cdbd2cSJim Jagielski 
327*b1cdbd2cSJim Jagielski 			// Pointer zurueckgeben
328*b1cdbd2cSJim Jagielski 			return Container::ImpGetObject( Container::GetCurPos() + 1 );
329*b1cdbd2cSJim Jagielski 		}
330*b1cdbd2cSJim Jagielski 	}
331*b1cdbd2cSJim Jagielski 	else
332*b1cdbd2cSJim Jagielski 		return NULL;
333*b1cdbd2cSJim Jagielski }
334*b1cdbd2cSJim Jagielski 
335*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
336*b1cdbd2cSJim Jagielski 
Seek(void * p)337*b1cdbd2cSJim Jagielski void* Table::Seek( void* p )
338*b1cdbd2cSJim Jagielski {
339*b1cdbd2cSJim Jagielski 	sal_uIntPtr nKey = GetKey( p );
340*b1cdbd2cSJim Jagielski 
341*b1cdbd2cSJim Jagielski 	// Ist Key vorhanden, dann als aktuellen Eintrag setzen
342*b1cdbd2cSJim Jagielski 	if ( nKey != TABLE_ENTRY_NOTFOUND )
343*b1cdbd2cSJim Jagielski 		return Seek( nKey );
344*b1cdbd2cSJim Jagielski 	else
345*b1cdbd2cSJim Jagielski 		return NULL;
346*b1cdbd2cSJim Jagielski }
347*b1cdbd2cSJim Jagielski 
348*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
349*b1cdbd2cSJim Jagielski 
First()350*b1cdbd2cSJim Jagielski void* Table::First()
351*b1cdbd2cSJim Jagielski {
352*b1cdbd2cSJim Jagielski 	// Testen, ob ein Eintrag vorhanden ist
353*b1cdbd2cSJim Jagielski 	if ( nCount )
354*b1cdbd2cSJim Jagielski 	{
355*b1cdbd2cSJim Jagielski 		// Auf ersten Eintag setzen
356*b1cdbd2cSJim Jagielski 		Container::First();
357*b1cdbd2cSJim Jagielski 
358*b1cdbd2cSJim Jagielski 		// Pointer zurueckgeben
359*b1cdbd2cSJim Jagielski 		return Container::ImpGetObject( 1 );
360*b1cdbd2cSJim Jagielski 	}
361*b1cdbd2cSJim Jagielski 	else
362*b1cdbd2cSJim Jagielski 		return NULL;
363*b1cdbd2cSJim Jagielski }
364*b1cdbd2cSJim Jagielski 
365*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
366*b1cdbd2cSJim Jagielski 
Last()367*b1cdbd2cSJim Jagielski void* Table::Last()
368*b1cdbd2cSJim Jagielski {
369*b1cdbd2cSJim Jagielski 	// Testen, ob ein Eintrag vorhanden ist
370*b1cdbd2cSJim Jagielski 	if ( nCount )
371*b1cdbd2cSJim Jagielski 	{
372*b1cdbd2cSJim Jagielski 		// Last auf letzten Eintrag setzen
373*b1cdbd2cSJim Jagielski 		void* p = Container::Last();
374*b1cdbd2cSJim Jagielski 		Container::Prev();
375*b1cdbd2cSJim Jagielski 
376*b1cdbd2cSJim Jagielski 		// Pointer zurueckgeben
377*b1cdbd2cSJim Jagielski 		return p;
378*b1cdbd2cSJim Jagielski 	}
379*b1cdbd2cSJim Jagielski 	else
380*b1cdbd2cSJim Jagielski 		return NULL;
381*b1cdbd2cSJim Jagielski }
382*b1cdbd2cSJim Jagielski 
383*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
384*b1cdbd2cSJim Jagielski 
Next()385*b1cdbd2cSJim Jagielski void* Table::Next()
386*b1cdbd2cSJim Jagielski {
387*b1cdbd2cSJim Jagielski 	// Ueber den Pointer weiterschalten
388*b1cdbd2cSJim Jagielski 	Container::Next();
389*b1cdbd2cSJim Jagielski 
390*b1cdbd2cSJim Jagielski 	// Nachsten Eintag
391*b1cdbd2cSJim Jagielski 	Container::Next();
392*b1cdbd2cSJim Jagielski 
393*b1cdbd2cSJim Jagielski 	// Pointer vom naechsten Key zurueckgeben
394*b1cdbd2cSJim Jagielski 	return Container::ImpGetObject( Container::GetCurPos() + 1 );
395*b1cdbd2cSJim Jagielski }
396*b1cdbd2cSJim Jagielski 
397*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
398*b1cdbd2cSJim Jagielski 
Prev()399*b1cdbd2cSJim Jagielski void* Table::Prev()
400*b1cdbd2cSJim Jagielski {
401*b1cdbd2cSJim Jagielski 	// Ueber den Pointer weiterschalten
402*b1cdbd2cSJim Jagielski 	void* p = Container::Prev();
403*b1cdbd2cSJim Jagielski 
404*b1cdbd2cSJim Jagielski 	// Nachsten Eintag
405*b1cdbd2cSJim Jagielski 	Container::Prev();
406*b1cdbd2cSJim Jagielski 
407*b1cdbd2cSJim Jagielski 	// Pointer vom vorherigen Key zurueckgeben
408*b1cdbd2cSJim Jagielski 	return p;
409*b1cdbd2cSJim Jagielski }
410