]> git.itanic.dy.fi Git - scan-pagemap/blob - bintree.h
Print verbose output during operation
[scan-pagemap] / bintree.h
1 /*
2  * Copyright (C) 2010 Timo Kokkonen <kaapeli@itanic.dy.fi>
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License.
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11  * GNU General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License
14  * along with this program; if not, write to the Free Software
15  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
16  */
17
18 #ifndef _BINTREE_H
19 #define _BINTREE_H
20
21 struct bintree {
22         struct bintree *left, *right;
23 };
24
25 struct bintree_ops {
26         int (*compare)(struct bintree *a, struct bintree *b);
27         void (*callback)(struct bintree *tree, struct bintree_ops *ops);
28 };
29
30 struct bintree *bintree_add(struct bintree *tree, struct bintree *new,
31                         struct bintree_ops *ops);
32 struct bintree *bintree_find(struct bintree *tree, struct bintree *new,
33                         struct bintree_ops *ops);
34 int bintree_walk(struct bintree *tree, struct bintree_ops *ops);
35
36 #endif