VirtualBox

source: vbox/trunk/include/iprt/avl.h@ 4997

Last change on this file since 4997 was 4687, checked in by vboxsync, 17 years ago

Added RTAvllU32*. Applied enumeration fixes for non-unique tree. Applied Destroy fixes.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 30.1 KB
Line 
1/** @file
2 * innotek Portable Runtime - AVL Trees.
3 */
4
5/*
6 * Copyright (C) 1999-2003 knut st. osmundsen <[email protected]>
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License as published by the Free Software Foundation,
12 * in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
13 * distribution. VirtualBox OSE is distributed in the hope that it will
14 * be useful, but WITHOUT ANY WARRANTY of any kind.
15 */
16
17#ifndef ___iprt_avl_h
18#define ___iprt_avl_h
19
20#include <iprt/cdefs.h>
21#include <iprt/types.h>
22
23__BEGIN_DECLS
24
25/** @defgroup grp_rt_avl RTAvl - AVL Trees
26 * @ingroup grp_rt
27 * @{
28 */
29
30
31/** AVL tree of void pointers.
32 * @{
33 */
34
35/**
36 * AVL key type
37 */
38typedef void * AVLPVKEY;
39
40/**
41 * AVL Core node.
42 */
43typedef struct _AVLPVNodeCore
44{
45 AVLPVKEY Key; /** Key value. */
46 struct _AVLPVNodeCore *pLeft; /** Pointer to left leaf node. */
47 struct _AVLPVNodeCore *pRight; /** Pointer to right leaf node. */
48 unsigned char uchHeight; /** Height of this tree: max(height(left), height(right)) + 1 */
49} AVLPVNODECORE, *PAVLPVNODECORE, **PPAVLPVNODECORE;
50
51/** A tree with void pointer keys. */
52typedef PAVLPVNODECORE AVLPVTREE;
53/** Pointer to a tree with void pointer keys. */
54typedef PPAVLPVNODECORE PAVLPVTREE;
55
56/** Callback function for AVLPVDoWithAll(). */
57typedef DECLCALLBACK(int) AVLPVCALLBACK(PAVLPVNODECORE, void *);
58/** Pointer to callback function for AVLPVDoWithAll(). */
59typedef AVLPVCALLBACK *PAVLPVCALLBACK;
60
61/*
62 * Functions.
63 */
64RTDECL(bool) RTAvlPVInsert(PAVLPVTREE ppTree, PAVLPVNODECORE pNode);
65RTDECL(PAVLPVNODECORE) RTAvlPVRemove(PAVLPVTREE ppTree, AVLPVKEY Key);
66RTDECL(PAVLPVNODECORE) RTAvlPVGet(PAVLPVTREE ppTree, AVLPVKEY Key);
67RTDECL(PAVLPVNODECORE) RTAvlPVGetBestFit(PAVLPVTREE ppTree, AVLPVKEY Key, bool fAbove);
68RTDECL(PAVLPVNODECORE) RTAvlPVRemoveBestFit(PAVLPVTREE ppTree, AVLPVKEY Key, bool fAbove);
69RTDECL(int) RTAvlPVDoWithAll(PAVLPVTREE ppTree, int fFromLeft, PAVLPVCALLBACK pfnCallBack, void *pvParam);
70RTDECL(int) RTAvlPVDestroy(PAVLPVTREE ppTree, PAVLPVCALLBACK pfnCallBack, void *pvParam);
71
72/** @} */
73
74
75/** AVL tree of unsigned long.
76 * @{
77 */
78
79/**
80 * AVL key type
81 */
82typedef unsigned long AVLULKEY;
83
84/**
85 * AVL Core node.
86 */
87typedef struct _AVLULNodeCore
88{
89 AVLULKEY Key; /** Key value. */
90 struct _AVLULNodeCore *pLeft; /** Pointer to left leaf node. */
91 struct _AVLULNodeCore *pRight; /** Pointer to right leaf node. */
92 unsigned char uchHeight; /** Height of this tree: max(height(left), height(right)) + 1 */
93} AVLULNODECORE, *PAVLULNODECORE, **PPAVLULNODECORE;
94
95
96/** Callback function for AVLULDoWithAll(). */
97typedef DECLCALLBACK(int) AVLULCALLBACK(PAVLULNODECORE, void*);
98/** Pointer to callback function for AVLULDoWithAll(). */
99typedef AVLULCALLBACK *PAVLULCALLBACK;
100
101
102/*
103 * Functions.
104 */
105RTDECL(bool) RTAvlULInsert(PPAVLULNODECORE ppTree, PAVLULNODECORE pNode);
106RTDECL(PAVLULNODECORE) RTAvlULRemove(PPAVLULNODECORE ppTree, AVLULKEY Key);
107RTDECL(PAVLULNODECORE) RTAvlULGet(PPAVLULNODECORE ppTree, AVLULKEY Key);
108RTDECL(PAVLULNODECORE) RTAvlULGetBestFit(PPAVLULNODECORE ppTree, AVLULKEY Key, bool fAbove);
109RTDECL(PAVLULNODECORE) RTAvlULRemoveBestFit(PPAVLULNODECORE ppTree, AVLULKEY Key, bool fAbove);
110RTDECL(int) RTAvlULDoWithAll(PPAVLULNODECORE ppTree, int fFromLeft, PAVLULCALLBACK pfnCallBack, void *pvParam);
111
112/** @} */
113
114
115
116/** AVL tree of uint32_t
117 * @{
118 */
119
120/** AVL key type. */
121typedef uint32_t AVLU32KEY;
122
123/** AVL Core node. */
124typedef struct _AVLU32NodeCore
125{
126 AVLU32KEY Key; /**< Key value. */
127 struct _AVLU32NodeCore *pLeft; /**< Pointer to left leaf node. */
128 struct _AVLU32NodeCore *pRight; /**< Pointer to right leaf node. */
129 unsigned char uchHeight; /**< Height of this tree: max(height(left), height(right)) + 1 */
130} AVLU32NODECORE, *PAVLU32NODECORE, **PPAVLU32NODECORE;
131
132/** Callback function for AVLU32DoWithAll() & AVLU32Destroy(). */
133typedef DECLCALLBACK(int) AVLU32CALLBACK(PAVLU32NODECORE, void*);
134/** Pointer to callback function for AVLU32DoWithAll() & AVLU32Destroy(). */
135typedef AVLU32CALLBACK *PAVLU32CALLBACK;
136
137
138/*
139 * Functions.
140 */
141RTDECL(bool) RTAvlU32Insert(PPAVLU32NODECORE ppTree, PAVLU32NODECORE pNode);
142RTDECL(PAVLU32NODECORE) RTAvlU32Remove(PPAVLU32NODECORE ppTree, AVLU32KEY Key);
143RTDECL(PAVLU32NODECORE) RTAvlU32Get(PPAVLU32NODECORE ppTree, AVLU32KEY Key);
144RTDECL(PAVLU32NODECORE) RTAvlU32GetBestFit(PPAVLU32NODECORE ppTree, AVLU32KEY Key, bool fAbove);
145RTDECL(PAVLU32NODECORE) RTAvlU32RemoveBestFit(PPAVLU32NODECORE ppTree, AVLU32KEY Key, bool fAbove);
146RTDECL(int) RTAvlU32DoWithAll(PPAVLU32NODECORE ppTree, int fFromLeft, PAVLU32CALLBACK pfnCallBack, void *pvParam);
147RTDECL(int) RTAvlU32Destroy(PPAVLU32NODECORE pTree, PAVLU32CALLBACK pfnCallBack, void *pvParam);
148
149/** @} */
150
151
152
153/** AVL tree of uint32_t, list duplicates.
154 * @{
155 */
156
157/** AVL key type. */
158typedef uint32_t AVLLU32KEY;
159
160/** AVL Core node. */
161typedef struct _AVLLU32NodeCore
162{
163 AVLLU32KEY Key; /**< Key value. */
164 unsigned char uchHeight; /**< Height of this tree: max(height(left), height(right)) + 1 */
165 struct _AVLLU32NodeCore *pLeft; /**< Pointer to left leaf node. */
166 struct _AVLLU32NodeCore *pRight; /**< Pointer to right leaf node. */
167 struct _AVLLU32NodeCore *pList; /**< Pointer to next node with the same key. */
168} AVLLU32NODECORE, *PAVLLU32NODECORE, **PPAVLLU32NODECORE;
169
170/** Callback function for RTAvllU32DoWithAll() & RTAvllU32Destroy(). */
171typedef DECLCALLBACK(int) AVLLU32CALLBACK(PAVLLU32NODECORE, void*);
172/** Pointer to callback function for RTAvllU32DoWithAll() & RTAvllU32Destroy(). */
173typedef AVLLU32CALLBACK *PAVLLU32CALLBACK;
174
175
176/*
177 * Functions.
178 */
179RTDECL(bool) RTAvllU32Insert(PPAVLLU32NODECORE ppTree, PAVLLU32NODECORE pNode);
180RTDECL(PAVLLU32NODECORE) RTAvllU32Remove(PPAVLLU32NODECORE ppTree, AVLLU32KEY Key);
181RTDECL(PAVLLU32NODECORE) RTAvllU32Get(PPAVLLU32NODECORE ppTree, AVLLU32KEY Key);
182RTDECL(PAVLLU32NODECORE) RTAvllU32GetBestFit(PPAVLLU32NODECORE ppTree, AVLLU32KEY Key, bool fAbove);
183RTDECL(PAVLLU32NODECORE) RTAvllU32RemoveBestFit(PPAVLLU32NODECORE ppTree, AVLLU32KEY Key, bool fAbove);
184RTDECL(int) RTAvllU32DoWithAll(PPAVLLU32NODECORE ppTree, int fFromLeft, PAVLLU32CALLBACK pfnCallBack, void *pvParam);
185RTDECL(int) RTAvllU32Destroy(PPAVLLU32NODECORE pTree, PAVLLU32CALLBACK pfnCallBack, void *pvParam);
186
187/** @} */
188
189
190
191/** AVL tree of RTGCPHYSes - using relative offsets internally.
192 * @{
193 */
194
195/**
196 * AVL 'pointer' type for the relative offset pointer scheme.
197 */
198typedef int32_t AVLOGCPHYS;
199
200/**
201 * AVL Core node.
202 */
203typedef struct _AVLOGCPhysNodeCore
204{
205 /** Key value. */
206 RTGCPHYS Key;
207 /** Offset to the left leaf node, relative to this field. */
208 AVLOGCPHYS pLeft;
209 /** Offset to the right leaf node, relative to this field. */
210 AVLOGCPHYS pRight;
211 /** Height of this tree: max(height(left), height(right)) + 1 */
212 unsigned char uchHeight;
213} AVLOGCPHYSNODECORE, *PAVLOGCPHYSNODECORE;
214
215/** A offset base tree with uint32_t keys. */
216typedef AVLOGCPHYS AVLOGCPHYSTREE;
217/** Pointer to a offset base tree with uint32_t keys. */
218typedef AVLOGCPHYSTREE *PAVLOGCPHYSTREE;
219
220/** Pointer to an internal tree pointer.
221 * In this case it's a pointer to a relative offset. */
222typedef AVLOGCPHYSTREE *PPAVLOGCPHYSNODECORE;
223
224/** Callback function for RTAvloGCPhysDoWithAll() and RTAvloGCPhysDestroy(). */
225typedef DECLCALLBACK(int) AVLOGCPHYSCALLBACK(PAVLOGCPHYSNODECORE pNode, void *pvUser);
226/** Pointer to callback function for RTAvloGCPhysDoWithAll() and RTAvloGCPhysDestroy(). */
227typedef AVLOGCPHYSCALLBACK *PAVLOGCPHYSCALLBACK;
228
229RTDECL(bool) RTAvloGCPhysInsert(PAVLOGCPHYSTREE pTree, PAVLOGCPHYSNODECORE pNode);
230RTDECL(PAVLOGCPHYSNODECORE) RTAvloGCPhysRemove(PAVLOGCPHYSTREE pTree, RTGCPHYS Key);
231RTDECL(PAVLOGCPHYSNODECORE) RTAvloGCPhysGet(PAVLOGCPHYSTREE pTree, RTGCPHYS Key);
232RTDECL(int) RTAvloGCPhysDoWithAll(PAVLOGCPHYSTREE pTree, int fFromLeft, PAVLOGCPHYSCALLBACK pfnCallBack, void *pvParam);
233RTDECL(PAVLOGCPHYSNODECORE) RTAvloGCPhysGetBestFit(PAVLOGCPHYSTREE ppTree, RTGCPHYS Key, bool fAbove);
234RTDECL(PAVLOGCPHYSNODECORE) RTAvloGCPhysRemoveBestFit(PAVLOGCPHYSTREE ppTree, RTGCPHYS Key, bool fAbove);
235RTDECL(int) RTAvloGCPhysDestroy(PAVLOGCPHYSTREE pTree, PAVLOGCPHYSCALLBACK pfnCallBack, void *pvParam);
236
237/** @} */
238
239
240/** AVL tree of RTGCPHYS ranges - using relative offsets internally.
241 * @{
242 */
243
244/**
245 * AVL 'pointer' type for the relative offset pointer scheme.
246 */
247typedef int32_t AVLROGCPHYS;
248
249/**
250 * AVL Core node.
251 */
252typedef struct _AVLROGCPhysNodeCore
253{
254 /** First key value in the range (inclusive). */
255 RTGCPHYS Key;
256 /** Last key value in the range (inclusive). */
257 RTGCPHYS KeyLast;
258 /** Offset to the left leaf node, relative to this field. */
259 AVLROGCPHYS pLeft;
260 /** Offset to the right leaf node, relative to this field. */
261 AVLROGCPHYS pRight;
262 /** Height of this tree: max(height(left), height(right)) + 1 */
263 unsigned char uchHeight;
264} AVLROGCPHYSNODECORE, *PAVLROGCPHYSNODECORE;
265
266/** A offset base tree with uint32_t keys. */
267typedef AVLROGCPHYS AVLROGCPHYSTREE;
268/** Pointer to a offset base tree with uint32_t keys. */
269typedef AVLROGCPHYSTREE *PAVLROGCPHYSTREE;
270
271/** Pointer to an internal tree pointer.
272 * In this case it's a pointer to a relative offset. */
273typedef AVLROGCPHYSTREE *PPAVLROGCPHYSNODECORE;
274
275/** Callback function for RTAvlroGCPhysDoWithAll() and RTAvlroGCPhysDestroy(). */
276typedef DECLCALLBACK(int) AVLROGCPHYSCALLBACK(PAVLROGCPHYSNODECORE pNode, void *pvUser);
277/** Pointer to callback function for RTAvlroGCPhysDoWithAll() and RTAvlroGCPhysDestroy(). */
278typedef AVLROGCPHYSCALLBACK *PAVLROGCPHYSCALLBACK;
279
280RTDECL(bool) RTAvlroGCPhysInsert(PAVLROGCPHYSTREE pTree, PAVLROGCPHYSNODECORE pNode);
281RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysRemove(PAVLROGCPHYSTREE pTree, RTGCPHYS Key);
282RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysGet(PAVLROGCPHYSTREE pTree, RTGCPHYS Key);
283RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysRangeGet(PAVLROGCPHYSTREE pTree, RTGCPHYS Key);
284RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysRangeRemove(PAVLROGCPHYSTREE pTree, RTGCPHYS Key);
285RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysGetBestFit(PAVLROGCPHYSTREE ppTree, RTGCPHYS Key, bool fAbove);
286RTDECL(int) RTAvlroGCPhysDoWithAll(PAVLROGCPHYSTREE pTree, int fFromLeft, PAVLROGCPHYSCALLBACK pfnCallBack, void *pvParam);
287RTDECL(int) RTAvlroGCPhysDestroy(PAVLROGCPHYSTREE pTree, PAVLROGCPHYSCALLBACK pfnCallBack, void *pvParam);
288RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysGetRoot(PAVLROGCPHYSTREE pTree);
289RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysGetLeft(PAVLROGCPHYSNODECORE pNode);
290RTDECL(PAVLROGCPHYSNODECORE) RTAvlroGCPhysGetRight(PAVLROGCPHYSNODECORE pNode);
291
292/** @} */
293
294
295/** AVL tree of RTGCPTRs.
296 * @{
297 */
298
299/**
300 * AVL Core node.
301 */
302typedef struct _AVLGCPtrNodeCore
303{
304 /** Key value. */
305 RTGCPTR Key;
306 /** Pointer to the left node. */
307 struct _AVLGCPtrNodeCore *pLeft;
308 /** Pointer to the right node. */
309 struct _AVLGCPtrNodeCore *pRight;
310 /** Height of this tree: max(height(left), height(right)) + 1 */
311 unsigned char uchHeight;
312} AVLGCPTRNODECORE, *PAVLGCPTRNODECORE, **PPAVLGCPTRNODECORE;
313
314/** A tree of RTGCPTR keys. */
315typedef PAVLGCPTRNODECORE AVLGCPTRTREE;
316/** Pointer to a tree of RTGCPTR keys. */
317typedef PPAVLGCPTRNODECORE PAVLGCPTRTREE;
318
319/** Callback function for RTAvlGCPtrDoWithAll(). */
320typedef DECLCALLBACK(int) AVLGCPTRCALLBACK(PAVLGCPTRNODECORE pNode, void *pvUser);
321/** Pointer to callback function for RTAvlGCPtrDoWithAll(). */
322typedef AVLGCPTRCALLBACK *PAVLGCPTRCALLBACK;
323
324RTDECL(bool) RTAvlGCPtrInsert(PAVLGCPTRTREE pTree, PAVLGCPTRNODECORE pNode);
325RTDECL(PAVLGCPTRNODECORE) RTAvlGCPtrRemove(PAVLGCPTRTREE pTree, RTGCPTR Key);
326RTDECL(PAVLGCPTRNODECORE) RTAvlGCPtrGet(PAVLGCPTRTREE pTree, RTGCPTR Key);
327RTDECL(int) RTAvlGCPtrDoWithAll(PAVLGCPTRTREE pTree, int fFromLeft, PAVLGCPTRCALLBACK pfnCallBack, void *pvParam);
328RTDECL(PAVLGCPTRNODECORE) RTAvlGCPtrGetBestFit(PAVLGCPTRTREE ppTree, RTGCPTR Key, bool fAbove);
329RTDECL(PAVLGCPTRNODECORE) RTAvlGCPtrRemoveBestFit(PAVLGCPTRTREE ppTree, RTGCPTR Key, bool fAbove);
330RTDECL(int) RTAvlGCPtrDestroy(PAVLGCPTRTREE pTree, PAVLGCPTRCALLBACK pfnCallBack, void *pvParam);
331
332/** @} */
333
334
335/** AVL tree of RTGCPTRs - using relative offsets internally.
336 * @{
337 */
338
339/**
340 * AVL 'pointer' type for the relative offset pointer scheme.
341 */
342typedef int32_t AVLOGCPTR;
343
344/**
345 * AVL Core node.
346 */
347typedef struct _AVLOGCPtrNodeCore
348{
349 /** Key value. */
350 RTGCPTR Key;
351 /** Offset to the left leaf node, relative to this field. */
352 AVLOGCPTR pLeft;
353 /** Offset to the right leaf node, relative to this field. */
354 AVLOGCPTR pRight;
355 /** Height of this tree: max(height(left), height(right)) + 1 */
356 unsigned char uchHeight;
357} AVLOGCPTRNODECORE, *PAVLOGCPTRNODECORE;
358
359/** A offset base tree with uint32_t keys. */
360typedef AVLOGCPTR AVLOGCPTRTREE;
361/** Pointer to a offset base tree with uint32_t keys. */
362typedef AVLOGCPTRTREE *PAVLOGCPTRTREE;
363
364/** Pointer to an internal tree pointer.
365 * In this case it's a pointer to a relative offset. */
366typedef AVLOGCPTRTREE *PPAVLOGCPTRNODECORE;
367
368/** Callback function for RTAvloGCPtrDoWithAll(). */
369typedef DECLCALLBACK(int) AVLOGCPTRCALLBACK(PAVLOGCPTRNODECORE pNode, void *pvUser);
370/** Pointer to callback function for RTAvloGCPtrDoWithAll(). */
371typedef AVLOGCPTRCALLBACK *PAVLOGCPTRCALLBACK;
372
373RTDECL(bool) RTAvloGCPtrInsert(PAVLOGCPTRTREE pTree, PAVLOGCPTRNODECORE pNode);
374RTDECL(PAVLOGCPTRNODECORE) RTAvloGCPtrRemove(PAVLOGCPTRTREE pTree, RTGCPTR Key);
375RTDECL(PAVLOGCPTRNODECORE) RTAvloGCPtrGet(PAVLOGCPTRTREE pTree, RTGCPTR Key);
376RTDECL(int) RTAvloGCPtrDoWithAll(PAVLOGCPTRTREE pTree, int fFromLeft, PAVLOGCPTRCALLBACK pfnCallBack, void *pvParam);
377RTDECL(PAVLOGCPTRNODECORE) RTAvloGCPtrGetBestFit(PAVLOGCPTRTREE ppTree, RTGCPTR Key, bool fAbove);
378RTDECL(PAVLOGCPTRNODECORE) RTAvloGCPtrRemoveBestFit(PAVLOGCPTRTREE ppTree, RTGCPTR Key, bool fAbove);
379RTDECL(int) RTAvloGCPtrDestroy(PAVLOGCPTRTREE pTree, PAVLOGCPTRCALLBACK pfnCallBack, void *pvParam);
380
381/** @} */
382
383
384/** AVL tree of RTGCPTR ranges.
385 * @{
386 */
387
388/**
389 * AVL Core node.
390 */
391typedef struct _AVLRGCPtrNodeCore
392{
393 /** First key value in the range (inclusive). */
394 RTGCPTR Key;
395 /** Last key value in the range (inclusive). */
396 RTGCPTR KeyLast;
397 /** Offset to the left leaf node, relative to this field. */
398 struct _AVLRGCPtrNodeCore *pLeft;
399 /** Offset to the right leaf node, relative to this field. */
400 struct _AVLRGCPtrNodeCore *pRight;
401 /** Height of this tree: max(height(left), height(right)) + 1 */
402 unsigned char uchHeight;
403} AVLRGCPTRNODECORE, *PAVLRGCPTRNODECORE;
404
405/** A offset base tree with RTGCPTR keys. */
406typedef PAVLRGCPTRNODECORE AVLRGCPTRTREE;
407/** Pointer to a offset base tree with RTGCPTR keys. */
408typedef AVLRGCPTRTREE *PAVLRGCPTRTREE;
409
410/** Pointer to an internal tree pointer.
411 * In this case it's a pointer to a relative offset. */
412typedef AVLRGCPTRTREE *PPAVLRGCPTRNODECORE;
413
414/** Callback function for RTAvlrGCPtrDoWithAll() and RTAvlrGCPtrDestroy(). */
415typedef DECLCALLBACK(int) AVLRGCPTRCALLBACK(PAVLRGCPTRNODECORE pNode, void *pvUser);
416/** Pointer to callback function for RTAvlrGCPtrDoWithAll() and RTAvlrGCPtrDestroy(). */
417typedef AVLRGCPTRCALLBACK *PAVLRGCPTRCALLBACK;
418
419RTDECL(bool) RTAvlrGCPtrInsert( PAVLRGCPTRTREE pTree, PAVLRGCPTRNODECORE pNode);
420RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrRemove( PAVLRGCPTRTREE pTree, RTGCPTR Key);
421RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrGet( PAVLRGCPTRTREE pTree, RTGCPTR Key);
422RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrGetBestFit( PAVLRGCPTRTREE pTree, RTGCPTR Key, bool fAbove);
423RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrRangeGet( PAVLRGCPTRTREE pTree, RTGCPTR Key);
424RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrRangeRemove( PAVLRGCPTRTREE pTree, RTGCPTR Key);
425RTDECL(int) RTAvlrGCPtrDoWithAll( PAVLRGCPTRTREE pTree, int fFromLeft, PAVLRGCPTRCALLBACK pfnCallBack, void *pvParam);
426RTDECL(int) RTAvlrGCPtrDestroy( PAVLRGCPTRTREE pTree, PAVLRGCPTRCALLBACK pfnCallBack, void *pvParam);
427RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrGetRoot( PAVLRGCPTRTREE pTree);
428RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrGetLeft( PAVLRGCPTRNODECORE pNode);
429RTDECL(PAVLRGCPTRNODECORE) RTAvlrGCPtrGetRight( PAVLRGCPTRNODECORE pNode);
430
431/** @} */
432
433
434/** AVL tree of RTGCPTR ranges - using relative offsets internally.
435 * @{
436 */
437
438/**
439 * AVL 'pointer' type for the relative offset pointer scheme.
440 */
441typedef int32_t AVLROGCPTR;
442
443/**
444 * AVL Core node.
445 */
446typedef struct _AVLROGCPtrNodeCore
447{
448 /** First key value in the range (inclusive). */
449 RTGCPTR Key;
450 /** Last key value in the range (inclusive). */
451 RTGCPTR KeyLast;
452 /** Offset to the left leaf node, relative to this field. */
453 AVLROGCPTR pLeft;
454 /** Offset to the right leaf node, relative to this field. */
455 AVLROGCPTR pRight;
456 /** Height of this tree: max(height(left), height(right)) + 1 */
457 unsigned char uchHeight;
458} AVLROGCPTRNODECORE, *PAVLROGCPTRNODECORE;
459
460/** A offset base tree with uint32_t keys. */
461typedef AVLROGCPTR AVLROGCPTRTREE;
462/** Pointer to a offset base tree with uint32_t keys. */
463typedef AVLROGCPTRTREE *PAVLROGCPTRTREE;
464
465/** Pointer to an internal tree pointer.
466 * In this case it's a pointer to a relative offset. */
467typedef AVLROGCPTRTREE *PPAVLROGCPTRNODECORE;
468
469/** Callback function for RTAvlroGCPtrDoWithAll() and RTAvlroGCPtrDestroy(). */
470typedef DECLCALLBACK(int) AVLROGCPTRCALLBACK(PAVLROGCPTRNODECORE pNode, void *pvUser);
471/** Pointer to callback function for RTAvlroGCPtrDoWithAll() and RTAvlroGCPtrDestroy(). */
472typedef AVLROGCPTRCALLBACK *PAVLROGCPTRCALLBACK;
473
474RTDECL(bool) RTAvlroGCPtrInsert(PAVLROGCPTRTREE pTree, PAVLROGCPTRNODECORE pNode);
475RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrRemove(PAVLROGCPTRTREE pTree, RTGCPTR Key);
476RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrGet(PAVLROGCPTRTREE pTree, RTGCPTR Key);
477RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrGetBestFit(PAVLROGCPTRTREE ppTree, RTGCPTR Key, bool fAbove);
478RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrRangeGet(PAVLROGCPTRTREE pTree, RTGCPTR Key);
479RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrRangeRemove(PAVLROGCPTRTREE pTree, RTGCPTR Key);
480RTDECL(int) RTAvlroGCPtrDoWithAll(PAVLROGCPTRTREE pTree, int fFromLeft, PAVLROGCPTRCALLBACK pfnCallBack, void *pvParam);
481RTDECL(int) RTAvlroGCPtrDestroy(PAVLROGCPTRTREE pTree, PAVLROGCPTRCALLBACK pfnCallBack, void *pvParam);
482RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrGetRoot(PAVLROGCPTRTREE pTree);
483RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrGetLeft(PAVLROGCPTRNODECORE pNode);
484RTDECL(PAVLROGCPTRNODECORE) RTAvlroGCPtrGetRight(PAVLROGCPTRNODECORE pNode);
485
486/** @} */
487
488
489/** AVL tree of RTGCPTR ranges (overlapping supported) - using relative offsets internally.
490 * @{
491 */
492
493/**
494 * AVL 'pointer' type for the relative offset pointer scheme.
495 */
496typedef int32_t AVLROOGCPTR;
497
498/**
499 * AVL Core node.
500 */
501typedef struct _AVLROOGCPtrNodeCore
502{
503 /** First key value in the range (inclusive). */
504 RTGCPTR Key;
505 /** Last key value in the range (inclusive). */
506 RTGCPTR KeyLast;
507 /** Offset to the left leaf node, relative to this field. */
508 AVLROOGCPTR pLeft;
509 /** Offset to the right leaf node, relative to this field. */
510 AVLROOGCPTR pRight;
511 /** Pointer to the list of string with the same key. Don't touch. */
512 AVLROOGCPTR pList;
513 /** Height of this tree: max(height(left), height(right)) + 1 */
514 unsigned char uchHeight;
515} AVLROOGCPTRNODECORE, *PAVLROOGCPTRNODECORE;
516
517/** A offset base tree with uint32_t keys. */
518typedef AVLROOGCPTR AVLROOGCPTRTREE;
519/** Pointer to a offset base tree with uint32_t keys. */
520typedef AVLROOGCPTRTREE *PAVLROOGCPTRTREE;
521
522/** Pointer to an internal tree pointer.
523 * In this case it's a pointer to a relative offset. */
524typedef AVLROOGCPTRTREE *PPAVLROOGCPTRNODECORE;
525
526/** Callback function for RTAvlrooGCPtrDoWithAll() and RTAvlrooGCPtrDestroy(). */
527typedef DECLCALLBACK(int) AVLROOGCPTRCALLBACK(PAVLROOGCPTRNODECORE pNode, void *pvUser);
528/** Pointer to callback function for RTAvlrooGCPtrDoWithAll() and RTAvlrooGCPtrDestroy(). */
529typedef AVLROOGCPTRCALLBACK *PAVLROOGCPTRCALLBACK;
530
531RTDECL(bool) RTAvlrooGCPtrInsert(PAVLROOGCPTRTREE pTree, PAVLROOGCPTRNODECORE pNode);
532RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrRemove(PAVLROOGCPTRTREE pTree, RTGCPTR Key);
533RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrGet(PAVLROOGCPTRTREE pTree, RTGCPTR Key);
534RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrGetBestFit(PAVLROOGCPTRTREE ppTree, RTGCPTR Key, bool fAbove);
535RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrRangeGet(PAVLROOGCPTRTREE pTree, RTGCPTR Key);
536RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrRangeRemove(PAVLROOGCPTRTREE pTree, RTGCPTR Key);
537RTDECL(int) RTAvlrooGCPtrDoWithAll(PAVLROOGCPTRTREE pTree, int fFromLeft, PAVLROOGCPTRCALLBACK pfnCallBack, void *pvParam);
538RTDECL(int) RTAvlrooGCPtrDestroy(PAVLROOGCPTRTREE pTree, PAVLROOGCPTRCALLBACK pfnCallBack, void *pvParam);
539RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrGetRoot(PAVLROOGCPTRTREE pTree);
540RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrGetLeft(PAVLROOGCPTRNODECORE pNode);
541RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrGetRight(PAVLROOGCPTRNODECORE pNode);
542RTDECL(PAVLROOGCPTRNODECORE) RTAvlrooGCPtrGetNextEqual(PAVLROOGCPTRNODECORE pNode);
543
544/** @} */
545
546
547/** AVL tree of RTHCPHYSes - using relative offsets internally.
548 * @{
549 */
550
551/**
552 * AVL 'pointer' type for the relative offset pointer scheme.
553 */
554typedef int32_t AVLOHCPHYS;
555
556/**
557 * AVL Core node.
558 */
559typedef struct _AVLOHCPhysNodeCore
560{
561 /** Key value. */
562 RTHCPHYS Key;
563 /** Offset to the left leaf node, relative to this field. */
564 AVLOHCPHYS pLeft;
565 /** Offset to the right leaf node, relative to this field. */
566 AVLOHCPHYS pRight;
567 /** Height of this tree: max(height(left), height(right)) + 1 */
568 unsigned char uchHeight;
569#if HC_ARCH_BITS == 64 || GC_ARCH_BITS == 64
570 unsigned char Padding[7]; /**< Alignment padding. */
571#endif
572} AVLOHCPHYSNODECORE, *PAVLOHCPHYSNODECORE;
573
574/** A offset base tree with uint32_t keys. */
575typedef AVLOHCPHYS AVLOHCPHYSTREE;
576/** Pointer to a offset base tree with uint32_t keys. */
577typedef AVLOHCPHYSTREE *PAVLOHCPHYSTREE;
578
579/** Pointer to an internal tree pointer.
580 * In this case it's a pointer to a relative offset. */
581typedef AVLOHCPHYSTREE *PPAVLOHCPHYSNODECORE;
582
583/** Callback function for RTAvloHCPhysDoWithAll() and RTAvloHCPhysDestroy(). */
584typedef DECLCALLBACK(int) AVLOHCPHYSCALLBACK(PAVLOHCPHYSNODECORE pNode, void *pvUser);
585/** Pointer to callback function for RTAvloHCPhysDoWithAll() and RTAvloHCPhysDestroy(). */
586typedef AVLOHCPHYSCALLBACK *PAVLOHCPHYSCALLBACK;
587
588RTDECL(bool) RTAvloHCPhysInsert(PAVLOHCPHYSTREE pTree, PAVLOHCPHYSNODECORE pNode);
589RTDECL(PAVLOHCPHYSNODECORE) RTAvloHCPhysRemove(PAVLOHCPHYSTREE pTree, RTHCPHYS Key);
590RTDECL(PAVLOHCPHYSNODECORE) RTAvloHCPhysGet(PAVLOHCPHYSTREE pTree, RTHCPHYS Key);
591RTDECL(int) RTAvloHCPhysDoWithAll(PAVLOHCPHYSTREE pTree, int fFromLeft, PAVLOHCPHYSCALLBACK pfnCallBack, void *pvParam);
592RTDECL(PAVLOHCPHYSNODECORE) RTAvloHCPhysGetBestFit(PAVLOHCPHYSTREE ppTree, RTHCPHYS Key, bool fAbove);
593RTDECL(PAVLOHCPHYSNODECORE) RTAvloHCPhysRemoveBestFit(PAVLOHCPHYSTREE ppTree, RTHCPHYS Key, bool fAbove);
594RTDECL(int) RTAvloHCPhysDestroy(PAVLOHCPHYSTREE pTree, PAVLOHCPHYSCALLBACK pfnCallBack, void *pvParam);
595
596/** @} */
597
598
599
600/** AVL tree of RTIOPORTs - using relative offsets internally.
601 * @{
602 */
603
604/**
605 * AVL 'pointer' type for the relative offset pointer scheme.
606 */
607typedef int32_t AVLOIOPORTPTR;
608
609/**
610 * AVL Core node.
611 */
612typedef struct _AVLOIOPortNodeCore
613{
614 /** Offset to the left leaf node, relative to this field. */
615 AVLOIOPORTPTR pLeft;
616 /** Offset to the right leaf node, relative to this field. */
617 AVLOIOPORTPTR pRight;
618 /** Key value. */
619 RTIOPORT Key;
620 /** Height of this tree: max(height(left), height(right)) + 1 */
621 unsigned char uchHeight;
622} AVLOIOPORTNODECORE, *PAVLOIOPORTNODECORE;
623
624/** A offset base tree with uint32_t keys. */
625typedef AVLOIOPORTPTR AVLOIOPORTTREE;
626/** Pointer to a offset base tree with uint32_t keys. */
627typedef AVLOIOPORTTREE *PAVLOIOPORTTREE;
628
629/** Pointer to an internal tree pointer.
630 * In this case it's a pointer to a relative offset. */
631typedef AVLOIOPORTTREE *PPAVLOIOPORTNODECORE;
632
633/** Callback function for RTAvloIOPortDoWithAll() and RTAvloIOPortDestroy(). */
634typedef DECLCALLBACK(int) AVLOIOPORTCALLBACK(PAVLOIOPORTNODECORE pNode, void *pvUser);
635/** Pointer to callback function for RTAvloIOPortDoWithAll() and RTAvloIOPortDestroy(). */
636typedef AVLOIOPORTCALLBACK *PAVLOIOPORTCALLBACK;
637
638RTDECL(bool) RTAvloIOPortInsert(PAVLOIOPORTTREE pTree, PAVLOIOPORTNODECORE pNode);
639RTDECL(PAVLOIOPORTNODECORE) RTAvloIOPortRemove(PAVLOIOPORTTREE pTree, RTIOPORT Key);
640RTDECL(PAVLOIOPORTNODECORE) RTAvloIOPortGet(PAVLOIOPORTTREE pTree, RTIOPORT Key);
641RTDECL(int) RTAvloIOPortDoWithAll(PAVLOIOPORTTREE pTree, int fFromLeft, PAVLOIOPORTCALLBACK pfnCallBack, void *pvParam);
642RTDECL(int) RTAvloIOPortDestroy(PAVLOIOPORTTREE pTree, PAVLOIOPORTCALLBACK pfnCallBack, void *pvParam);
643
644/** @} */
645
646
647/** AVL tree of RTIOPORT ranges - using relative offsets internally.
648 * @{
649 */
650
651/**
652 * AVL 'pointer' type for the relative offset pointer scheme.
653 */
654typedef int32_t AVLROIOPORTPTR;
655
656/**
657 * AVL Core node.
658 */
659typedef struct _AVLROIOPortNodeCore
660{
661 /** First key value in the range (inclusive). */
662 RTIOPORT Key;
663 /** Last key value in the range (inclusive). */
664 RTIOPORT KeyLast;
665 /** Offset to the left leaf node, relative to this field. */
666 AVLROIOPORTPTR pLeft;
667 /** Offset to the right leaf node, relative to this field. */
668 AVLROIOPORTPTR pRight;
669 /** Height of this tree: max(height(left), height(right)) + 1 */
670 unsigned char uchHeight;
671} AVLROIOPORTNODECORE, *PAVLROIOPORTNODECORE;
672
673/** A offset base tree with uint32_t keys. */
674typedef AVLROIOPORTPTR AVLROIOPORTTREE;
675/** Pointer to a offset base tree with uint32_t keys. */
676typedef AVLROIOPORTTREE *PAVLROIOPORTTREE;
677
678/** Pointer to an internal tree pointer.
679 * In this case it's a pointer to a relative offset. */
680typedef AVLROIOPORTTREE *PPAVLROIOPORTNODECORE;
681
682/** Callback function for RTAvlroIOPortDoWithAll() and RTAvlroIOPortDestroy(). */
683typedef DECLCALLBACK(int) AVLROIOPORTCALLBACK(PAVLROIOPORTNODECORE pNode, void *pvUser);
684/** Pointer to callback function for RTAvlroIOPortDoWithAll() and RTAvlroIOPortDestroy(). */
685typedef AVLROIOPORTCALLBACK *PAVLROIOPORTCALLBACK;
686
687RTDECL(bool) RTAvlroIOPortInsert(PAVLROIOPORTTREE pTree, PAVLROIOPORTNODECORE pNode);
688RTDECL(PAVLROIOPORTNODECORE) RTAvlroIOPortRemove(PAVLROIOPORTTREE pTree, RTIOPORT Key);
689RTDECL(PAVLROIOPORTNODECORE) RTAvlroIOPortGet(PAVLROIOPORTTREE pTree, RTIOPORT Key);
690RTDECL(PAVLROIOPORTNODECORE) RTAvlroIOPortRangeGet(PAVLROIOPORTTREE pTree, RTIOPORT Key);
691RTDECL(PAVLROIOPORTNODECORE) RTAvlroIOPortRangeRemove(PAVLROIOPORTTREE pTree, RTIOPORT Key);
692RTDECL(int) RTAvlroIOPortDoWithAll(PAVLROIOPORTTREE pTree, int fFromLeft, PAVLROIOPORTCALLBACK pfnCallBack, void *pvParam);
693RTDECL(int) RTAvlroIOPortDestroy(PAVLROIOPORTTREE pTree, PAVLROIOPORTCALLBACK pfnCallBack, void *pvParam);
694
695/** @} */
696
697
698/** AVL tree of RTHCPHYSes.
699 * @{
700 */
701
702/**
703 * AVL 'pointer' type for the relative offset pointer scheme.
704 */
705typedef struct _AVLHCPhysNodeCore *AVLHCPHYSPTR;
706
707/**
708 * AVL Core node.
709 */
710typedef struct _AVLHCPhysNodeCore
711{
712 /** Offset to the left leaf node, relative to this field. */
713 AVLHCPHYSPTR pLeft;
714 /** Offset to the right leaf node, relative to this field. */
715 AVLHCPHYSPTR pRight;
716 /** Key value. */
717 RTHCPHYS Key;
718 /** Height of this tree: max(height(left), height(right)) + 1 */
719 unsigned char uchHeight;
720} AVLHCPHYSNODECORE, *PAVLHCPHYSNODECORE;
721
722/** A offset base tree with RTHCPHYS keys. */
723typedef AVLHCPHYSPTR AVLHCPHYSTREE;
724/** Pointer to a offset base tree with RTHCPHYS keys. */
725typedef AVLHCPHYSTREE *PAVLHCPHYSTREE;
726
727/** Pointer to an internal tree pointer.
728 * In this case it's a pointer to a relative offset. */
729typedef AVLHCPHYSTREE *PPAVLHCPHYSNODECORE;
730
731/** Callback function for RTAvlHCPhysDoWithAll() and RTAvlHCPhysDestroy(). */
732typedef DECLCALLBACK(int) AVLHCPHYSCALLBACK(PAVLHCPHYSNODECORE pNode, void *pvUser);
733/** Pointer to callback function for RTAvlHCPhysDoWithAll() and RTAvlHCPhysDestroy(). */
734typedef AVLHCPHYSCALLBACK *PAVLHCPHYSCALLBACK;
735
736RTDECL(bool) RTAvlHCPhysInsert(PAVLHCPHYSTREE pTree, PAVLHCPHYSNODECORE pNode);
737RTDECL(PAVLHCPHYSNODECORE) RTAvlHCPhysRemove(PAVLHCPHYSTREE pTree, RTHCPHYS Key);
738RTDECL(PAVLHCPHYSNODECORE) RTAvlHCPhysGet(PAVLHCPHYSTREE pTree, RTHCPHYS Key);
739RTDECL(int) RTAvlHCPhysDoWithAll(PAVLHCPHYSTREE pTree, int fFromLeft, PAVLHCPHYSCALLBACK pfnCallBack, void *pvParam);
740RTDECL(PAVLHCPHYSNODECORE) RTAvlHCPhysGetBestFit(PAVLHCPHYSTREE ppTree, RTHCPHYS Key, bool fAbove);
741RTDECL(PAVLHCPHYSNODECORE) RTAvlHCPhysRemoveBestFit(PAVLHCPHYSTREE ppTree, RTHCPHYS Key, bool fAbove);
742RTDECL(int) RTAvlHCPhysDestroy(PAVLHCPHYSTREE pTree, PAVLHCPHYSCALLBACK pfnCallBack, void *pvParam);
743
744/** @} */
745
746
747/** @} */
748
749__END_DECLS
750
751#endif
752
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette