2 Unix SMB/CIFS implementation.
4 very efficient functions to manage mapping a id (such as a fnum) to
5 a pointer. This is used for fnum and search id allocation.
7 Copyright (C) Andrew Tridgell 2004
9 This code is derived from lib/idr.c in the 2.6 Linux kernel, which was
10 written by Jim Houston jim.houston@ccur.com, and is
11 Copyright (C) 2002 by Concurrent Computer Corporation
13 This program is free software; you can redistribute it and/or modify
14 it under the terms of the GNU General Public License as published by
15 the Free Software Foundation; either version 2 of the License, or
16 (at your option) any later version.
18 This program is distributed in the hope that it will be useful,
19 but WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 GNU General Public License for more details.
23 You should have received a copy of the GNU General Public License
24 along with this program. If not, see <http://www.gnu.org/licenses/>.
27 #ifndef _SAMBA_IDTREE_H_
28 #define _SAMBA_IDTREE_H_
35 initialise a idr tree. The context return value must be passed to
36 all subsequent idr calls. To destroy the idr tree use talloc_free()
39 struct idr_context
*idr_init(TALLOC_CTX
*mem_ctx
);
42 allocate the next available id, and assign 'ptr' into its slot.
43 you can retrieve later this pointer using idr_find()
45 int idr_get_new(struct idr_context
*idp
, void *ptr
, int limit
);
48 allocate a new id, giving the first available value greater than or
49 equal to the given starting id
51 int idr_get_new_above(struct idr_context
*idp
, void *ptr
, int starting_id
, int limit
);
54 allocate a new id randomly in the given range
56 int idr_get_new_random(struct idr_context
*idp
, void *ptr
, int limit
);
59 find a pointer value previously set with idr_get_new given an id
61 void *idr_find(struct idr_context
*idp
, int id
);
64 remove an id from the idr tree
66 int idr_remove(struct idr_context
*idp
, int id
);
68 #endif /* _SAMBA_IDTREE_H_ */